Centos7创建支持ssh服务器的docker容器

时间:2022-06-19
本文章向大家介绍Centos7创建支持ssh服务器的docker容器 ,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

1、启动一个docker容器:

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

这样就会新建一个docker容器,并且进入容器的bash中  2、安装sshd:

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

3、启动sshd服务:

# /usr/sbin/sshd -D
  • 1

我的报一下错误

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

此时,依次执行下列命令:  一路按回车键确认

# 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服务,一切正常。  4、编辑sshd_config配置文件

# vim /etc/ssh/sshd_config
  • 1

找到UsePAM yes这一段配置,将其改成UsePAM no

UsePAM no
#UsePAM yes
  • 1
  • 2

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

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

两次输入密码  6、改完密码执行exit命令退出,这时会回到宿主机器的shell,执行下列命令将容器提交到镜像:

# docker commit containerid imagename
  • 1

这里的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
  • 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目录:

这个功能在进行测试的时候十分方便,比如用户可以放置一些程序或数据到本地目录中,然后在容器内运行和使用。另外,本地目录的

(adsbygoogle = window.adsbygoogle || []).push({});