docker 容器添加指定網(wǎng)絡地址的方法實現(xiàn)
在搭建halo博客時,準備讓 halo、mysql8.1、nginx 三個容器在同一個網(wǎng)段中,并指定IP。
實現(xiàn)docker內(nèi)部容器之間網(wǎng)絡互通。
查看容器網(wǎng)絡信息命令
docker inspect 容器名
各容器部署成功后網(wǎng)絡效果如下:
nginx 網(wǎng)絡
IP:172.10.0.4
網(wǎng)關(guān) :172.10.0.1
halo 網(wǎng)絡
IP:172.10.0.2
網(wǎng)關(guān) :172.10.0.1
halodb 網(wǎng)絡(halo數(shù)據(jù)庫 mysql8.1)
IP:172.10.0.3
網(wǎng)關(guān) :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: # 端口號綁定(宿主機:容器內(nèi)) - '8080:80' - '443:443' volumes: # 目錄映射(宿主機:容器內(nèi)) - /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
到此這篇關(guān)于docker 容器添加指定網(wǎng)絡地址的方法實現(xiàn)的文章就介紹到這了,更多相關(guān)docker 添加指定網(wǎng)絡地址內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
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-11docker-compose部署配置jenkins的詳細教程
這篇文章主要介紹了docker-compose部署配置jenkins的詳細教程,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07zabbix監(jiān)控docker容器狀態(tài)【推薦】
這篇文章主要介紹了zabbix監(jiān)控docker容器狀態(tài)的相關(guān)資料,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-06-06使用Docker部署 spring-boot maven應用的方法
本篇文章主要介紹了使用Docker部署 spring-boot maven應用的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08