docker 容器开启ssh

一. 从docker hub 下载centos 官方镜像
docker pull centos:7
 
运行容器
docker run -i -t -p 1022:22 --name ssh centos:7 /bin/bash
 
二. 安装passwd,openssl,openssh-server
yum -y update
yum install passwd openssl openssh-server -y
 
启动sshd:
# /usr/sbin/sshd -D &
正常启动需要pid文件存在,可以创建/var/run/ssh
这时报以下错误:
[root@ b5926410fe60 /]# /usr/sbin/sshd
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
 
执行以下命令解决:
[root@b5926410fe60 /]# ssh-keygen -q -t rsa -b 2048 -f /etc/ssh/ssh_host_rsa_key -N '' 
[root@b5926410fe60 /]# ssh-keygen -q -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key -N ''
[root@b5926410fe60 /]# ssh-keygen -t dsa -f /etc/ssh/ssh_host_ed25519_key -N ''
 
然后,修改 /etc/ssh/sshd_config 配置信息:
UsePAM yes 改为 UsePAM no
UsePrivilegeSeparation sandbox 改为 UsePrivilegeSeparation no
 
[root@b5926410fe60 /]# sed -i "s/#UsePrivilegeSeparation.*/UsePrivilegeSeparation no/g" /etc/ssh/sshd_config
[root@b5926410fe60 /]# sed -i "s/UsePAM.*/UsePAM no/g" /etc/ssh/sshd_config
 
修改完后,重新启动sshd
[root@b5926410fe60 /]# /usr/sbin/sshd -D &
编写简单的启动脚本,方便直接后台运行容器ssh服务远程连接容器
vim /sshd.sh
#!/bin/bash
/usr/sbin/sshd -D
chmod 755 /sshd.sh
 
三. 修改root 密码
 [root@b5926410fe60 /]# passwd root
 
五. 将当前容器保存为镜像
docker ps -all
docker commit ce09 centos7-ssh
 
六. 在宿主机上基于新创建的镜像启动新的容器
--先删除之前的容器 docker ps -all
docker rm -f 4122f818a741

 

--基于新镜像运行容器
docker run -t -i -p 10021:22 --name one_ssh centos7-ssh:latest /bin/bash
docker run -p 10022:22 -d centos7-ssh:latest /run.sh
当容器内22端口启动后才可以用docker ps -a看到相应的端口
保证22端口启动后就可以进行远程 连接了。
 
可以直接拿此镜像使用了
 
posted @   阮小七  阅读(21127)  评论(1编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
点击右上角即可分享
微信分享提示