主頁 > 知識(shí)庫 > Docker每次啟動(dòng)容器,IP及hosts指定的操作

Docker每次啟動(dòng)容器,IP及hosts指定的操作

熱門標(biāo)簽:美圖手機(jī) 阿里云 百度競價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 智能手機(jī) 網(wǎng)站建設(shè) 硅谷的囚徒呼叫中心 檢查注冊表項(xiàng) 使用U盤裝系統(tǒng)

前言

每次在使用Docker啟動(dòng)Hadoop集群的時(shí)候,都需要重新綁定下網(wǎng)卡,固定IP,同時(shí)修改/etc/hosts文件,非常麻煩,于是想探尋下原因及優(yōu)化。

一、原因

/etc/hosts, /etc/resolv.conf和/etc/hostname,容器中的這三個(gè)文件不存在于鏡像,在啟動(dòng)容器的時(shí)候,通過mount的形式將這些文件掛載到容器內(nèi)部。因此,如果在容器中修改這些文件的話,修改部分不會(huì)存在于容器的top layer,而是直接寫入這三個(gè)物理文件中。

為什么重啟后修改內(nèi)容不存在了?原因是:每次Docker在啟動(dòng)容器的時(shí)候,通過重新構(gòu)建新的/etc/hosts文件,這又是為什么呢?原因是:容器重啟,IP地址為改變,hosts文件中原來的IP地址無效,因此理應(yīng)修改hosts文件,否則會(huì)產(chǎn)生臟數(shù)據(jù)。

二、解決辦法

在每次啟動(dòng)容器的時(shí)候指定IP、hostname、往/etc/hosts里添加hosts,命令如下:

docker run -itd --name hadoop0 --hostname hadoop0 --net network_my --ip 192.168.10.30 --add-host hadoop1:192.168.10.31 --add-host hadoop2:192.168.10.32 -d -P -p 50070:50070 -p 8088:8088 hadoop:master

Docker 網(wǎng)絡(luò)模式及配置的操作

--hostname :指定hostname;
--net : 指定網(wǎng)絡(luò)模式
--ip:指定IP
--add-host :指定往/etc/hosts添加的host

以上命令需要docker1.9以上版本才行;

啟動(dòng)完容器后,進(jìn)入容器查看 /etc/hosts

[root@centos-linux-7 /]# docker exec -it hadoop0 bash
[root@hadoop0 /]# cat /etc/hosts
127.0.0.1 localhost
::1 localhost ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters
192.168.10.31 hadoop1
192.168.10.32 hadoop2
192.168.10.30 hadoop0
[root@hadoop0 /]# 

上述命令太長,可寫成shell腳本,另外網(wǎng)上有說其它幾種方式:

1、使用dockerfile構(gòu)建鏡像

2、使用docker-compose啟動(dòng)

3、修改docker容器啟動(dòng)公共加載的環(huán)境變量的配置文件(我沒找到我這個(gè)版本的該配置文件)

第一種方式應(yīng)該是不行的,雖然dockerfile在構(gòu)建鏡像時(shí)能設(shè)置相關(guān)環(huán)境變量,但前面提到過IP、hostname、/etc/hosts都是重新加載的,所以得在docker容器啟動(dòng)的時(shí)候指定,鏡像里的都是不行的;

第二種,本人暫時(shí)對(duì)docker-compose不熟悉,也暫時(shí)不深入探討;

第三種,本人感覺不方便,因?yàn)槟鞘枪驳?,?duì)于不同容器,無法個(gè)性化;

綜上所述,本人覺得在容器啟動(dòng)的時(shí)候,通過命令行指定最方便,但缺點(diǎn)是命令行太長,不過寫成shell腳本就行啦!

補(bǔ)充:linux docker 設(shè)置固定容器IP(docker默認(rèn) 容器ip會(huì)變解決)

一、創(chuàng)建自己的網(wǎng)絡(luò)類型并指定網(wǎng)段

命令

docker network create --subnet=172.18.0.0/16 mynetwork

二、鏡像啟動(dòng)運(yùn)行時(shí)指定自己的網(wǎng)絡(luò)IP

命令

docker run -itd -p 5001:5001 --name 鏡像名稱 --net mynetwork --ip 172.18.0.2 --privileged=true --restart=always -d 鏡像名稱

三、重啟docker、查看容器IP

重啟dockers

命令

service docker restart

查看所有容器

命令

docker ps -a

查看容器信息

命令

docker inspect 容器名稱

這樣容器IP就不會(huì)變了

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽:黃山 湘潭 湖北 通遼 煙臺(tái) 山南 懷化 賀州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Docker每次啟動(dòng)容器,IP及hosts指定的操作》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266