Centos7建立支持ssh服務器的docker容器

一、啓動一個docker容器:web

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

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

# yum -y install openssh-server
# yum -y install openssh-clients
  • 1
  • 2

三、啓動sshd服務:shell

# /usr/sbin/sshd -D
  • 1

個人報一下錯誤vim

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
  • 1
  • 2
  • 3

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

# 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 ""
  • 1
  • 2
  • 3

再啓動sshd服務,一切正常。 
四、編輯sshd_config配置文件bash

# vim /etc/ssh/sshd_config
  • 1

找到UsePAM yes這一段配置,將其改爲UsePAM noapp

UsePAM no
#UsePAM yes
  • 1
  • 2

五、修改root的密碼,若是不能passwd,執行:# yum -y install passwdssh

# passwd root
Changing password for user root.
New password:
  • 1
  • 2
  • 3

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

# docker commit containerid imagename
  • 1

這裏的containerid是容器的id,imagename就是提交時候鏡像的名稱,第一次提交的時候最好使用一個新的名稱,不要覆蓋了原有的乾淨的centos鏡像。 
容器id能夠經過docker ps -l命令查看到,啓動容器後默認的主機名其實就是容器id。 
例如:# docker commit 67bb1912a373 sshd-images 
七、經過docker run啓動一個新的容器,參數-d表示後臺運行,-p表示docker到主機的端口的映射測試

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

若是啓動沒問題的話,就能夠登陸到容器了:

# ssh root@localhost -p 10022
  • 1

掛載一個主機目錄做爲數據卷 
使用-v標記也能夠指定掛載一個本地的已有目錄到容器中去做爲數據卷:

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

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

這個功能在進行測試的時候十分方便,好比用戶能夠放置一些程序或數據到本地目錄中,而後在容器內運行和使用。另外,本地目錄的

相關文章
相關標籤/搜索