`

ssh访问docker容器

阅读更多
1、用户密码认证方式登陆

hsl@ubuntu:~$ sudo docker images

 
REPOSITORY TAG IMAGE ID CREATED SIZE
hsl/ubuntu 14.04_add_sourcealiyun_git_vim_ssh 7e81fb2f82c5 44 minutes ago 634.2 MB
hsl/ubuntu 14.04_JenkinsWithDocker_key 6fb1d3cb7983 46 hours ago 760 MB
hsl/ubuntu 14.04_JenkinsWithDocker_password 659fcb00b0dc 3 days ago 760.1 MB
ubuntu 14.04 4a725d3b3b1c 8 days ago 188 MB
training/webapp latest 6fae60ef3446 15 months ago 348.8 MB

hsl@ubuntu:~$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

hsl@ubuntu:~$ sudo docker run -tid -p 22 -P hsl/ubuntu:14.04_add_sourcealiyun_git_vim_ssh
ea153153c8837a4b0e1a8d0e6945200c7ac820c358d546202f1a95c72f12ca77

hsl@ubuntu:~$ sudo docker exec -ti ea /bin/bash
root@ea153153c883:/# cd /etc/ssh
root@ea153153c883:/etc/ssh# vim sshd_config 


sshd_config 需要关注三个地方,未修改之前是这样:

PermitRootLogin without-password
#AuthorizedKeysFile %h/.ssh/authorized_keys
#PasswordAuthentication yes
说明:
#PermitRootLogin yes #允许root用户以任何认证方式登录(用户名密码认证和公钥认证)
#PermitRootLogin without-password #只允许root用公钥认证方式登录
#PermitRootLogin no #不允许root用户以任何认证方式登录

这里先修改两处:
PermitRootLogin without-password 改为 PermitRootLogin yes
#PasswordAuthentication yes 改为 PasswordAuthentication yes

root@ea153153c883:/etc/ssh# cd
root@ea153153c883:~# service ssh start
* Starting OpenBSD Secure Shell server sshd [ OK ] 
root@ea153153c883:/# passwd root
Enter new UNIX password: 
Retype new UNIX password: 
passwd: password updated successfully
root@ea153153c883:/# ifconfig


#获得docker的内网地址(inet addr):172.17.0.2
root@ea153153c883:/# exit

exit
hsl@ubuntu:~$ ssh root@172.17.0.2
root@172.17.0.2's password: 
Welcome to Ubuntu 14.04 LTS (GNU/Linux 3.13.0-93-generic x86_64)
* Documentation:  https://help.ubuntu.com/
The programs included with the Ubuntu system are free software;
the exact distribution terms for each program are described in the
individual files in /usr/share/doc/*/copyright.
Ubuntu comes with ABSOLUTELY NO WARRANTY, to the extent permitted by
applicable law.
root@ea153153c883:~# exit
logout
Connection to 172.17.0.2 closed.


hsl@ubuntu:~$ ifconfig
#获得宿主机的内网地址(inet地址):192.168.127.159,这里试一下端口映射方式登陆docker
#因为做了端口映射,所以可以直接从映射的端口登陆,只需要知道和docker的22端口映射的宿主机端口和宿主机的ip(如果和docker的22做端口映射时候采用默认IP方式,则默认宿主机的所有IP都和docker的22端口映射,这样localhost和子网IP均可等登陆)
#即ssh root@172.17.0.2和ssh -p 32770 root@192.168.127.159都可以登陆docker

hsl@ubuntu:~$ ssh -p 32771 root@192.168.127.159

#第一次登陆有警告
The authenticity of host '[192.168.127.159]:32771 ([192.168.127.159]:32771)' can't be established.
ECDSA key fingerprint is SHA256:icDOU4lcWTiFb4eIKUtosFNrqzGMo5ufzqXQfPdtSZg.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '[192.168.127.159]:32771' (ECDSA) to the list of known hosts.

root@192.168.127.159's password: 
Welcome to Ubuntu 14.04.5 LTS (GNU/Linux 4.4.0-36-generic x86_64)
* Documentation:  https://help.ubuntu.com/
Last login: Sun Sep 4 06:00:37 2016 from 172.17.0.1
root@ea153153c883:~# exit
logout
Connection to 192.168.127.159 closed.
hsl@ubuntu:~$ ssh -p 32771 root@192.168.127.159


#再登录一遍就没有警告了
root@192.168.127.159's password: 
Welcome to Ubuntu 14.04.5 LTS (GNU/Linux 4.4.0-36-generic x86_64)
* Documentation:  https://help.ubuntu.com/
Last login: Sun Sep 4 06:01:33 2016 from 192.168.127.159
root@ea153153c883:~# exit
logout
Connection to 192.168.127.159 closed.

 
2、公钥认证方式登陆

hsl@ubuntu:~$ sudo docker run -tid -p 22 -P hsl/ubuntu:14.04_add_sourcealiyun_git_vim_ssh
f2e54200c5c7f3310a27e274d7d8c9585ed3c79f921cb63edb8f3a00d1165e24


hsl@ubuntu:~$ sudo docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f2e54200c5c7 hsl/ubuntu:14.04_add_sourcealiyun_git_vim_ssh "/bin/bash" 15 seconds
ago Up 10 seconds 0.0.0.0:32768->22/tcp big_brown

hsl@ubuntu:~$ sudo docker exec -it f2 /bin/bash


root@f2e54200c5c7:/# vim /etc/ssh/sshd_config 

把第一步中提到的需要注意的三个地方做以下修改:
PermitRootLogin without-password
#AuthorizedKeysFile %h/.ssh/authorized_keys改为AuthorizedKeysFile %h/.ssh/authorized_keys
#PasswordAuthentication yes改为PasswordAuthentication yes

(如果服务器不在本地,千万不能PasswordAuthentication yes->no,万一当前的ssh链接中断,万一RAS认证没弄好,密码验证又禁止了。可以理解为公钥认证优先于用户密码认证,但是万一公钥认证失败,用用户密码认证以防万一)

root@f2e54200c5c7:/# exit
exit

hsl@ubuntu:~$ ssh-keygen -t rsa


#一直回车,生成宿主机的密钥
hsl@ubuntu:~$ cd .ssh
hsl@ubuntu:~/.ssh$ ls
id_rsa id_rsa.pub
hsl@ubuntu:~/.ssh$ scp id_rsa.pub root@172.17.0.2:~/.ssh/
root@172.17.0.2's password: 
id_rsa.pub 100% 392 0.4KB/s 00:00  
hsl@ubuntu:~/.ssh$ sudo docker exec -it f2 /bin/bash

root@ea153153c883:/# cd  
root@ea153153c883:~# cd .ssh
root@ea153153c883:~/.ssh# ls
id_rsa.pub
root@ea153153c883:~/.ssh# mv id_rsa.pub authorized_keys
root@ea153153c883:~/.ssh# ls
authorized_keys
********可以替换上面的通过scp方法把公钥传送到docker*********
#或者直接把宿主机的id_rsa.pub内容复制到docker的/root/.ssh/authorized_keys
hsl@ubuntu:~$ cd .ssh
hsl@ubuntu:~/.ssh$ ls
id_rsa id_rsa.pub known_hosts
hsl@ubuntu:~/.ssh$ cat id_rsa.pub 

#宿主机的公钥
hsl@ubuntu:~/.ssh$ sudo docker exec -it f2 /bin/bash

root@f2e54200c5c7:/# ssh-keygen -t rsa

#这一步只是为了方便产生docker的.ssh目录
root@f2e54200c5c7:/# cd 
root@f2e54200c5c7:~# cd .ssh
root@f2e54200c5c7:~/.ssh# ls
id_rsa id_rsa.pub
root@f2e54200c5c7:~/.ssh# touch authorized_keys
root@f2e54200c5c7:~/.ssh# ls
authorized_keys id_rsa id_rsa.pub
root@f2e54200c5c7:~/.ssh# vim authorized_keys 


#把宿主机的id_rsa.pub内容复制到docker的/root/.ssh/authorized_keys

********可以替换上面的通过scp方法把公钥传送到docker*********
root@f2e54200c5c7:/# service ssh start
* Starting OpenBSD Secure Shell server sshd [ OK ] 
root@f2e54200c5c7:/# exit
exit

hsl@ubuntu:~/.ssh$ ssh root@172.17.0.2
Welcome to Ubuntu 14.04.5 LTS (GNU/Linux 4.4.0-36-generic x86_64)
* Documentation:  https://help.ubuntu.com/
Last login: Sun Sep 4 08:18:21 2016 from 172.17.0.1
root@f2e54200c5c7:~# exit
logout
Connection to 172.17.0.2 closed.

分享到:
评论

相关推荐

    Go-Shipspotter-用于通过SSH将端口隧道转发到远程Docker容器的工具

    综上所述,Go-Shipspotter 结合了 Go 语言的高效编程能力、SSH 的安全连接、Docker 的容器化部署以及网络编程技术,提供了一个强大且实用的工具,帮助开发者轻松访问远程 Docker 容器内的服务。

    docker-ssh:Docker容器的SSH服务器〜因为每个容器都应该可访问

    Docker容器的SSH服务器〜因为每个容器都应可访问。 是否想立即通过SSH进入您的容器? 干得好: $ docker run -d -p 2222:22 \ -v /var/run/docker.sock:/var/run/docker.sock \ -e FILTERS={\"name\":[\"^/my-...

    freighter:通过SSH轻松部署Docker容器

    Freighter的目标是简化在ssh上部署docker容器的过程。 Freighter使用一个YAML文件来描述您环境中的环境,服务器,图像和容器。 货机目标: 简单的Docker容器部署 直截了当的配置 刚接触货机的用户应能在几分钟内...

    在Docker容器中不需要运行sshd的原因浅析

    总的来说,虽然在Docker容器中运行SSHD提供了一种熟悉的远程访问途径,但它可能并不适合所有的应用场景,尤其是对于那些追求轻量级、安全性和易于管理的容器化服务来说。理解并利用Docker原生功能以及最佳实践,可以...

    Go-Dockssh从任何地何ssh进入任何容器借助redis进行密码存储

    Go-Dockssh是一个基于Go语言开发的工具,它允许用户从任何地方通过SSH协议安全地连接到Docker容器。这个工具特别有用,因为它提供了一种便捷的方法来远程管理运行在不同环境下的容器,无需直接暴露容器的端口或设置...

    dockupdater:自动使您的Docker服务和Docker容器保持最新版本

    通过提供的多种平台通知您与Docker swarm一起使用以更新最新可用版本的服务限制您的服务器SSH访问有助于保持第三方容器的最新状态入门可以找到更详细的用法和配置。Docker容器通过docker映像将Dockupdater部署在...

    通过SSH将端口转发到远程Docker容器的工具:ship:-Golang开发

    Shipspotter一个远程端口转发工具,用于访问Docker容器内的服务。 那些私有管理界面,JMX端口或Erlang / Elixir分发端口不对外开放? 没问题。 Shipspotter aut Shipspotter一个远程端口转发工具,用于访问Docker...

    群晖中docker开启ssh.pdf

    在本文中,我们将讨论如何在群晖NAS上运行的Docker容器中启用SSH服务,特别是针对CentOS容器。 首先,我们需要理解Docker的基本概念。Docker的设计目标是使每个容器专注于运行单个进程,以实现更好的资源隔离和效率...

    在docker容器中调用和执行宿主机的docker操作

    标题中的“在docker容器中调用和执行宿主机的docker操作”是指在Docker容器内部运行命令来控制宿主机上的Docker服务。这种技术被称为Docker-in-Docker(dind),它允许用户在隔离的环境中运行Docker命令,这对于自动...

    docker相关资料

    #### 二、Docker容器网络模型 Docker使用了一种称为**docker0**的虚拟网桥来实现容器间的通信。这个虚拟网桥扮演着类似家庭路由器的角色,所有容器的网络流量都会经过docker0网桥。这意味着每个容器都有一个虚拟接口...

    docker-gollum:Gollum Wiki 的 Docker 容器

    Gollum Docker 容器从Docker容器在机架网络服务器中运行 gollum/gollum。安装 git clone https://github.com/hrzg/docker-gollum.gitcd docker-gollum在开始使用此容器之前,您必须准备一些包含 SSH 密钥和所需配置...

    docker-desktop:通过Docker Desktop,您可以创建可以远程访问的虚拟桌面。 它已经安装了Firefox和Libreoffice!

    Docker Desktop是一款强大的工具,它为开发者提供了在本地运行Docker容器的便捷环境。通过Docker Desktop,用户可以在自己的机器上构建、测试和部署应用程序,而无需关心底层基础设施的复杂性。这款应用支持Windows...

    jenkins+docker实现自动编译、打包、构建镜像、容器部署

    通过maven编译、打包,然后通过执行shell脚本使docker构建镜像并push到私服(或者阿里云)仓库,此操作完成后jenkins服务器上再执行SSH命令登录到部署服务器,docker从仓库(私服)拉取镜像,启动容器。整个操作流程...

    群晖中docker开启ssh (2).pdf

    本文将详细讨论如何在群晖的Docker容器中开启SSH服务。 首先,群晖用户已经知道如何安装Docker并创建容器,这里不再赘述。重点在于,在Docker容器内启用SSH服务,这通常是为了远程管理和控制容器内的应用。然而,...

    群晖中docker开启ssh.docx

    1. **进入Docker容器的Shell**: 使用`docker exec`命令,可以进入已运行的CentOS-SVN容器的交互式bash shell: ```bash docker exec -it centos-svn /bin/bash ``` 2. **检查和安装SSH服务**: 首先,确认...

    docker-dropbear:Docker 容器中的 Dropbear

    可用于受限的 root ssh 访问 ###示例用法 只有容器没有卷 # Fetch image docker fetch simonswine/dropbear # Start a container and map to host port 22001 docker run -d -p 22001:22 simonswine/dropbear 1f4...

    autossh:高度可定制的AutoSSH Docker容器

    Autossh 高度可定制的AutoSSH docker容器。概述jnovack / autossh是一个小型的轻量级映像(约15MB),尝试提供一种安全的方式来建立SSH隧道,而无需在映像本身中包含密钥或链接到主机。 有数千个autossh docker容器...

    docker-postgresql93:PostgreSQL 9.3 的 Docker 容器

    将您的公钥添加到容器的 SSH 服务器以便于访问 向主机公开端口22 (SSH) 和 5432 (PostgreSQL) 与主机和其他 Docker 容器共享 PostgreSQL数据目录和日志文件 链接: 我网站中的 建造 $ docker build -t nimiq/...

Global site tag (gtag.js) - Google Analytics