您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關Docker中每次啟動容器IP及hosts指定的操作示例的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
/etc/hosts, /etc/resolv.conf和/etc/hostname,容器中的這三個文件不存在于鏡像,在啟動容器的時候,通過mount的形式將這些文件掛載到容器內部。因此,如果在容器中修改這些文件的話,修改部分不會存在于容器的top layer,而是直接寫入這三個物理文件中。
為什么重啟后修改內容不存在了?原因是:每次Docker在啟動容器的時候,通過重新構建新的/etc/hosts文件,這又是為什么呢?原因是:容器重啟,IP地址為改變,hosts文件中原來的IP地址無效,因此理應修改hosts文件,否則會產生臟數據。
在每次啟動容器的時候指定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 網絡模式及配置的操作
--hostname :指定hostname; --net : 指定網絡模式 --ip:指定IP --add-host :指定往/etc/hosts添加的host
啟動完容器后,進入容器查看 /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 /]#
1、使用dockerfile構建鏡像
2、使用docker-compose啟動
3、修改docker容器啟動公共加載的環境變量的配置文件(我沒找到我這個版本的該配置文件)
第一種方式應該是不行的,雖然dockerfile在構建鏡像時能設置相關環境變量,但前面提到過IP、hostname、/etc/hosts都是重新加載的,所以得在docker容器啟動的時候指定,鏡像里的都是不行的;
第二種,本人暫時對docker-compose不熟悉,也暫時不深入探討;
第三種,本人感覺不方便,因為那是公共的,對于不同容器,無法個性化;
綜上所述,本人覺得在容器啟動的時候,通過命令行指定最方便,但缺點是命令行太長,不過寫成shell腳本就行啦!
補充:linux docker 設置固定容器IP(docker默認 容器ip會變解決)
命令
docker network create --subnet=172.18.0.0/16 mynetwork
命令
docker run -itd -p 5001:5001 --name 鏡像名稱 --net mynetwork --ip 172.18.0.2 --privileged=true --restart=always -d 鏡像名稱
重啟dockers
命令
service docker restart
查看所有容器
命令
docker ps -a
查看容器信息
命令
docker inspect 容器名稱
這樣容器IP就不會變了
感謝各位的閱讀!關于“Docker中每次啟動容器IP及hosts指定的操作示例”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。