9isuper论坛

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 6741|回复: 0

Docker每次启动容器,IP及hosts指定

[复制链接]

10

主题

11

帖子

103

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
103
发表于 2021-12-14 09:57:39 | 显示全部楼层 |阅读模式
前言
每次在使用Docker启动Hadoop集群的时候,都需要重新绑定下网卡,固定IP,同时修改/etc/hosts文件,非常麻烦,于是想探寻下原因及优化。

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

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

二、解决办法
在每次启动容器的时候指定IP、hostname、往/etc/hosts里添加hosts,命令如下:
  1. 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系列(四)Docker 网络模式及配置
  1. --hostname :指定hostname;
  2. --net : 指定网络模式
  3. --ip:指定IP
  4. --add-host :指定往/etc/hosts添加的host
复制代码

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

启动完容器后,进入容器查看 /etc/hosts

  1. [root@centos-linux-7 /]# docker exec -it hadoop0 bash

  2. [root@hadoop0 /]# cat /etc/hosts
  3. 127.0.0.1   localhost
  4. ::1 localhost ip6-localhost ip6-loopback
  5. fe00::0 ip6-localnet
  6. ff00::0 ip6-mcastprefix
  7. ff02::1 ip6-allnodes
  8. ff02::2 ip6-allrouters
  9. 192.168.10.31   hadoop1
  10. 192.168.10.32   hadoop2
  11. 192.168.10.30   hadoop0
  12. [root@hadoop0 /]#
复制代码

上述命令太长,可写成shell脚本,另外网上有说其它几种方式:

1、使用dockerfile构建镜像

2、使用docker-compose启动

3、修改docker容器启动公共加载的环境变量的配置文件(我没找到我这个版本的该配置文件)

第一种方式应该是不行的,虽然dockerfile在构建镜像时能设置相关环境变量,但前面提到过IP、hostname、/etc/hosts都是重新加载的,所以得在docker容器启动的时候指定,镜像里的都是不行的;

第二种,本人暂时对docker-compose不熟悉,也暂时不深入探讨;

第三种,本人感觉不方便,因为那是公共的,对于不同容器,无法个性化;

综上所述,本人觉得在容器启动的时候,通过命令行指定最方便,但缺点是命令行太长,不过写成shell脚本就行啦!



回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|9isuper ( 鄂ICP备15002592号 )

GMT+8, 2024-11-21 18:08 , Processed in 0.077320 second(s), 18 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表