1. 程式人生 > >Docker下,實現多臺機器之間相互SSH免密碼登入

Docker下,實現多臺機器之間相互SSH免密碼登入

在Docker下搭建hadoop叢集環境的時候,需要將叢集的機器設定為相互SSH免密碼登入,這裡將整個設定過程總結下來。

機器情況

一共啟動三個容器,都是centos6.7的系統,每個容器的名字和ip如下圖所示:

這裡寫圖片描述

映象檔案

我們要實現SSH免密碼登入,所以執行的容器是要有SSH服務的,為了快速實現我們就不自己裝SSH服務了,hub.docker.com上的kinogmt/centos-ssh:6.7這個映象就能滿足我們的要求,網上也有詳細的Dockerfile指令碼,有興趣的讀者可以通過Dockerfile瞭解這個映象的詳情。

docker-compose.yml檔案

由於是三個容器的相互操作,所以可以製作一個docker-compose.yml檔案對這三個容器做批量操作,檔案內容如下:

version: '2'
services:
  a0: 
    image: kinogmt/centos-ssh:6.7
    container_name: a0
    ports:
      - "19010:22"
    restart: always
  a1: 
    image: kinogmt/centos-ssh:6.7
    container_name: a1
    depends_on:
      - a0
    ports:
      - "19011:22"
    restart: always
  a2: 
    image: kinogmt/centos-ssh:6.7
    container_name: a2
    depends_on:
      - a1
ports: - "19012:22" restart: always

上面的docker-compose.yml檔案中,定義了a0,a1,a2三個容器,用相同的映象,它們的22埠依次對映到當前電腦的19010、19011、19012三個埠上,通過depends_on保證順序啟動(順序啟動在此處沒特殊意義,只是這樣得到的ip是順序的)。

啟動,拿到IP

在docker-compose.yml檔案所在目錄下執行docker-compose up -d建立並啟動三個容器,如下圖:

這裡寫圖片描述

執行命令docker exec -it a0 ip addr可以拿到a0容器的ip是172.19.0.2

,如下圖:

這裡寫圖片描述

再執行docker exec -it a1 ip addrdocker exec -it a2 ip addr命令,得到所有容器的地址如下表:

容器名稱 IP地址 對映埠
a0 172.19.0.2 19010
a1 172.19.0.3 19011
a2 172.19.0.4 19012

登入a0容器,修改ssh配置,建立ssh key

由於a0的22埠已經對映到當前電腦的19010埠,因此在當前電腦的命令列執行ssh [email protected] -p 19010即可登入a0,密碼是password,如下圖:

這裡寫圖片描述

登入a0後,用vi開啟檔案/etc/ssh/sshd_config,找到下圖紅框中的兩個配置:RSAAuthentication和PubkeyAuthentication:

這裡寫圖片描述

將每個配置最左邊的”#”去掉,最終配置如下圖所示:

這裡寫圖片描述

接下來在命令列輸入ssh-keygen -t rsa,連續回車,最終會在/root/.ssh目錄下生成id_rsa和 id_rsa.pub檔案,如下圖:

這裡寫圖片描述

分別登入a1、a2容器,修改ssh配置,建立ssh key

將上面做的登入容器、修改ssh配置、建立ssh key三件事,在a1和a2容器上也各做一次;

在a0上合併a0、a1、a2的公鑰

登入a0容器後,在/root/.ssh目錄下執行以下命令,將a0的公鑰追加到authorized_keys檔案中(如果authorized_keys不存在會新建):

cat id_rsa.pub>> authorized_keys 

然後執行以下命令,將a1的公鑰追加到a0的authorized_keys檔案中:

ssh root@172.19.0.3 cat ~/.ssh/id_rsa.pub>> authorized_keys

執行上述命令的時候會要求輸入密碼,輸入”password”後,就會把a1的公鑰追加到a0的authorized_keys檔案中;

再執行以下命令,將a2的公鑰也追加到a0的authorized_keys檔案中:

ssh root@172.19.0.4 cat ~/.ssh/id_rsa.pub>> authorized_keys

執行完畢後,用cat authorized_keys看一下authorized_keys檔案,裡面已經有了三個公鑰,如下圖:

這裡寫圖片描述

把a0上合併好的公鑰檔案複製到a1

在當前電腦上新開一個控制檯視窗,執行ssh [email protected] -p 19011登入a1,然後執行以下命令就能將a0的authorized_keys檔案複製到a1:

ssh root@172.19.0.2 cat ~/.ssh/authorized_keys>> ~/.ssh/authorized_keys

這次沒有要求輸入密碼,因為a0上已經有了a1的公鑰了,執行完畢後可以檢查/root/.ssh目錄,裡面的authorized_keys檔案和a0上一模一樣;

再新開一個視窗登入a2,將上面的操作重複一遍,使得a2上也有了一模一樣的authorized_keys檔案;

驗證免密碼登入

經過以上步驟,a0、a1、a2三個機器之間已經可以相互免密碼登入了,我們新開一個控制檯視窗,執行ssh [email protected] -p 19011登入a1,再執行ssh [email protected]遠端登入a2,發現可以直接登入成功,不需要輸入密碼,如下圖:

這裡寫圖片描述