docker compose配置容器只允许指定的外部IP访问

  1. 系统:Ubuntu 22.04
  2. 要求:容器能访问外网,即允许请求http、https,但外部服务只允许指定ip访问容器A
  3. 踩坑:用Ubuntu自带的ufw是不能设置容器的访问规则的,倘若要用ufw的route规则,则需要关闭docker的iptables配置,如果关闭此配置,则容器无法请求外网。docker链是在UFW之前生效的。

步骤:

配置docker的daemon文件

添加:

bash 复制代码
{
	...
	"iptables": true
}

重新加载daemon并重启docker

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

配置容器的固定ip

在docker-compose.yaml文件中配置容器的固定ip,后续重启也不会改变。

yaml 复制代码
services:
	contanier:
	...
	networks:
      engine_network:
        ipv4_address: 172.20.0.3

检查docker是否启用ip_forwad

bash 复制代码
cat /proc/sys/net/ipv4/ip_forward
复制代码
如果输出为0,启用:
bash 复制代码
echo "net.ipv4.ip_forward = 1" | sudo tee -a /etc/sysctl.conf

检查docker 的iptables规则(此为重点!!!!)

注意: docker开启了iptables是默认有自己的规则的,它会绕过ufw,所以配置ufw是无效的。

可以验证下,执行:

bash 复制代码
sudo iptables -L DOCKER -n -v

一般会看到类似:

Chain DOCKER (8 references)

pkts bytes target prot opt in out source destination

4 240 ACCEPT tcp -- !br-ab83bf174013 br-ab83bf174013 0.0.0.0/0 172.20.0.3 tcp dpt:<容器映射ip>

这条规则直接放行了所有ip对与容器A的访问,完全绕过了UFW。

解决方案:

  • 检查是否有DOCKER-USER链

    bash 复制代码
    sudo iptables -L -n | grep "DOCKER"

    若没有则创建:

    bash 复制代码
    	sudo iptables -N DOCKER-USER
  • 添加白名单规则

    bash 复制代码
     ## 1. 获取容器A的ip
     	CONTAINER_IP=$(docker inspect <容器名称> -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}')
    	echo "容器 IP: $CONTAINER_IP"
    ## 2. 添加白名单:只允许指定IP访问容器A的端口
    	sudo iptables -I DOCKER-USER -p tcp --dport <容器端口> -s <指定IP> -d $CONTAINER_IP -j ACCEPT
    ## 3. 拒绝其它所有访问容器A的端口的请求
    	sudo iptables -A DOCKER-USER -p tcp --dport 11434 -d $OLLAMA_IP -j DROP
    ## 3.或者是提示用户连接被拒绝而不是超时
    	sudo iptables -A DOCKER-USER -p tcp --dport 11434 -d $OLLAMA_IP -j REJECT --reject-with tcp-reset
  • 永久保存规则

    bash 复制代码
    ##	1. Ubuntu/debian使用iptables-persistent
    	## 安装(如果未安装)
    	sudo apt install iptables-persistent -y
    	## 保存规则
    	sudo netfilter-persistent save
    ## 2. 或者手动保存
    	sudo iptables-save > /etc/iptables/rules.v4
相关推荐
杨浦老苏20 小时前
安全共享敏感信息的共享工具Hemmelig.app
docker·群晖·密码·阅后即焚
眠りたいです20 小时前
Docker:容器虚拟化技术基础-namespace,cgroups,资源管理与LXC
运维·docker·中间件·容器
java_logo1 天前
宝塔 Linux 面板 Docker 容器化部署指南
linux·运维·docker·宝塔·docker部署宝塔·宝塔部署教程·docker部署baota
用户3521802454751 天前
🚀 Milvus 实战部署全记录
数据库·docker·ai编程
令狐囱1 天前
宝塔docker 运行 go-zero-looklook项目
docker·容器·golang
yBmZlQzJ1 天前
内网穿透 + 域名解析:到底解决了什么核心问题?
运维·经验分享·网络协议·docker·容器
小挪号底迪滴1 天前
Docker容器化实践:从开发到生产的完整流程
运维·docker·容器
gordon~91 天前
Docker常用命令
运维·docker·容器
隔壁小红馆1 天前
docker 部署pgsql
运维·docker·容器
石小千1 天前
Ubuntu24.04 安装Docker
运维·docker·容器