欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

綁定Dokcer容器到主機(jī)指定網(wǎng)卡的方法

 更新時(shí)間:2018年03月29日 08:28:40   作者:寂寞是國,我是王  
這篇文章主要介紹了綁定 Dokcer 容器到主機(jī)指定網(wǎng)卡的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

如果你的主機(jī)有多塊網(wǎng)卡,你可能會(huì)需要把 Docker 容器綁定到指定網(wǎng)卡,以使容器內(nèi)的所有網(wǎng)絡(luò)請(qǐng)求都經(jīng)過該指定網(wǎng)卡發(fā)送至外網(wǎng)。

不幸的是,Docker 并沒有直接提供實(shí)現(xiàn)該需求的方法。不過,通過 iptables 可以輕松搞定。

一刀切

假設(shè)你的主機(jī)上有兩塊網(wǎng)卡:一塊網(wǎng)卡的 IP 地址是 192.168.0.100 ;另一塊網(wǎng)卡的 IP 地址是 10.0.0.100 。你想讓這臺(tái)主機(jī)上的 Docker 容器內(nèi)的所有服務(wù)都走第二塊網(wǎng)卡進(jìn)出外網(wǎng)。

先給出答案再解釋:

復(fù)制代碼 代碼如下:
iptables -t nat -I POSTROUTING -p all -s 172.17.0.0/16 -j SNAT --to-source 10.0.0.100

上面的 iptables 命令創(chuàng)建了一條源地址轉(zhuǎn)換( SNAT )規(guī)則,把所有來自 172.17.0.0/16 網(wǎng)段且即將流出本主機(jī)的數(shù)據(jù)包的源 IP 地址都修改為 10.0.0.100 。

對(duì)于 10.0.0.100 我們知道它是主機(jī)第二塊網(wǎng)卡的 IP 地址。而 172.17.0.0/16 是從哪來的呢?

簡單來說,在主機(jī)上運(yùn)行 Docker 時(shí),它會(huì)在主機(jī)上創(chuàng)建一個(gè)名為 docker0 的網(wǎng)橋,其 IP 地址為 172.17.0.1 ,網(wǎng)段為 172.17.0.0/16 。默認(rèn)情況下,Docker 會(huì)為所有容器從該網(wǎng)段分配一個(gè) IP 地址。

更詳細(xì)的說明,可以參考這篇《單 Host 下 Docker 的默認(rèn)網(wǎng)絡(luò)配置》 。

所有 Docker 容器的 IP 地址都是在 172.17.0.0/16 網(wǎng)段,那么,上邊的 iptables 命令創(chuàng)建的規(guī)則就是把所有來自 Docker 容器的且即將流出本主機(jī)的數(shù)據(jù)包的源 IP 地址都修改為本主機(jī)的第二塊網(wǎng)卡的 IP 地址,即 10.0.0.100 。

這樣,就實(shí)現(xiàn)了我們需求的『出』這半部分。

而『進(jìn)』那半部分需求的實(shí)現(xiàn)也很簡單,只需在 docker run 的時(shí)候通過 -p 參數(shù)指定主機(jī) IP 即可,如:

docker run -p 10.0.0.100:80:80 ...

分而治

需求變化很快,或許我們又多了一塊網(wǎng)卡,其 IP 地址為 10.0.0.101 。而由于某種原因,我們想讓一部分容器的流量走第二塊網(wǎng)卡,同時(shí)讓另一部分容器的流量走新加的這第三塊網(wǎng)卡。

由于在使用默認(rèn)網(wǎng)橋時(shí),Docker 不允許為容器指定 IP 地址(如果你指定 IP 地址,Docker 會(huì)給出如下錯(cuò)誤提示),所以我們無法提前預(yù)知某個(gè)容器最終被分配給的 IP 地址是什么,也就無法提前通過 iptables 規(guī)則為其指定出口網(wǎng)卡。

docker: Error response from daemon: user specified IP address is supported on user defined networks only.

其實(shí),上面的錯(cuò)誤提示已經(jīng)給出了解決的辦法,那就是用戶自定義網(wǎng)絡(luò)。

用以下命令創(chuàng)建自定義網(wǎng)絡(luò):

復(fù)制代碼 代碼如下:
docker network create --subnet=172.18.0.0/16 --opt "com.docker.network.bridge.name"="docker1"  docker1

其中,172.18.0.0/16 為新建網(wǎng)橋所在網(wǎng)段。因?yàn)?Dokcer 默認(rèn)網(wǎng)橋已經(jīng)占用了 172.17.0.0/16 ,所以新建網(wǎng)橋只能使用未被占用的其他網(wǎng)段。

第一個(gè) docker1 為執(zhí)行 ifconfig -a 命令時(shí),顯示的網(wǎng)橋名,如果不使用 --opt 參數(shù)指定此名稱,那你在使用 ifconfig -a 命令查看網(wǎng)絡(luò)信息時(shí),看到的是類似 br-110eb56a0b22 這樣的名字。這顯然不怎么好看/記;

第二個(gè) docker1 為執(zhí)行 docker network list 命令時(shí),顯示的網(wǎng)橋名。

有了自定義網(wǎng)絡(luò),我們就可以為容器指定一個(gè)固定 IP 地址了。

docker run --network=docker1 --ip=172.18.0.100 ......
docker run --network=docker1 --ip=172.18.0.101 ......

知道了容器的固定 IP 地址,那我們就可以如法炮制,把該容器綁定到指定主機(jī)網(wǎng)卡了:

iptables -t nat -I POSTROUTING -p all -s 172.18.0.100 -j SNAT --to-source 10.0.0.100
iptables -t nat -I POSTROUTING -p all -s 172.18.0.101 -j SNAT --to-source 10.0.0.101

需要注意的是,這里的 -s 選項(xiàng)后面跟的參數(shù)是 IP 地址,而不是網(wǎng)段了。

其他相關(guān)命令

查看 iptables 規(guī)則

iptables -t nat -L -n --line-number

刪除 iptables 規(guī)則

iptables -t nat -D POSTROUTING 11

其中,最后的 11 是要?jiǎng)h除的規(guī)則序號(hào)(num)。

刪除 Docker 自定義網(wǎng)絡(luò)

docker network rm docker1

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Docker-compose一鍵部署gitlab中文版的方法步驟

    Docker-compose一鍵部署gitlab中文版的方法步驟

    這篇文章主要介紹了Docker-compose一鍵部署gitlab中文版的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • Windows?Server?2016中文版安裝docker的詳細(xì)步驟

    Windows?Server?2016中文版安裝docker的詳細(xì)步驟

    因業(yè)務(wù)需要所以需要安裝Docker,但是在途中遇到了一些問題,所以下面這篇文章主要給大家介紹了關(guān)于Windows?Server?2016中文版安裝docker的詳細(xì)步驟,需要的朋友可以參考下
    2022-07-07
  • docker?ps容器未顯示的問題以及排查過程詳解

    docker?ps容器未顯示的問題以及排查過程詳解

    這篇文章主要給大家介紹了關(guān)于docker?ps容器未顯示的問題以及排查過程的相關(guān)資料,相信各位在使用docker容器的時(shí)候,經(jīng)常docker run -d后臺(tái)運(yùn)行后,使用docker ps的時(shí)候發(fā)現(xiàn)這個(gè)容器顯示不到,這里給大家介紹下,需要的朋友可以參考下
    2023-09-09
  • 通過UI管理docker的方法

    通過UI管理docker的方法

    這篇文章主要介紹了通過UI管理docker的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • docker安裝mysql并實(shí)現(xiàn)數(shù)據(jù)卷掛載的示例代碼

    docker安裝mysql并實(shí)現(xiàn)數(shù)據(jù)卷掛載的示例代碼

    本文介紹了如何通過Docker安裝MySQL并實(shí)現(xiàn)了數(shù)據(jù)卷掛載,詳細(xì)說明了創(chuàng)建容器、配置掛載以及驗(yàn)證數(shù)據(jù)持久性的步驟,對(duì)于需要在Docker環(huán)境下部署MySQL的用戶非常有幫助
    2024-10-10
  • docker啟動(dòng)mysql并映射數(shù)據(jù)目錄(含備份腳本)

    docker啟動(dòng)mysql并映射數(shù)據(jù)目錄(含備份腳本)

    本文主要介紹了docker啟動(dòng)mysql并映射數(shù)據(jù)目錄(含備份腳本),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • Docker多個(gè)容器不能有相同端口號(hào)的處理方案

    Docker多個(gè)容器不能有相同端口號(hào)的處理方案

    這篇文章主要介紹了Docker多個(gè)容器不能有相同端口號(hào)的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • docker啟動(dòng)鏡像失敗后如何用日志logs查找失敗原因及解決

    docker啟動(dòng)鏡像失敗后如何用日志logs查找失敗原因及解決

    在使用docker的時(shí)候,在某些未知的情況下可能啟動(dòng)了容器,但是過了沒幾秒容器自動(dòng)退出了,這個(gè)時(shí)候如何排查問題呢?下面這篇文章主要給大家介紹了關(guān)于docker啟動(dòng)鏡像失敗后如何用日志logs查找失敗原因及解決的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • Docker 查看鏡像信息的方法

    Docker 查看鏡像信息的方法

    這篇文章主要介紹了Docker 查看鏡像信息的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Docker 運(yùn)行時(shí)的用戶與組管理的方法

    Docker 運(yùn)行時(shí)的用戶與組管理的方法

    這篇文章主要介紹了Docker 運(yùn)行時(shí)的用戶與組管理的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-10-10

最新評(píng)論