標籤:dockerfile
1、安裝docker並啟動docker,不在贅述
2、建立使用Dockerfile安裝sshd服務的目錄,名字路徑自訂
mkdir sshd_centos
cd sshd_centos
3、編輯啟動sshd服務的指令檔
vim run.sh內容為
#!/bin/bash
/usr/sbin/sshd -D
4、產生宿主機和docker容器通訊的密鑰
ssh-keygen -t rsa -b 2048 -f /etc/ssh/ssh_host_rsa_key
650) this.width=650;" src="/e/u261/themes/default/images/spacer.gif" style="background:url("/e/u261/lang/zh-cn/images/localimage.png") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" />650) this.width=650;" src="http://s1.51cto.com/wyfs02/M01/84/59/wKiom1eN2CTjLLYsAABJJfgyVY4725.png-wh_500x0-wm_3-wmp_4-s_2013598360.png" title="1.png" alt="wKiom1eN2CTjLLYsAABJJfgyVY4725.png-wh_50" />
此時進入/etc/ssh/目錄下可查看到一系列密鑰檔案,
650) this.width=650;" src="/e/u261/themes/default/images/spacer.gif" style="background:url("/e/u261/lang/zh-cn/images/localimage.png") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" />650) this.width=650;" src="http://s3.51cto.com/wyfs02/M02/84/59/wKiom1eN2D3RjKhNAABK8aKt0vM791.png-wh_500x0-wm_3-wmp_4-s_4016783231.png" title="2.png" alt="wKiom1eN2D3RjKhNAABK8aKt0vM791.png-wh_50" />
4、拷貝檔案到sshd_centos目錄下,此時在sshd_centos目錄下,下面的./表示當前路徑
cp /etc/ssh/ssh_host_rsa_key ./
cp /etc/ssh/ssh_host_ecdsa_key ./
cp /etc/ssh/ssh_host_ed25519_key ./
cat /etc/ssh/ssh_host_rsa_key.pub > authorized.keys
5、編輯Dockerfile檔案vim Dockerfile,內容如下
650) this.width=650;" src="/e/u261/themes/default/images/spacer.gif" style="background:url("/e/u261/lang/zh-cn/images/localimage.png") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" />650) this.width=650;" src="http://s1.51cto.com/wyfs02/M01/84/59/wKiom1eN2FOzk9xiAAC7znUkV9A411.png-wh_500x0-wm_3-wmp_4-s_3997655008.png" title="3.png" alt="wKiom1eN2FOzk9xiAAC7znUkV9A411.png-wh_50" />
#產生的鏡像以centos為基礎鏡像
FROM centos
#開發人員資訊及其他
MAINTAINER by test
#升級系統
RUN yum -y update
#安裝openssh-server
RUN yum install -y openssh-server
#修改ssh_config
RUN sed -i ‘s/UsePAM yes/UsePAM no/g‘ /etc/ssh/sshd_config
#將密鑰檔案複製到/etc/ssh目錄中
ADD ssh_host_rsa_key /etc/ssh/ssh_host_rsa_key
RUN chmod 600 /etc/ssh/ssh_host_rsa_key
ADD ssh_host_rsa_key.pub /etc/ssh/ssh_host_rsa_key.pub
ADD ssh_host_ed25519_key /etc/ssh/ssh_host_ed25519_key
RUN chmod 600 /etc/ssh/ssh_host_ed25519_key
ADD ssh_host_ecdsa_key /etc/ssh/ssh_host_ecdsa_key
RUN chmod 600 /etc/ssh/ssh_host_ecdsa_key
RUN mkdir -p /root/.ssh
ADD authorized_keys /root/.ssh/authorized_keys
#將ssh服務啟動指令碼複製到/usr/local/sbin目錄中,並附加執行許可權
ADD run.sh /usr/local/sbin/run.sh
RUN chmod 755 /usr/local/sbin/run.sh
#變更root密碼
RUN echo "root:111111" |chpasswd
#開啟22連接埠
EXPOSE 22
#運行指令碼,啟動ssh服務
CMD ["/usr/local/sbin/run.sh"]
儲存退出,查看sshd_centos目錄下檔案
650) this.width=650;" src="/e/u261/themes/default/images/spacer.gif" style="background:url("/e/u261/lang/zh-cn/images/localimage.png") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" />
6、產生鏡像檔案
docker build -t sshd:dockerfile .
注意:-t後面是自訂容器名,最後有一個點. 表示目前的目錄下的Dockerfile檔案
有資訊產生
650) this.width=650;" src="/e/u261/themes/default/images/spacer.gif" style="background:url("/e/u261/lang/zh-cn/images/localimage.png") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" />650) this.width=650;" src="http://s4.51cto.com/wyfs02/M02/84/59/wKioL1eN2IXjd2L2AAELaOJ8QtA836.png-wh_500x0-wm_3-wmp_4-s_4206275963.png" title="5.png" alt="wKioL1eN2IXjd2L2AAELaOJ8QtA836.png-wh_50" />
最後看到
650) this.width=650;" src="/e/u261/themes/default/images/spacer.gif" style="background:url("/e/u261/lang/zh-cn/images/localimage.png") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" />650) this.width=650;" src="http://s3.51cto.com/wyfs02/M01/84/59/wKioL1eN2JiCrWTQAABE5IW6rv4589.png-wh_500x0-wm_3-wmp_4-s_2566451327.png" title="6.png" alt="wKioL1eN2JiCrWTQAABE5IW6rv4589.png-wh_50" />successfully即表示成功
表示產生鏡像成功
可用docker images查看
650) this.width=650;" src="/e/u261/themes/default/images/spacer.gif" style="background:url("/e/u261/lang/zh-cn/images/localimage.png") no-repeat center;border:1px solid #ddd;" alt="spacer.gif" />650) this.width=650;" src="http://s5.51cto.com/wyfs02/M02/84/59/wKiom1eN2MvCkh6AAAArRZTSsWM485.png-wh_500x0-wm_3-wmp_4-s_612672709.png" title="clipboard.png" alt="wKiom1eN2MvCkh6AAAArRZTSsWM485.png-wh_50" />
7、運行鏡像產生容器
docker run -d -p 10022:22 sshd:dockerfile
docker ps 查看容器
8、在終端使用ssh 宿主機IP 10022是否可登陸
另:若無法登陸,則使用docker logs 容器ID查看日誌
本文出自 “沏茶品香” 部落格,請務必保留此出處http://chinawu.blog.51cto.com/10692884/1827787
利用Dockerfile檔案建立帶有sshd服務的centos鏡像