1. 程式人生 > >Centos7建立支援ssh伺服器的docker容器

Centos7建立支援ssh伺服器的docker容器

1、啟動一個docker容器:

# docker run -it centos:latest /bin/bash

這樣就會新建一個docker容器,並且進入容器的bash中
2、安裝sshd:

# yum -y install openssh-server
# yum -y install openssh-clients

3、啟動sshd服務:

# /usr/sbin/sshd -D

我的報一下錯誤

Could not load host key: /etc/ssh/ssh_host_rsa_key
Could not load host key: /etc/ssh/ssh_host_ecdsa_key
Could not
load host key: /etc/ssh/ssh_host_ed25519_key

此時,依次執行下列命令:
一路按回車鍵確認

# ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N ""
# ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key -N ""
# ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ed25519_key -N ""

再啟動sshd服務,一切正常。
4、編輯sshd_config配置檔案

# vim /etc/ssh/sshd_config

找到UsePAM yes這一段配置,將其改成UsePAM no

UsePAM no
#UsePAM yes

5、修改root的密碼,如果不能passwd,執行:# yum -y install passwd

# passwd root
Changing password for user root.
New password:

兩次輸入密碼
6、改完密碼執行exit命令退出,這時會回到宿主機器的shell,執行下列命令將容器提交到映象:

# docker commit containerid imagename

這裡的containerid是容器的id,imagename就是提交時候映象的名稱,第一次提交的時候最好使用一個新的名稱,不要覆蓋了原有的乾淨的centos映象。
容器id可以通過docker ps -l命令檢視到,啟動容器後預設的主機名其實就是容器id。
例如:# docker commit 67bb1912a373 sshd-images


7、通過docker run啟動一個新的容器,引數-d表示後臺執行,-p表示docker到主機的埠的對映

# docker run -d -p 10022:22 imagename /usr/sbin/sshd -D

如果啟動沒問題的話,就可以登入到容器了:

# ssh root@localhost -p 10022

掛載一個主機目錄作為資料卷
使用-v標記也可以指定掛載一個本地的已有目錄到容器中去作為資料卷:

# docker run -d -p 10022:22 --name web -v /usr/webapp:/opt/webapp sshd-images:latest /usr/sbin/sshd -D

上面的命令載入主機的/usr/webapp目錄到容器的/opt/webapp目錄:

這個功能在進行測試的時候十分方便,比如使用者可以放置一些程式或資料到本地目錄中,然後在容器內執行和使用。另外,本地目錄的