Docker每次啟動容器,IP及hosts指定

2021-08-29 09:53:54 字數 1566 閱讀 7547

前言

每次在使用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,命令如下:

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 網路模式及配置

–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

192.168.10.31 hadoop1

192.168.10.32 hadoop2

192.168.10.30 hadoop0

[root@hadoop0 /]#

上述命令太長,可寫成shell指令碼,另外網上有說其它幾種方式:

1、使用dockerfile構建映象

2、使用docker-compose啟動

3、修改docker容器啟動公共載入的環境變數的配置檔案(我沒找到我這個版本的該配置檔案)

第二種,本人暫時對docker-compose不熟悉,也暫時不深入**;

第三種,本人感覺不方便,因為那是公共的,對於不同容器,無法個性化;

綜上所述,本人覺得在容器啟動的時候,通過命令列指定最方便,但缺點是命令列太長,不過寫成shell指令碼就行啦!

Docker 進入啟動容器

在使用 d引數時,容器啟動後會進入後台,使用者無法看到容器中的資訊,也無法進行操作。這個時候如果需要進入容器進行操作,有多種方法,包括使用官方的attach或exec命令,以及第三方的nsenter工具等。1 attach命令 attach命令是docker自帶的命令,命令格式為 docker at...

docker安裝mysql映象及啟動容器

1 查詢mysql映象 docker search mysqldocker pull mysql 5.7docker run p 3306 3306 name sql v var conf etc mysql conf.d v var mysql data var lib mysql e mysql...

Docker宿主啟動容器mysql

使用docker官方映象安裝mysql服務 1 拉取mysql映象,採用網易加速位址 2 重新命名映象名 3 建立用於掛載的目錄 sudo mkdir my mysql datadir 用於掛載mysql資料檔案 sudo mkdir my mysql conf.d 用於掛載mysql配置檔案 su...