Zhou Study hard, improve every day.

docker自定义ip

2020-06-03
本文 975 字,阅读全文约需 3 分钟

一、原因

/etc/hosts, /etc/resolv.conf和/etc/hostname,容器中的这三个文件不存在于镜像,在启动容器的时候,通过mount的形式将这些文件挂载到容器内部。因此,如果在容器中修改这些文件的话,修改部分不会存在于容器的top layer,而是直接写入这三个物理文件中。

为什么重启后修改内容不存在了?原因是:每次Docker在启动容器的时候,通过重新构建新的/etc/hosts文件,这又是为什么呢?原因是:容器重启,IP地址为改变,hosts文件中原来的IP地址无效,因此理应修改hosts文件,否则会产生脏数据。

二、解决办法

在每次启动容器的时候指定IP、hostname、往/etc/hosts里添加hosts,命令如下:

# 创建自定义网络,以便后续设置静态ip
$ docker network create --subnet 10.0.0.0/24 custom_net

$ docker run -itd --name hadoop0 --hostname hadoop0 --net custom_net --ip 10.0.0.30 --add-host hadoop1:10.0.0.31 --add-host hadoop2:10.0.0.32  -d -P -p 50070:50070 -p 8088:8088 hadoop:master

Docker系列(四)Docker 网络模式及配置

--hostname :指定hostname;
--net : 指定网络模式
--ip:指定IP
--add-host :指定往/etc/hosts添加的host

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

启动完容器后,进入容器查看 /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
10.0.0.31   hadoop1
10.0.0.32   hadoop2
10.0.0.30   hadoop0

#


Comments

Content