FinalShell/Xshell连接docker容器中的Ubuntu
具体流程:1.先pull ubuntu镜像,2.安装ssh服务,3.修改root密码,4.finalshell登陆windows10doceker:Server Version: 19.03.5docker 环境:ubuntu一.先拉取镜像docker pull ubuntu运行容器:docker run --name iubuntu -t -i -d -p 3316:22 ubuntu参数: –
·
具体流程:
1.先pull ubuntu镜像,2.安装ssh服务,3.修改root密码,4.finalshell登陆
windows10
doceker:Server Version: 19.03.5
docker 环境:ubuntu
一.先拉取镜像
docker pull ubuntu
运行容器:
docker run --name iubuntu -t -i -d -p 3316:22 ubuntu
参数: –name 指定生成的容器的名称
-i: 以交互模式运行容器,保证容器中STDIN是开启的。通常与 -t 同时使用;
-t: 为容器重新分配一个伪tty终端,通常与 -i 同时使用;
-d: 后台运行容器,并返回容器ID;
-p:可以指定要映射的IP和端口,但是在一个指定端口上只可以绑定一个容器。支持的格式有 hostPort:containerPort、ip:hostPort:containerPort、 ip::containerPort。
ubuntu 则是镜像名称,镜像ID也可以的。
查看是否运行成功:
二、安装ssh服务
1、进入容器终端安装ssh服务#
docker exec -t -i iubuntu /bin/bash
2、执行更新#
apt-get update
等待,输入Y就可以了
3、安装ssh-client、ssh-server#
安装ssh-client命令#
apt-get install openssh-client
等待,输入Y就可以了
安装ssh-server命令#
apt-get install openssh-server
等待,输入Y就可以了
安装完成后,先启动服务#
/etc/init.d/ssh start
查看是否正确启动
ps -e|grep ssh
编辑sshd_config文件#
需要先安装vim编辑器#
apt-get install vim
编辑sshd_config文件#
vim /etc/ssh/sshd_config
保存退出 ESC + : + WQ
重启ssh服务#
service ssh restart
设置ssh密码#
passwd root
查看容器的IP#
(也可以直接使用命令: cat /etc/hosts 直接查看端口)
先安装net-tools工具包#
apt-get install net-tools
查看IP#
ifconfig
退出#
exit
4、保存刚刚修改的镜像#
docker commit [容器ID/容器名] [REPOSITORY:TAG]
5、查看修改用户名或密码
passwd root
后面是用户名
三、使用Xshell连接
在本机连接可以用localhost:3316连接也可以用本机IP:3316连接#
使用Finalshell连接:
然后就成功了:
1.Container安装ssh服务
首先进入Container,进行以下步骤:
① 安装ssh
sudo apt-get install openssh-server #安装ssh服务器 ,没有sudo,直接用apt-get就可以了
service ssh status # 查看ssh服务启动情况
service ssh start # 启动ssh服务
② 配置ssh,允许root登陆
vi /etc/ssh/sshd_config
将PermitRootLogin的值从withoutPassword改为yes - 允许root登陆
将UseDNS yes 改为 UseDNS no - 开始我这个没改,xshell一直报错To escape to local shell, press 'Ctrl+Alt+]'
③ 重启ssh服务
service ssh restart # 重启动ssh服务
3.保存Container镜像
另外开启Docker Quickstart Terminal,保存镜像
docker ps #查看正在运行的container
**找到所要保存的container的container id,假设为xxxxxx**
docker commit xxxxxxxx tomjerry/foobar
(注:tomjerry/foobar为要保存的新镜像的名字,可任意写)
4.重新运行Container
docker run -it -p 50001:22 tomjerry/foobar /bin/bash
service ssh start
注意-p 50001:22这句,意思是将docker的50001端口和container的22端口绑定,这样访问docker的50001等价于访问container的22端口
5.ssh连接container
你可以用xshell或putty等ssh客户端工具连接container
首先假设各方的ip如下:
本地windows ip: 192.168.99.1
docker ip:192.168.99.100
container ip:172.17.0.3
那么,你要远程container,则要访问以下地址:
ssh 192.168.99.100:50001
这样通过访问docker的50001端口,就神奇的间接连通到container的22端口了,从而达到ssh连接container的目的,至此。
6:特别需要注意:因为自己作为一个小白:开始找docker的ip的时候 一直以为是“”以太网适配器 vEthernet (DockerNAT):“ 这个地址,结果搞了很久一直没有成功,结果改为 “以太网适配器 vEthernet (Default Switch):” 就成功了- 直接在cmd中ipconfig可以看到这个地址:如图:
更多推荐
已为社区贡献26条内容
所有评论(0)