从docker仓库拉取 Ubuntu 镜像:
docker pull ubuntu
配置一个可复用的镜像:
# 创建容器
sudo docker run -it --name ubuntu01 ubuntu /bin/bash
# 安装基础软件
apt-get update
apt-get install vim -y
apt-get install openssh-server -y
# ssh配置
vi /etc/ssh/sshd_config
改变为下面的内容(针对选项修改)
PermitRootLogin yes # 可以登录 root 用户
PubkeyAuthentication yes # 可以使用 ssh 公钥许可
AuthorizedKeysFile .ssh/authorized_keys # 公钥信息保存到文件 .ssh/authorized_keys 中
UsePAM no
# 启动服务
service ssh restart
如果上面的失败,用
/etc/init.d/ssh restart
# 设置当前root密码
passwd
123456
添加主机的 ssh 公钥:
这里的主机指的就是 macOS,保证此时还是在 ubuntu 容器中。
- 在 HOME 目录下创建
.ssh
目录:mkdir ~/.ssh
- 新建文件
~/.ssh/authorized_keys
:touch ~/.ssh/authorized_keys
- 新开一个 macOS 下的终端窗口,执行命令
cat ~/.ssh/id_rsa.pub
,复制打印的一行公钥信息 - 回到 ubuntu 容器中,将第 3 步复制的公钥粘贴到
~/.ssh/authorized_keys
中保存。 - 此时完成了 SSH 访问支持的添加,
ctrl
+d
退出容器。
到这里,一个可复用的容器已经创建好了,接下来我们需要将这个容器保存为镜像,留在后面重复使用:
退出容器的命令行,进入到当前系统的命令行:
sudo docker ps
找出 ubuntu01
对应的 id
, 然后依据这个ID创建镜像:
sudo docker commit id ubuntu-ssh
镜像创建成功,接下来根据 ubuntu-ssh
镜像创建容器:
sudo docker run -d --name ubuntu-ssh01 -p 22201:22 ubuntu-ssh
或者
sudo docker run -d -p 22201:22 --name ubuntu-ssh01 ubuntu-ssh /usr/sbin/sshd -D
将容器的 22 端口绑定到当前主机的 22201 端口
到这里,我们来连接下上面创建的容器:
ssh root@127.0.0.1 -p 22201
参考:
https://58hualong.cn/archives/docker-chaungjian-keyong-ssh-lianjie-de-ubuntu.html