這篇文章主要介紹了docker-compose網(wǎng)絡(luò)設(shè)置之networks的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
成都創(chuàng)新互聯(lián)公司2013年成立,先為陽新等服務(wù)建站,陽新等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為陽新企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。networks通常應(yīng)用于集群服務(wù),從而使得不同的應(yīng)用程序得以在相同的網(wǎng)絡(luò)中運(yùn)行,從而解決網(wǎng)絡(luò)隔離問題。這種應(yīng)用在swarm部署中,非常常見。不過,本文并不做討論。
一般對于集群服務(wù),常常通過docker-compose.yml文檔快速編排、部署應(yīng)用服務(wù)。官網(wǎ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
啟動容器后,這些容器都會被加入app_default
網(wǎng)絡(luò)中。使用docker network ls
可以查看網(wǎng)絡(luò)列表,docker network inspect
可以查看對應(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之間只能通過app來實(shí)現(xiàn)通信。其中,custom-driver-1
并不能直接使用,你應(yīng)該替換為host, bridge, overlay
等選項中的一種。
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兩個網(wǎng)絡(luò),似乎它們的名字就定義成了back和font,但是你使用docker network ls
命令并不能找到它們。假如你是在myApp
目錄下運(yùn)行的docker-compose up
命令,那么這兩個網(wǎng)絡(luò)應(yīng)該分別對應(yīng)myApp_back
和myApp_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
遇到的問題
學(xué)習(xí)了上面的東西,筆者準(zhǔn)備將自己的項目付諸實(shí)踐。我的項目包含了兩個docker-compose.yml,且使用了links
選項,所以必須使用networks配置。
其中,一個docker-compose.yml用于啟動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
另一個docker-compose.yml用于啟動服務(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ò),然后把他們加入這個已經(jīng)創(chuàng)建好的網(wǎng)絡(luò),從而實(shí)現(xiàn)通信。為此,我運(yùn)行了如下命令:
$ docker network create app1
之后,開始運(yùn)行編寫好的docker-compose.yml文件。首先運(yùn)行啟動mysql的配置文件,結(jié)果如下:
l$ docker-compose up ERROR: Service "dbmaster" uses an undefined network "app"12
明明已經(jīng)創(chuàng)建好了,卻還是報了錯,說該網(wǎng)絡(luò)未定義。嘗試改變名稱mysql_app,但是依舊報出同樣的錯誤。最終證明,這種方法無法實(shí)現(xiàn),至今沒有找到官方文檔給出的例子。
所以,最終決定將第一個docker-compose.yml文件中的networks配置改為如下內(nèi)容:
networks: mysql_app: driver: bridge123
在這個文件中定義一個網(wǎng)絡(luò),以便在后面使用。這里修改完畢,該文件其他地方凡是引用到了該網(wǎng)絡(luò)的地方均要作出相同的修改。同樣,第二個文件也一樣。
其他的一些用法
使用aliases代替link
一般的使用格式如下:
services: some-service: networks: some-network: aliases: - alias1 - alias3 other-network: aliases: - alias212345678910
在下面的例子中,我的web
容器可以直接通過database:3306
或者db:3306
訪問db
容器了。它們同時屬于一個網(wǎng)絡(luò),并且db
設(shè)置了主機(jī)別名,所以這樣的訪問方式是完全可以的。
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
此時直接使用depends_on已經(jīng)不再需要link,如果woker需要訪問db,可以直接通過mysql:port的方式。
使用networks的要點(diǎn)在于:
1. 注意自定義網(wǎng)絡(luò)的方式
2. 注意docker-compose.yml文件的位置與網(wǎng)絡(luò)默認(rèn)命名的關(guān)系
3. 注意遇到問題嘗試幾種替代方式去解決
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“docker-compose網(wǎng)絡(luò)設(shè)置之networks的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。