docker-compose網(wǎng)絡(luò)設(shè)置之networks的示例分析-創(chuàng)新互聯(lián)

這篇文章主要介紹了docker-compose網(wǎng)絡(luò)設(shè)置之networks的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)公司2013年成立,先為陽(yáng)新等服務(wù)建站,陽(yáng)新等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢(xún)服務(wù)。為陽(yáng)新企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。

networks通常應(yīng)用于集群服務(wù),從而使得不同的應(yīng)用程序得以在相同的網(wǎng)絡(luò)中運(yùn)行,從而解決網(wǎng)絡(luò)隔離問(wèn)題。這種應(yīng)用在swarm部署中,非常常見(jiàn)。不過(guò),本文并不做討論。

一般對(duì)于集群服務(wù),常常通過(guò)docker-compose.yml文檔快速編排、部署應(yīng)用服務(wù)。官網(wǎng)中給出了如下的使用場(chǎng)景和方式:

1. 未顯式聲明網(wǎng)絡(luò)環(huán)境的docker-compose.yml

例如,在目錄app下創(chuàng)建docker-compose.yml,內(nèi)容如下:

version: '3'
services:
 web:
  mage: nginx:latest
  container_name: web
  depends_on:
   - db
  ports:
   - "9090:80"
  links:
   - db
 db:
  image: mysql
  container_name: db1234567891011121314

使用docker-compose up啟動(dòng)容器后,這些容器都會(huì)被加入app_default網(wǎng)絡(luò)中。使用docker network ls可以查看網(wǎng)絡(luò)列表,docker network inspect <container id>可以查看對(duì)應(yīng)網(wǎng)絡(luò)的配置。

$ docker net work ls
NETWORK ID     NAME           DRIVER       SCOPE
6f5d9bc0b0a0    app_default       bridge       local
0fb4027b4f6d    bridge          bridge       local
567f333b9de8    docker-compose_default  bridge       local
bb346324162a    host           host        local
a4de711f6915    mysql_app        bridge       local
f6c79184ed27    mysql_default      bridge       local
6358d9d60e8a    none           null        local
12345678910

2. networks關(guān)鍵字指定自定義網(wǎng)絡(luò)

例如下面的docker-compose.yml文件,定義了front和back網(wǎng)絡(luò),實(shí)現(xiàn)了網(wǎng)絡(luò)隔離。其中proxy和db之間只能通過(guò)app來(lái)實(shí)現(xiàn)通信。其中,custom-driver-1并不能直接使用,你應(yīng)該替換為host, bridge, overlay等選項(xiàng)中的一種。

version: '3'

services:
 proxy:
  build: ./proxy
  networks:
   - front
 app:
  build: ./app
  networks:
   - front
   - back
 db:
  image: postgres
  networks:
   - back

networks:
 front:
  # Use a custom driver
  driver: custom-driver-1
 back:
  # Use a custom driver which takes special options
  driver: custom-driver-2
  driver_opts:
   foo: "1"
   bar: "2"123456789101112131415161718192021222324252627

值得注意的是,這里定義了back和front兩個(gè)網(wǎng)絡(luò),似乎它們的名字就定義成了back和font,但是你使用docker network ls命令并不能找到它們。假如你是在myApp目錄下運(yùn)行的docker-compose up命令,那么這兩個(gè)網(wǎng)絡(luò)應(yīng)該分別對(duì)應(yīng)myApp_backmyApp_front

3. 配置默認(rèn)網(wǎng)絡(luò)

version: '2'

services:
 web:
  build: .
  ports:
   - "8000:8000"
 db:
  image: postgres

networks:
 default:
  # Use a custom driver
  driver: custom-driver-11234567891011121314

4. 使用已存在的網(wǎng)絡(luò)

networks:
 default:
  external:
   name: my-pre-existing-network1234

遇到的問(wèn)題

學(xué)習(xí)了上面的東西,筆者準(zhǔn)備將自己的項(xiàng)目付諸實(shí)踐。我的項(xiàng)目包含了兩個(gè)docker-compose.yml,且使用了links選項(xiàng),所以必須使用networks配置。

其中,一個(gè)docker-compose.yml用于啟動(dòng)mysql服務(wù),位于mysql/目錄下:

 version: "3"
services:
 dbmaster:
  image: master/mysql:latest
  container_name: dbmaster
  ports:
   - "3308:3306"
  volumes:
   - $HOME/Work/data/dbmaster:/var/lib/mysql
  environment:
   MYSQL_ROOT_PASSWORD: master
  logging:
   driver: "json-file"
   options:
    max-size: "1000k"
    max-file: "20"
  networks:
   - app

 dbslave:
  image: slave/mysql:latest
  container_name: dbslave
  ports:
   - "3309:3306"
  depends_on:
   - dbmaster
  volumes:
   - $HOME/Work/data/dbslave:/var/lib/mysql
  environment:
   MYSQL_ROOT_PASSWORD: slave
  logging:
   driver: "json-file"
   options:
    max-size: "1000k"
    max-file: "20"
  links:
   - dbmaster
  networks:
   - app
networks:
  default:
  external:
   name: app12345678910111213141516171819202122232425262728293031323334353637383940414243

另一個(gè)docker-compose.yml用于啟動(dòng)服務(wù)程序,位于cloudgo/目錄下:

version: "3"
services:
 web:
  image: nginx:latest
  container_name: web
  depends_on:
   - cloudgo
  ports:
   - "9090:80"
  volumes:
   - $HOME/Work/docker/docker-compose/nginx/conf.d:/etc/nginx/conf.d
  links:
   - cloudgot
  logging:
   driver: "json-file"
   options:
    max-size: "1000k"
    max-file: "20"
  networks:
   - app

 cloudgo:
  image: cloudgo:latest
  container_name: cloudgo
  ports:
   - "8080:8080"
  logging:
   driver: "json-file"
   options:
    max-size: "1000k"
    max-file: "20" 
  external_links:
   - dbmaster
   - dbslave
  networks:
   - app
networks:
 app:
  external: true123456789101112131415161718192021222324252627282930313233343536373839

我決定使用預(yù)先創(chuàng)建的網(wǎng)絡(luò),然后把他們加入這個(gè)已經(jīng)創(chuàng)建好的網(wǎng)絡(luò),從而實(shí)現(xiàn)通信。為此,我運(yùn)行了如下命令:

$ docker network create app1

之后,開(kāi)始運(yùn)行編寫(xiě)好的docker-compose.yml文件。首先運(yùn)行啟動(dòng)mysql的配置文件,結(jié)果如下:

l$ docker-compose up
ERROR: Service "dbmaster" uses an undefined network "app"12

明明已經(jīng)創(chuàng)建好了,卻還是報(bào)了錯(cuò),說(shuō)該網(wǎng)絡(luò)未定義。嘗試改變名稱(chēng)mysql_app,但是依舊報(bào)出同樣的錯(cuò)誤。最終證明,這種方法無(wú)法實(shí)現(xiàn),至今沒(méi)有找到官方文檔給出的例子。

所以,最終決定將第一個(gè)docker-compose.yml文件中的networks配置改為如下內(nèi)容:

networks:
  mysql_app:
   driver: bridge123

在這個(gè)文件中定義一個(gè)網(wǎng)絡(luò),以便在后面使用。這里修改完畢,該文件其他地方凡是引用到了該網(wǎng)絡(luò)的地方均要作出相同的修改。同樣,第二個(gè)文件也一樣。

其他的一些用法

使用aliases代替link

一般的使用格式如下:

services:
 some-service:
  networks:
   some-network:
    aliases:
     - alias1
     - alias3
   other-network:
    aliases:
     - alias212345678910

在下面的例子中,我的web容器可以直接通過(guò)database:3306或者db:3306訪(fǎng)問(wèn)db容器了。它們同時(shí)屬于一個(gè)網(wǎng)絡(luò),并且db設(shè)置了主機(jī)別名,所以這樣的訪(fǎng)問(wèn)方式是完全可以的。

version: '2'

services:
 web:
  depends_on:
   - worker
  networks:
   - new

 worker:
  depends_on:
   - db
  networks:
   - legacy

 db:
  image: mysql
  networks:
   new:
    aliases:
     - database
   legacy:
    aliases:
     - mysql
networks:
 new:
 legacy:123456789101112131415161718192021222324252627

此時(shí)直接使用depends_on已經(jīng)不再需要link,如果woker需要訪(fǎng)問(wèn)db,可以直接通過(guò)mysql:port的方式。

使用networks的要點(diǎn)在于:
1. 注意自定義網(wǎng)絡(luò)的方式
2. 注意docker-compose.yml文件的位置與網(wǎng)絡(luò)默認(rèn)命名的關(guān)系
3. 注意遇到問(wèn)題嘗試幾種替代方式去解決

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“docker-compose網(wǎng)絡(luò)設(shè)置之networks的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線(xiàn),公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計(jì)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。

當(dāng)前題目:docker-compose網(wǎng)絡(luò)設(shè)置之networks的示例分析-創(chuàng)新互聯(lián)
分享路徑:http://www.muchs.cn/article32/hgosc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)網(wǎng)站制作網(wǎng)站導(dǎo)航、靜態(tài)網(wǎng)站、網(wǎng)站維護(hù)移動(dòng)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

微信小程序開(kāi)發(fā)