创建可以ssh的docker容器[通俗易懂]

创建可以ssh的docker容器

大家好,又见面了,我是全栈君。

操作系统:vm centos6.5 x64 192.168.240.148

docker容器:centos6.5 x64 172.17.0.3

 

1.下载原始镜像

 

1

2

[root@localhost ~]#docker pull centos 

###一般会拉最新版centos7和centos6.5过来,这里使用的是centos6.5###

 

2.安装openssh

1

2

3

4

5

6

7

[root@localhost ~]# docker run -i -t kw1073/centos-new4 /bin/bash

 

bash-4.1#yum -y install openssh-server openssh-clients

bash-4.1#chkconfig sshd on

bash-4.1#service sshd start

 

######显示如下#####

1

2

3

4

Generating SSH1 RSA host key:                              [  OK  ]

Generating SSH2 RSA host key:                              [  OK  ]

Generating SSH2 DSA host key:                              [  OK  ]

Starting sshd:                                             [  OK  ]

 

3.ssh到宿主机中

1

2

3

4

5

bash-4.1#ssh 192.168.240.148 -p61618

 

root@192.168.240.148's password: 

Last login: Thu Jul 31 22:39:38 2014 from 192.168.240.1

[root@localhost ~]#

 

4.安装passwd

1

2

3

4

bash-4.1#yum install passwd 

###docker官网上的centos6.5原始镜像中没有passwd,用于修改root用户的密码###

bash-4.1#passwd root

bash-4.1#useradd kw1073

 

5.使用commit命令保存镜像

1

[root@localhost ~]#docker ps -l  ###查看docker的id###

wKiom1PZ7TqiK8bWAADDsE7t8k0901.jpg

1

2

[root@localhost ~]#docker commit 6b84dba2a9bb kw1073/centos-new4 

###做成可ssh的docker镜像###

 

6.在宿主机上映射端口

1

2

[root@localhost ~]#docker run -u -t -p 127.0.0.1:222:22 kw1073/centos-new4  /bin/bash 

###做好docker镜像和宿主机的端口映射,这里会直接进入bash环境###

 

7.在docker容器中启动ssh服务

1

2

bash-4.1#service sshd start

bash-4.1#ifconfig

1

2

3

4

5

6

7

8

eth0 Link encap:Ethernet HWaddr 82:E2:4F:F5:12:E9

          inet addr:172.17.0.3 Bcast:0.0.0.0 Mask:255.255.0.0

          inet6 addr: fe80::80e2:4fff:fef5:12e9/64 Scope:Link

          UP BROADCAST RUNNING MTU:1500 Metric:1

          RX packets:4882 errors:0 dropped:0 overruns:0 frame:0

          TX packets:4107 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:1000

          RX bytes:27592541 (26.3 MiB) TX bytes:342979 (334.9 KiB)

 

8.在宿主机上进行ssh连接

1

2

3

4

5

6

7

8

9

[root@localhost ~]#ssh 172.0.0.3

 

The authenticity of host '172.17.0.3 (172.17.0.3)' can't be established.

RSA key fingerprint is 40:4f:f2:9a:55:07:9e:a0:cb:42:60:4f:92:fa:90:e7.

Are you sure you want to continue connecting (yes/no)? yes

Warning: Permanently added '172.17.0.3' (RSA) to the list of known hosts.

root@172.17.0.3's password: 

Last login: Thu Jul 31 10:26:24 2014 from 172.17.42.1

Connection to 172.17.0.3 closed.

 

9.修改容器中ssh的配置

####从上一步可以看到,ssh连接错误,可以登录,但是一登录上去就马上断开####

1

2

3

4

5

bash-4.1# sed -i 's/UsePAM yes/UsePAM no/' /etc/ssh/sshd_config   #修改sshd配置文件

bash-4.1# /etc/init.d/sshd reload 

bash-4.1# /etc/init.d/sshd restart                    #重启sshd服务

Stopping sshd:                                             [  OK  ]

Starting sshd:                                             [  OK  ]

 

10.在宿主机上重试一次ssh连接

1

2

3

4

5

6

7

8

9

10

[root@localhost dist]# ssh 172.17.0.3 

root@172.17.0.3's password: Last login: Thu Jul 31 11:48:51 2014 from 172.17.42.1 

 

-bash-4.1# ls

 

或者如下连接:

[root@localhost dist]# ssh root@127.0.0.1 -p222 

root@127.0.0.1's password: Last login: Thu Jul 31 15:36:56 2014 from 172.17.42.1

 

#####因为做了端口映射,所以可以直接从映射的端口登陆###

 

11.设置docker容器中的环境变量

1

2

3

#######直接从宿主机上拷贝一份过去########

 

[root@localhost dist]# scp /root/.bash* 172.17.0.3:/root/

 

12.在宿主机上重新ssh到容器中

1

2

[root@localhost dist]# ssh 172.17.0.3 root@172.17.0.3's password: Last login: Thu Jul 31 15:07:00 2014 from 172.17.42.1 

[root@89741e6f8e61 ~]#

 

13.保存配置好的docker容器为镜像

1

2

#######查看当前运行中的docker容器#######

[root@localhost ~]# docker ps -a

wKioL1PZ8WGQEfVEAAFkJJ6Wx5s434.jpg

1

2

3

#######保存容器为镜像#######

[root@localhost ~]# docker commit 89741e6f8e61 kw1073/centos-new5

17a270866d48429d582aae50b6f3183a4e76c5b4813b1f6e96b5684cb222b100

1

2

#####查看当前的镜像########

[root@localhost ~]# docker images

wKioL1PZ8oeiGVA1AAKPBPYmO90349.jpg

转载于:https://my.oschina.net/colour10/blog/878672

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108571.html原文链接:https://javaforall.net

(1)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • docker 修改容器时间_docker开放容器端口

    docker 修改容器时间_docker开放容器端口前言用docker搭建的Jenkins环境时间显示和我们本地时间相差8个小时,需修改容器内部的系统时间查看时间查看系统时间date-R进入docker容器内部,查看容器时间dockere

    2022年7月31日
    8
  • docker停止运行中的容器(docker关闭容器)

    问题描述:centos启动一个容器添加了-d参数,但是dockerps或者dockerps-a查看却已经退出了shell>dockerrun-dcentosa44b2b88559b68a2221c9574490a0e708bff49d88ca21f9e59d3eb245c7c0547shell>dockerps退出原因1、docker容器运行必须有一…

    2022年4月10日
    731
  • docker 搭建drone + gitee 的CI/CD

    docker 搭建drone + gitee 的CI/CD准备创建OAuth应用程序创建一个GiteeOAuth应用程序。ConsumerKey和ConsumerSecret用于授权访问Gitee资源。授权回调URL必须与以下格式和路径匹配,并且必须使用您的确切服务器方案和主机。创建共享密钥创建一个共享密钥来验证跑步者和您的中央无人机服务器之间的通信。您可以使用openssl生成共享密钥:$opensslrand-hex16bea26a2221fd8090ea38720fc445ec.

    2022年8月15日
    18
  • docker mysql日志查看_MySQL查看版本

    docker mysql日志查看_MySQL查看版本查询DockerMySQL的版本号1.查找到当前正在运行的容器#dockerps2.进入mysql容器(命令中不带小括号)#dockerexec-it(mysql的名字,或id)bash3.登录mysql,输入账号密码登录(命令中不带小括号)#mysql-u(root)-p(abcd)登录成功以后,会显示该mysql的详细信息,其中包含版本号…

    2022年9月28日
    5
  • docker 拉取镜像_docker启动镜像命令

    docker 拉取镜像_docker启动镜像命令docker镜像网站官网https://hub.docker.com/网易蜂巢https://id.163yun.com/需要的登录daocloudhttp://hub.daocloud.io/不需要登录公司内部私服:需要添加配置需要在/etc/docker/daemon.json(如果不存在,则手动创建)添加下面一段话 { “registry-mirrors”:[“https://registry.docker-cn.com”], “insecure-

    2022年9月22日
    5
  • docker 使用 记录

    docker 使用 记录

    2022年2月19日
    52

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号