这篇文章给大家分享的是有关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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。