Squid代理服务器配置

需求是:通过外网机(跳板机)访问内网机,并为内网机提供访问网络的能力。

【跳板机T】+【内网机N】
公网IP:39.107.xx.xxx
跳板机IP:172.17.216.234
内网机IP:172.17.216.241
Squid代理服务器地址和端口:172.17.216.234:3128

写在前头,使用FinalShell配置跳板机和内网机,原理就是通过本地端口进行一次转发。

1、新建跳板机T的ssh连接,然后添加隧道,监听端口填个一般用不到的就行。 

2、新建内网机N的ssh连接,主机和端口则使用上面隧道配置的绑定ip和监听端口。

3、先访问跳板机T,再访问内网机N就ok了。

 

一、跳板机T安装Squid代理服务器 

1、安装Squid 

sudo apt update
sudo apt install squid

2、配置访问控制,修改/etc/squid/squid.conf文件,增加行信息如下,配置允许内网机N访问 

acl host241 src 172.17.216.241
http_access allow host241
access_log /var/log/squid/access.log squid

注意Squid的默认端口是3128,可在配置中进行修改http_port 

3、检查配置是否有误,然后重启使生效

squid  -k parse 
sudo systemctl restart squid

 4、使用NAT(网络地址转换),需启用 IP 转发  /etc/sysctl.conf

sudo sysctl -w net.ipv4.ip_forward=1

二、内网机N进行代理网络配置 

1、设置NAT规则,内网服务器上配置 MASQUERADE 规则,将内网服务器的流量重定向到外部接口 

sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

 2、查看NAT表的规则,确认配置成功

sudo iptables -t nat -L

 3、配置代理,进入/etc/profile文件,增加行信息设置代理服务器的ip和端口号

export http_proxy=http://172.17.216.234:3128
export https_proxy=http://172.17.216.234:3128
export no_proxy=localhost,*.local,127.0.0.1,192.168.*.*

4、source /etc/profile 使配置生效 

source /etc/profile

 5、echo $http_proxy 查看是否配置成功

echo $http_proxy

6、重启网络

sudo systemctl restart networking  或者 sudo systemctl restart systemd-networkd

7、查看是否可以正常访问

curl www.baidu.com

如果可以正常访问,到此内网机就已经具备外网访问能力了。

注意ping命令不支持代理,请使用curl进行测试。

三、内网机N相关软件代理配置(选择性配置) 

#1、apt代理配置
#在/etc/apt/apt.conf.d 文件夹下修改/增加proxy.conf文件,增加行信息
Acquire::http::Proxy "http://172.17.216.234:3128";
Acquire::https::Proxy "http://172.17.216.234:3128";
Acquire::ftp::Proxy "http://172.17.216.234:3128";

#2、git代理配置
git config --global http.proxy 'http://172.17.216.234:3128'
git config --global https.proxy 'http://172.17.216.234:3128'

#3、docker代理配置(先安装docker)
#如果不知道路径,可以通过systemctl status docker查看
#修改/lib/systemd/system/docker.service文件,添加行信息
Environment="HTTP_PROXY=http://172.17.216.234:3128"
Environment="HTTPS_PROXY=http://172.17.216.234:3128"
Environment="NO_PROXY=localhost,127.0.0.1,192.168.*.*"

四、内网机N环境安装(选择性安装)

注意:以下步骤如果您使用的系统版本不一致,可能会有些许不同。

1、安装docker 

#1. 更新系统包列表:
sudo apt update

#2. 安装所需的软件包以允许 `apt` 命令通过 HTTPS 使用存储库:
sudo apt install -y apt-transport-https ca-certificates curl software-properties-common

#3. 添加 Docker 官方 GPG 密钥:
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

#4. 添加 Docker 的 APT 存储库:
echo "deb [signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

#5. 更新包列表:
sudo apt update

#6. 安装 Docker:
sudo apt install -y docker-ce docker-ce-cli containerd.io

#7. 启动 Docker 服务并设置它随系统启动:
sudo systemctl start docker
sudo systemctl enable docker

#8. 验证 Docker 是否正确安装:
sudo docker --version

#9. 最后,为了允许您的用户帐户使用 Docker 命令,您可以将您的用户添加到 `docker` 组中,注意:要使用户更改生效,您需要注销并重新登录到系统。
sudo usermod -aG docker $USER

2、安装OpenJDK 8 

sudo apt update
sudo apt install openjdk-8-jdk
java -version

#(可选)设置默认的Java版本。如果您同时安装了多个Java版本,可以使用以下命令选择默认版本
sudo update-alternatives --config java

 3、安装Caddy

sudo apt install -y debian-keyring debian-archive-keyring apt-transport-https
curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/gpg.key' | sudo gpg --dearmor -o /usr/share/keyrings/caddy-stable-archive-keyring.gpg
curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/debian.deb.txt' | sudo tee /etc/apt/sources.list.d/caddy-stable.list
sudo apt update
sudo apt install caddy

#配置文件
/etc/caddy/Caddyfile
caddy reload --config ./Caddyfile
systemctl restart caddy

#配置示例
#跳板机T的Caddyfile
dev.example.com {
    reverse_proxy 172.17.216.241:80
}

#内网机N的Caddyfile
:80 {
    handle_path /api* {          
        reverse_proxy http://127.0.0.1:8081      
    }
}

 五、MysqlWorkbench和Navicat工具如何通过跳板机访问数据库?

MysqlWorkbench

 Navicat

六、SpringBoot中如何配置ssh访问内网数据库? 

=== 

  • 10
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
配置Squid代理服务器,您可以按照以下步骤进行操作: 1. 安装Squid软件包:使用适合您操作系统的软件包管理器(如apt、yum或brew)安装Squid软件包。 2. 配置Squid配置文件:打开Squid配置文件,该文件通常位于`/etc/squid/squid.conf`。您可以使用文本编辑器打开并进行编辑。 3. 定义访问控制列表(ACL):在配置文件中定义ACL以控制谁可以访问代理服务器。例如,您可以为特定IP地址、子网或域名设置允许或拒绝访问。 示例: ``` acl internal_network src 192.168.0.0/24 http_access allow internal_network ``` 4. 配置代理端口:根据需要配置代理服务器监听的端口。默认情况下,Squid监听3128端口。 示例: ``` http_port 3128 ``` 5. 配置缓存:您可以定义代理服务器的缓存行为,例如缓存大小、缓存目录等。 示例: ``` cache_dir ufs /var/spool/squid 10000 16 256 maximum_object_size 128 MB ``` 6. 配置其他选项:根据需要配置其他选项,如日志记录、认证、SSL等。 7. 保存并关闭配置文件。 8. 启动Squid服务:启动Squid服务以使配置生效。使用适合您操作系统的命令。 例如,对于systemd系统,执行: ``` systemctl start squid ``` 或者对于SysVinit系统,执行: ``` service squid start ``` 这些是基本的Squid代理服务器配置步骤。您可以根据您的需求进行进一步的配置和定制化。请确保在进行任何更改之前备份原始配置文件,并确保您的配置符合安全和隐私要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值