利用Squid实现局域网内多台机器共享上网

简述

服务器A为内网机器,服务器B和A在同一局域网环境,服务器B可以访问外部网络,现在希望服务器A可以通过服务器B访问外部网络

  1. 在服务器B上设置代理服务器:

    Squid作为代理服务器。在服务器B上安装并配置Squid:

    bash 复制代码
    # 在服务器B上
    sudo yum install squid
    sudo vi /etc/squid/squid.conf

    在squid.conf中添加或修改以下内容:

    bash 复制代码
    http_port 3128
    acl localnet src 10.0.0.0/8     # 假设您的局域网IP范围
    http_access allow localnet
    http_access deny all

    启动Squid服务:

    bash 复制代码
    sudo systemctl start squid
    sudo systemctl enable squid
  2. 在服务器A上配置代理设置:

    设置环境变量:

    bash 复制代码
    # 在服务器A上
    export http_proxy="http://服务器B的IP:3128"
    export https_proxy="http://服务器B的IP:3128"

    为了使这些设置永久生效,将它们添加到/etc/profile或~/.bashrc文件中。

  3. 配置特定工具使用代理:

    对于yum:

    编辑/etc/yum.conf,添加:

    bash 复制代码
    proxy=http://服务器B的IP:3128

    对于docker:

    创建或编辑/etc/systemd/system/docker.service.d/http-proxy.conf:

    bash 复制代码
    [Service]
    Environment="HTTP_PROXY=http://服务器B的IP:3128"
    Environment="HTTPS_PROXY=http://服务器B的IP:3128"

    然后重启Docker服务:

    bash 复制代码
    sudo systemctl daemon-reload
    sudo systemctl restart docker

    对于git:

    bash 复制代码
    git config --global http.proxy http://服务器B的IP:3128
    git config --global https.proxy http://服务器B的IP:3128
  4. 测试连接:

    在服务器A上测试各个工具:

    bash 复制代码
    yum update
    docker pull hello-world
    git clone https://github.com/some/repository.git

请注意使用代理可能会带来一些安全风险,请确保采取适当的安全措施,如限制代理访问和监控流量。可以考虑使用 openvpn 实现。

相关推荐
IMPYLH20 分钟前
Linux 的 wc 命令
linux·运维·服务器·前端·bash
zxy64449247331 分钟前
Centos7.9编译安装PHP7.4
linux·运维·服务器
无限进步_34 分钟前
【Linux】从冯诺依曼到操作系统:理解计算机运行的基本脉络
linux·运维·服务器
Rabbit_QL1 小时前
【ln -s】Linux 软链接在大模型部署中的应用
linux·运维·服务器
希望永不加班1 小时前
var局部变量类型推断的利弊
java·服务器·前端·javascript·html
樱桃花下的小猫2 小时前
游戏云服务器定时任务设置教程
服务器·游戏·新手友好·云鸢互联·零门槛一键开服
oo哦哦3 小时前
同城矩阵系统的中心地密码:用克里斯塔勒中心地理论和引力模型,解释为什么你的10个探店号加起来,还不如别人3个
服务器·人工智能·矩阵
Anthony_2313 小时前
Linux 防火墙完全指南:从 iptables 到 firewalld
linux·运维·服务器
月走乂山3 小时前
Linux 服务器安装 CC Switch GUI 工具 + VNC 远程桌面完整教程
linux·运维·服务器
IpdataCloud4 小时前
企业IT管理中,如何通过IP地址查询定位快速溯源异常终端?用IP离线库实现
服务器·网络·数据库·tcp/ip