中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

Docker容器怎么互聯(lián)

本篇內(nèi)容介紹了“Docker容器怎么互聯(lián)”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

10余年專注成都網(wǎng)站制作,企業(yè)網(wǎng)站設(shè)計,個人網(wǎng)站制作服務(wù),為大家分享網(wǎng)站制作知識、方案,網(wǎng)站設(shè)計流程、步驟,成功服務(wù)上千家企業(yè)。為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計及定制高端網(wǎng)站建設(shè)服務(wù),專注于企業(yè)網(wǎng)站設(shè)計,高端網(wǎng)頁制作,對報廢汽車回收等多個方面,擁有豐富的網(wǎng)站維護經(jīng)驗。

配置

在我們展示容器間如何被連接之前,我們需要先建立一對容器作為本次的例子。

第一個鏡像將是來源于一個簡單的ubuntu操作系統(tǒng)安裝。它將扮演一個客戶端容器的角色。

首先,我們創(chuàng)建該容器并連接到它。

$ sudo docker run -itd --name=client_setup ubuntu /bin/bash
$ sudo docker attach client_setup

接下來,一旦有了容器內(nèi)的shell程序,我們就可以運行以下命令:

$ apt-get install curl

如果你看不見shell命令提示符,點擊鍵盤方向區(qū)的向上箭頭。

當(dāng)容器安裝完畢,執(zhí)行ctrl+p和ctrl+q命令退出該容器。

緊接著我們停止并提交該容器。

$ sudo docker stop client_setup
$ sudo docker commit client_setup client_img

現(xiàn)在我們可以使用剛才創(chuàng)建的名為client_img的容器了。

第二個容器我們還是從之前的ubuntu操作系統(tǒng)的安裝上獲得。但是這一次,我們將把它修改成一個運行了apache http的服務(wù)器容器。

首先,我們像之前一樣建立并且連接到它:

$ sudo docker run -itd --name=server_setup ubuntu /bin/bash
$ sudo docker attach server_setup

然后,一旦我們可以用容器內(nèi)的shell程序了,就可以能安裝apache的http服務(wù)了。

$ apt-get install apache2

當(dāng)容器安裝完畢,執(zhí)行ctrl+p和ctrl+q命令退出該容器。

現(xiàn)在我們停止并提交容器:

$ sudo docker stop server_setup
$ sudo docker commit server_setup server_img

那么現(xiàn)在我們就有了兩個鏡像了,分別是 client_img 和 server_img。

當(dāng)這些設(shè)置好后,我們就可以探索多種的容器間連接的可能性了。

docker橋接bridge

單個docker容器是默認地與其他容器和外部網(wǎng)絡(luò)隔離的。docker提供了bridge接口,名為docker0,這其實是在docker engine安裝時就建立好的。

它通過docker的bridge接口可以讓容器間以及容器和主機之間進行通信。

我們可以通過下面的命令來查看一個位于docker宿主機上的docker bridge:

$ ifconfig docker0

你可以看到類似如下的輸出:

docker0  link encap:ethernet hwaddr 02:42:a2:dc:0f:a8 
   inet addr:172.17.0.1 bcast:0.0.0.0 mask:255.255.0.0
   inet6 addr: fe80::42:a2ff:fedc:fa8/64 scope:link
   up broadcast running multicast mtu:1500 metric:1
   rx packets:1477 errors:0 dropped:0 overruns:0 frame:0
   tx packets:2436 errors:0 dropped:0 overruns:0 carrier:0
   collisions:0 txqueuelen:0 
   rx bytes:83901 (83.9 kb) tx bytes:3606039 (3.6 mb)

該bridge接口在本地一個單獨的docker宿主機上運行,并且它是我們本篇文章所提及的所有三種方法背后的連接機制。在下一章節(jié)中,我們將轉(zhuǎn)向overlay接口,這種接口允許把網(wǎng)絡(luò)容器部署在多個docker宿主機上。

端口公開exposing ports

首先,讓我們看下如何運行一個容器服務(wù)并且公開其80端口(http)給其他容器。

為了這么做,我通過expose命令去運行該容器,這是告訴docker在運行該容器的時候讓其公開特定的端口。當(dāng)然,被公開的端口是可以被其他容器訪問的。

讓我們運行server_img并且把該容器命名為server1,公開其80端口:

$ sudo docker run -itd --expose=80 --name=server1 server_img /bin/bash

接下來我們會按依次命名這些容器(server1,server2以及其他)。

然后,連接到容器:

$ sudo docker attach server1

重申一遍,如果你看不見shell命令提示符,可以使用方向鍵的向上箭頭。

啟動該容器內(nèi)的apache http服務(wù):

$ /etc/init.d/apache2 start

讓我們來看下獲得的ip地址:

$ ifconfig
eth0   link encap:ethernet hwaddr 02:42:ac:11:00:03 
   inet addr:172.17.0.3 bcast:0.0.0.0 mask:255.255.0.0

那么,這樣我們就有了172.17.0.3這個ip地址。讓我們試一下從一個客戶端的容器里去看這些信息吧。

打開第二個終端。

啟動名稱為client1的容器:

$ sudo docker run -itd --name=client1 client_img /bin/bash

進容器里看一下:

$ sudo docker attach client1

如果你看不見shell命令提示符,可以使用方向鍵的向上箭頭。

讓我們來測試一下到server1的連通性:

$ curl 172.17.0.3

如果一切正常,你應(yīng)該可以看見基于apache http服務(wù)的默認頁面。這表明client1容器已經(jīng)可以與server1容器的http端口正確地建立連接了。

端口綁定port binding

如果我們希望我們的http服務(wù)器公開在主機網(wǎng)絡(luò)呢,包括主機上的應(yīng)用及主機網(wǎng)絡(luò)上的其他機器?在這個方案中,我們需要去將主機端口綁定bind至容器端口。

為了讓基于apache的http服務(wù)器公開給主機所處的網(wǎng)絡(luò),我們需要將該容器的80端口綁定至宿主機上的8080端口。

我們可以按照以下命令來這么做:

$ sudo docker run -itd -p 8080:80 --name=server2 server_img /bin/bash

在這里需要注意的是-p 8080:80選項。

現(xiàn)在,進容器看下:

$ sudo docker attach server2

如果看不見shell的提示符,和之前一樣,按方向區(qū)的向上箭頭,緊接著我們啟動該http服務(wù):

$ /etc/init.d/apache2 start

現(xiàn)在,我們可以從宿主系統(tǒng)去訪問http://localhost:8080/,同時應(yīng)該能看見基于apache http服務(wù)的默認頁面。

Docker容器怎么互聯(lián)

任何在你主機網(wǎng)絡(luò)內(nèi)的那些機器都可以訪問由你的宿主機所發(fā)布出來的8080端口。

容器鏈接linking containers

docker將另一種涉及到的連接各容器的方法稱為鏈接linking。

當(dāng)你將一個容器鏈接到另一個容器的時候,docker將通過一些環(huán)境變量來關(guān)聯(lián)這些容器之間的信息。

我們可以看一下。

首先,啟動該服務(wù)器容器。

$ sudo docker run -itd --name=server3 server_img /bin/bash

接著通過以下命令一樣去啟動客戶機容器并鏈接至服務(wù)器容器。

$ sudo docker run -itd --link server3 --name=client3 client_img /bin/bash

請注意我們這里用了--link server3 選項。

接著我們登錄到客戶機容器看一眼:

$ sudo docker attach client3

然后我們檢查一下可用的環(huán)境變量:

$ env | grep server3
server3_port_80_tcp_proto=tcp
server3_port=tcp://172.17.0.2:80
server3_port_80_tcp_port=80
server3_name=/client3/server3
server3_port_80_tcp=tcp://172.17.0.2:80
server3_port_80_tcp_addr=172.17.0.2

docker同樣也更新了客戶端容器中的/etc/hosts 文件并且將server3作為一個本地主機指向了服務(wù)器容器。

為了演示該情況,讓我們運行以下命令看一看:

$ curl server3

你應(yīng)該可以再一次看見那個相同的默認html頁面了。

“Docker容器怎么互聯(lián)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

本文名稱:Docker容器怎么互聯(lián)
文章路徑:http://www.rwnh.cn/article30/jgpeso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計App設(shè)計、網(wǎng)站排名、搜索引擎優(yōu)化企業(yè)建站、動態(tài)網(wǎng)站

廣告

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

成都網(wǎng)站建設(shè)
礼泉县| 宜阳县| 滦南县| 房产| 浙江省| 长汀县| 夏河县| 冕宁县| 莆田市| 会泽县| 罗城| 衡南县| 高安市| 资讯| 乌兰察布市| 高密市| 逊克县| 东莞市| 甘南县| 玛纳斯县| 孟州市| 清流县| 台山市| 年辖:市辖区| 建德市| 沁水县| 铜陵市| 遵义县| 深水埗区| 安达市| 尼玛县| 呼和浩特市| 古丈县| 玉环县| 界首市| 肥东县| 成武县| 庆城县| 浮梁县| 互助| 新竹县|