Docker每次啟動(dòng)容器,IP及hosts指定的操作
前言
每次在使用Docker啟動(dòng)Hadoop集群的時(shí)候,都需要重新綁定下網(wǎng)卡,固定IP,同時(shí)修改/etc/hosts文件,非常麻煩,于是想探尋下原因及優(yōu)化。
一、原因
/etc/hosts, /etc/resolv.conf和/etc/hostname,容器中的這三個(gè)文件不存在于鏡像,在啟動(dòng)容器的時(shí)候,通過(guò)mount的形式將這些文件掛載到容器內(nèi)部。因此,如果在容器中修改這些文件的話,修改部分不會(huì)存在于容器的top layer,而是直接寫(xiě)入這三個(gè)物理文件中。
為什么重啟后修改內(nèi)容不存在了?原因是:每次Docker在啟動(dòng)容器的時(shí)候,通過(guò)重新構(gòu)建新的/etc/hosts文件,這又是為什么呢?原因是:容器重啟,IP地址為改變,hosts文件中原來(lái)的IP地址無(wú)效,因此理應(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
--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 /]#
上述命令太長(zhǎng),可寫(xiě)成shell腳本,另外網(wǎng)上有說(shuō)其它幾種方式:
1、使用dockerfile構(gòu)建鏡像
2、使用docker-compose啟動(dòng)
3、修改docker容器啟動(dòng)公共加載的環(huán)境變量的配置文件(我沒(méi)找到我這個(gè)版本的該配置文件)
第一種方式應(yīng)該是不行的,雖然dockerfile在構(gòu)建鏡像時(shí)能設(shè)置相關(guān)環(huán)境變量,但前面提到過(guò)IP、hostname、/etc/hosts都是重新加載的,所以得在docker容器啟動(dòng)的時(shí)候指定,鏡像里的都是不行的;
第二種,本人暫時(shí)對(duì)docker-compose不熟悉,也暫時(shí)不深入探討;
第三種,本人感覺(jué)不方便,因?yàn)槟鞘枪驳模瑢?duì)于不同容器,無(wú)法個(gè)性化;
綜上所述,本人覺(jué)得在容器啟動(dòng)的時(shí)候,通過(guò)命令行指定最方便,但缺點(diǎn)是命令行太長(zhǎng),不過(guò)寫(xiě)成shell腳本就行啦!
補(bǔ)充:linux docker 設(shè)置固定容器IP(docker默認(rèn) 容器ip會(huì)變解決)
一、創(chuàng)建自己的網(wǎng)絡(luò)類(lèi)型并指定網(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 鏡像名稱(chēng) --net mynetwork --ip 172.18.0.2 --privileged=true --restart=always -d 鏡像名稱(chēng)
三、重啟docker、查看容器IP
重啟dockers
命令
service docker restart
查看所有容器
命令
docker ps -a
查看容器信息
命令
docker inspect 容器名稱(chēng)
這樣容器IP就不會(huì)變了
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
centos修改docker網(wǎng)絡(luò)配置方法分享
本文給大家分享的是centos修改docker網(wǎng)絡(luò)配置的方法,非常的實(shí)用,有需要的小伙伴可以參考下2017-03-03解決docker加載新的鏡像后repository和tag名稱(chēng)都為none的問(wèn)題
這篇文章主要介紹了解決docker加載新的鏡像后repository和tag名稱(chēng)都為none的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11詳解使用export/import導(dǎo)出和導(dǎo)入docker容器
本篇文章主要介紹了詳解使用export/import導(dǎo)出和導(dǎo)入docker容器,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07如何使用Docker定時(shí)備份數(shù)據(jù)
這篇文章主要介紹了如何使用Docker定時(shí)備份數(shù)據(jù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-04-04Docker Desktop Vmmem內(nèi)存占用過(guò)高問(wèn)題及完美解決方案
DockerDesktopVmmem內(nèi)存占用過(guò)高問(wèn)題常見(jiàn)于其基于WSL運(yùn)行類(lèi)似虛擬機(jī)的機(jī)制,通過(guò)編輯.wslconfig文件限制WSL資源,可有效降低內(nèi)存占用,具體操作包括創(chuàng)建.wslconfig文件,調(diào)整內(nèi)存配置,并重啟Docker Desktop,需注意內(nèi)存設(shè)置不宜過(guò)小,以免影響Docker運(yùn)行和容器穩(wěn)定性2024-09-09Docker容器遷移之導(dǎo)入和導(dǎo)出容器方式
這篇文章主要介紹了Docker容器遷移之導(dǎo)入和導(dǎo)出容器方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05如何修改Docker部署gitlab的外部訪問(wèn)地址和端口
這篇文章主要介紹了如何修改Docker部署gitlab的外部訪問(wèn)地址和端口問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05