docker 容器添加指定網(wǎng)絡地址的方法實現(xiàn)
在搭建halo博客時,準備讓 halo、mysql8.1、nginx 三個容器在同一個網(wǎng)段中,并指定IP。
實現(xiàn)docker內部容器之間網(wǎng)絡互通。
查看容器網(wǎng)絡信息命令
docker inspect 容器名
各容器部署成功后網(wǎng)絡效果如下:
nginx 網(wǎng)絡
IP:172.10.0.4
網(wǎng)關 :172.10.0.1

halo 網(wǎng)絡
IP:172.10.0.2
網(wǎng)關 :172.10.0.1

halodb 網(wǎng)絡(halo數(shù)據(jù)庫 mysql8.1)
IP:172.10.0.3
網(wǎng)關 :172.10.0.1

部署流程如下:
halo 博客部署
由于開始前我沒有創(chuàng)建自定義網(wǎng)絡。
我采用的是 部署halo時創(chuàng)建網(wǎng)絡。
如果需要創(chuàng)建自定義網(wǎng)絡看 》》》自定義創(chuàng)建網(wǎng)絡
如果已經(jīng)有自定義網(wǎng)絡,將 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: #網(wǎng)絡名稱
ipv4_address: 172.10.0.2 ###halo指定網(wǎng)絡
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
# 外部訪問地址,請根據(jù)實際需要修改
- --halo.external-url=http://47.98.237.238:8090/
#halo 數(shù)據(jù)庫配置
halodb:
image: mysql:8.1.0
container_name: halodb
restart: on-failure:3
networks:
mynetwork: #網(wǎng)絡名稱
ipv4_address: 172.10.0.3 ###mysql指定網(wǎng)絡
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
# 創(chuàng)建網(wǎng)絡,創(chuàng)建成功后網(wǎng)絡名稱 halo_mynetwork
# 創(chuàng)建網(wǎng)絡過程中 會將文件名 halo 作為前綴。
# 如果已經(jīng)有自定義網(wǎng)絡,就將networks 配置 按照下面nginx 來配置即可。
networks:
mynetwork: ###網(wǎng)絡名稱
driver: bridge ###網(wǎng)絡模式 橋接
ipam:
config:
- subnet: 172.10.0.0/24
gateway: 172.10.0.1
查看當前容器存在的網(wǎng)絡
docker network ls
部署好 halo 和mysql 后,創(chuàng)建的網(wǎng)絡為 halo_mynetwork

nginx 部署指定網(wǎng)絡和掛載目錄
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
#網(wǎng)絡配置
networks:
halo_mynetwork: ### 網(wǎng)絡名稱
external: true ###外部網(wǎng)絡
錯誤信息提示:
執(zhí)行:docker-compose up -d 命令時報如下錯誤:
// 是因為網(wǎng)絡不存在,查看docker-compose.yaml文件中網(wǎng)絡配置是否正確。 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 容器添加指定網(wǎng)絡地址的方法實現(xiàn)的文章就介紹到這了,更多相關docker 添加指定網(wǎng)絡地址內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Docker 中快速安裝tensorflow環(huán)境的方法步驟
這篇文章主要介紹了Docker 中快速安裝tensorflow環(huán)境的方法步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10
解決docker CMD/ENTRYPOINT執(zhí)行sh腳本報: not found/run.sh:
這篇文章主要介紹了解決docker CMD/ENTRYPOINT執(zhí)行sh腳本報: not found/run.sh:的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
docker-compose部署配置jenkins的詳細教程
這篇文章主要介紹了docker-compose部署配置jenkins的詳細教程,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
zabbix監(jiān)控docker容器狀態(tài)【推薦】
這篇文章主要介紹了zabbix監(jiān)控docker容器狀態(tài)的相關資料,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-06-06
使用Docker部署 spring-boot maven應用的方法
本篇文章主要介紹了使用Docker部署 spring-boot maven應用的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08

