docker 容器添加指定网络地址的方法实现
在搭建halo博客时,准备让 halo、mysql8.1、nginx 三个容器在同一个网段中,并指定IP。
实现docker内部容器之间网络互通。
查看容器网络信息命令
docker inspect 容器名
各容器部署成功后网络效果如下:
nginx 网络
IP:172.10.0.4
网关 :172.10.0.1
halo 网络
IP:172.10.0.2
网关 :172.10.0.1
halodb 网络(halo数据库 mysql8.1)
IP:172.10.0.3
网关 :172.10.0.1
部署流程如下:
halo 博客部署
由于开始前我没有创建自定义网络。
我采用的是 部署halo时创建网络。
如果需要创建自定义网络看 》》》自定义创建网络
如果已经有自定义网络,将 halo docker-compose.yaml文件中 networks 配置,
按照下面 nginx docker-compose.yaml文件 networks 来修改。
version: "3" services: #halo 配置 halo: image: halohub/halo:2.11 container_name: halo restart: on-failure:3 depends_on: halodb: condition: service_healthy networks: mynetwork: #网络名称 ipv4_address: 172.10.0.2 ###halo指定网络 volumes: - ./halo2:/root/.halo2 ports: - "8090:8090" healthcheck: test: ["CMD", "curl", "-f", "http://localhost:8090/actuator/health/readiness"] interval: 30s timeout: 5s retries: 5 start_period: 30s command: - --spring.r2dbc.url=r2dbc:pool:mysql://halodb:3306/halo - --spring.r2dbc.username=root # MySQL 的密码,请保证与下方 MYSQL_ROOT_PASSWORD 的变量值一致。 - --spring.r2dbc.password=123456 - --spring.sql.init.platform=mysql # 外部访问地址,请根据实际需要修改 - --halo.external-url=http://47.98.237.238:8090/ #halo 数据库配置 halodb: image: mysql:8.1.0 container_name: halodb restart: on-failure:3 networks: mynetwork: #网络名称 ipv4_address: 172.10.0.3 ###mysql指定网络 command: - --default-authentication-plugin=caching_sha2_password - --character-set-server=utf8mb4 - --collation-server=utf8mb4_general_ci - --explicit_defaults_for_timestamp=true volumes: - ./mysql:/var/lib/mysql - ./mysqlBackup:/data/mysqlBackup ports: - "33060:3306" healthcheck: test: ["CMD", "mysqladmin", "ping", "-h", "127.0.0.1", "--silent"] interval: 3s retries: 5 start_period: 30s environment: # 请修改此密码,并对应修改上方 Halo 服务的 SPRING_R2DBC_PASSWORD 变量值 - MYSQL_ROOT_PASSWORD=123456 - MYSQL_DATABASE=halo # 创建网络,创建成功后网络名称 halo_mynetwork # 创建网络过程中 会将文件名 halo 作为前缀。 # 如果已经有自定义网络,就将networks 配置 按照下面nginx 来配置即可。 networks: mynetwork: ###网络名称 driver: bridge ###网络模式 桥接 ipam: config: - subnet: 172.10.0.0/24 gateway: 172.10.0.1
查看当前容器存在的网络
docker network ls
部署好 halo 和mysql 后,创建的网络为 halo_mynetwork
nginx 部署指定网络和挂载目录
version: '3' services: nginx: image: nginx # 镜像名称 container_name: mynginx # 容器名字 restart: always # 开机自动重启 networks: halo_mynetwork: ipv4_address: 172.10.0.4 ports: # 端口号绑定(宿主机:容器内) - '8080:80' - '443:443' volumes: # 目录映射(宿主机:容器内) - /home/docker/nginx/nginx.conf:/etc/nginx/nginx.conf ###配置文件 - /home/docker/nginx/log:/var/log/nginx ###这里面放置日志 - /home/docker/nginx/html:/html ###这里面放置项目目录 - /home/docker/nginx/conf.d:/etc/nginx/conf.d #网络配置 networks: halo_mynetwork: ### 网络名称 external: true ###外部网络
错误信息提示:
执行:docker-compose up -d 命令时报如下错误:
// 是因为网络不存在,查看docker-compose.yaml文件中网络配置是否正确。 service "nginx" refers to undefined network halo_mynetwork: invalid compose project
// docker-compose.yaml 文件编码不正确 parsing /home/docker/nginx/docker-compose.yml: yaml: invalid leading UTF-8 octet
// 文件格式化不正确,比如不能使用 tab进行缩进,采用空格键。 parsing /home/docker/nginx/docker-compose.yml: yaml: line 7: found character that cannot start any token
到此这篇关于docker 容器添加指定网络地址的方法实现的文章就介绍到这了,更多相关docker 添加指定网络地址内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
关于docker compose安装redis集群的问题(集群扩容、集群收缩)
这篇文章主要介绍了docker compose安装redis集群、集群扩容、集群收缩,主要包括redis配置信息模板,编写批量生成配置文件脚本的相关命令,需要的朋友参考下吧2022-03-03使用Docker配置redis sentinel哨兵的方法步骤
本文主要介绍了Docker配置redis sentinel哨兵的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-07-07
最新评论