2016-12-14 83 views
0

我在我的ubuntu机器上安装了Docker镜像 - centos 7。但没有找到ssh服务。所以我无法运行这项服务。docker image - centos 7> ssh service not found

[[email protected] /]# yum install openssh-server openssh-clients 
Loaded plugins: fastestmirror, ovl 
Loading mirror speeds from cached hostfile 
* base: mirror.dhakacom.com 
* extras: mirror.dhakacom.com 
* updates: mirror.dhakacom.com 
Package openssh-server-6.6.1p1-31.el7.x86_64 already installed and latest version 

Package openssh-clients-6.6.1p1-31.el7.x86_64 already installed and latest version 
Nothing to do 
[[email protected] /]# ss    
ssh   ssh-agent ssh-keygen sshd   ssltap  
ssh-add  ssh-copy-id ssh-keyscan sshd-keygen 

我该如何远程登录docker镜像?

+0

'sshd'在那里,但为什么你需要ssh到你的容器? – Matt

+0

我知道sshd在那里。但没有找到与该服务相关的任何内容。我想远程登录码头容器来运行一个 –

+0

通常,试图[ssh到一个容器是一个容器反模式](https://blog.docker.com/2014/06/why-you-dont-need-to -run-sshd的功能于搬运工/)。如果你在一个容器中做了一件容易的事情,它可以在图像构建过程中完成吗?你可以通过[docker连接插件](https://github.com/ansible/ansible/pull/11650)来做到吗? – Matt

回答

2

您必须对Dockerfile执行以下指示。

RUN yum install -y sudo wget telnet openssh-server vim git ncurses-term 
RUN useradd your_account 

RUN mkdir -p /home/your_account/.ssh && chown -R your_account /home/your_account/.ssh/ 

# Create known_hosts 
RUN touch /home/your_account/.ssh/known_hosts 


COPY files/authorized_keys /home/your_account/.ssh/ 
COPY files/config   /home/your_account/.ssh/ 
COPY files/pam.d/sshd  /etc/pam.d/sshd 
RUN touch /home/your_account/.ssh/environment 
RUN chown -R your_account /home/your_account/.ssh 
RUN chmod 400 -R /home/your_account/.ssh/* 
RUN chmod 700 -R /home/your_account/.ssh/known_hosts 
RUN chmod 700 /home/your_account/.ssh/environment 


# Enable sshd 
COPY files/sshd_config /etc/ssh/ 
RUN ssh-keygen -f /etc/ssh/ssh_host_rsa_key -N '' -t rsa 

# Add a account into sudoers and this account doesn't need to type his password 
COPY files/sudoers /etc/ 
COPY files/start.sh /root/ 

我不得不删除该文件上将/etc/pam.d/sshd“pam_nologin.so”,因为当我升级的OpenSSH服务器的版本的OpenSSH服务器,6.6.1p1-31.el7, pam_nologin.so将不允许任何用户进行远程登录,即使文件/ etc/nologin不存在。

start.sh

#!/bin/bash 
/usr/sbin/sshd -E /tmp/sshd.log 

开始的CentOS容器

  • 搬运工运行-d -t -p $(sshPort):22 --name $(容器名称)$(imageName)/箱/ bash的
  • 泊坞窗EXEC -d $(容器名称)庆典-c “SH /root/start.sh”

登录容器

  • SSH $(泊坞IP)$(sshPort)
1

在延伸到@puritys

你可以这样做的,而不是Dockerfile

最后文件中:

ENTRYPOINT /usr/sbin/sshd -E /tmp/sshd.log && /bin/bash 

然后你只需要运行:

docker run -d -p -t $(sshPort):22 --name $(containerName) $(imageName) /bin/bash