Docker创建可用ssh连接的ubuntu

从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 容器中。

  1. 在 HOME 目录下创建 .ssh 目录:mkdir ~/.ssh
  2. 新建文件 ~/.ssh/authorized_keys :touch ~/.ssh/authorized_keys
  3. 新开一个 macOS 下的终端窗口,执行命令 cat ~/.ssh/id_rsa.pub,复制打印的一行公钥信息
  4. 回到 ubuntu 容器中,将第 3 步复制的公钥粘贴到 ~/.ssh/authorized_keys 中保存。
  5. 此时完成了 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

https://www.smslit.top/2018/12/20/docker_ubuntu_learn/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值