docker配置固定ip解决nginx代理容器名称dns缓存不更新问题

docker配置固定ip解决nginx代理容器名称dns缓存不更新问题

场景

在nginx配置中,proxy_pass代理项使用容器名称替代ip,容器重启后代理的url网络不通。

nginx配置示例

conf 复制代码
location /api/ {
	proxy_set_header Host $http_host;
	proxy_set_header X-Real-IP $remote_addr;
	proxy_set_header REMOTE-HOST $remote_addr;
	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    # 这里的iot-backend为docker容器名称
	proxy_pass http://iot-backend:8089;
}

docker dns

在docker网络中,提供有默认dns服务127.0.0.11用于容器名称和容器ip的解析转换,同时自动生成文件到容器内/etc/resolv.conf。在不指定容器ip时,每次容器重启后,容器ip会重新分配而发生变更。

nginx dns缓存

在nginx中,在第一次dns解析成功后,结果会被缓存,并不会自动更新。因此容器重启后,容易导致proxy_pass配置的基于容器名称的代理网络不通。此时需要手动重启nginx或重新加载nginx配置,触发后续网络请求进入更新dns。

使用固定ip解决重启后容器ip变更

创建容器网络,为容器配置网络,并设置固定ip。容器重启后ip不变,间接保证nginx代理url网络联通。

docker compose配置示例

yml 复制代码
# 创建容器网络,桥接模式,使用ipam固定ip
networks:
  iot-network:
    name: iot-network
    ipam:
      driver: default
      config:
        - subnet: '177.7.0.0/16'

# 为容器配置网络和固定ip
iot-backend:
    networks:
      iot-network:
        ipv4_address: 177.7.0.10

创建后可以使用docker network ls查看容器网络。

相关推荐
武子康19 小时前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
ping某2 天前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
Alsn864 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
treesforest4 天前
AI安全系统如何识别异常访问?IP风险识别正在成为关键能力
网络·人工智能·tcp/ip·安全·web安全
江华森4 天前
TCP/IP 协议栈实战 — 7 个实验详解
网络·tcp/ip·智能路由器
程序员老赵4 天前
服务器没有桌面?Docker 跑个 Chrome,浏览器就能远程用
docker·容器·devops
難釋懷4 天前
Nginx反向代理中的容错机制
运维·nginx
杨浦老苏4 天前
轻量级Docker仪表板Servedash
运维·docker·监控·群晖·仪表板
正经教主4 天前
【docker基础】 第八周:容器监控与应用更新策略
运维·docker·容器
bloglin999994 天前
Nginx高危漏洞CVE-2021-23017及配置样例
运维·nginx