通过DockerFile创建ssh服务镜像

简介:

说明:创建一个含有sshd服务的基础镜像,再在这个基础镜像中创建其它中间件镜像,再利用中间件镜像创建应用容器。通过Dockerfile可以创建任意自定义容器,配合supervisord服务完美搭配。

1. 编写Dockerfile

[root@docker1 ~]# vi /root/base_ssh/Dockerfile

-----------------DockerFile-----------------

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# This is Dockerfile   
# Author: koumm     
# Base image docker.io/centos    
FROM docker.io /centos    
MAINTAINER KOUMM XXX@126.com    
RUN rpm -ivh http: //dl .fedoraproject.org /pub/epel/7/x86_64/e/epel-release-7-9 .noarch.rpm && \    
     yum  install  -y curl wget  tar  bzip2  unzip net-tools  rsync  man  openssl openssl-devel && \     
     yum  install  -y gcc gcc-c++ git  make  automake cmake patch logrotate python-devel && \    
     yum -y  install  openssh-server  passwd  python-pip && \    
     yum clean all && \    
     /usr/bin/pip  install  supervisor    
ADD supervisord.conf  /etc/supervisord .conf    
RUN  mkdir  -p  /etc/supervisor .conf.d     
ADD sshd.ini  /etc/supervisor .d /sshd .ini    
RUN  echo  'QWER#123456'  passwd  --stdin root    
RUN  ssh -keygen -q -t rsa -b 2048 -f  /etc/ssh/ssh_host_rsa_key  -N  ''   
RUN  ssh -keygen -q -t ecdsa -f  /etc/ssh/ssh_host_ecdsa_key  -N  ''    
RUN  ssh -keygen -t dsa -f  /etc/ssh/ssh_host_ed25519_key   -N  ''     
RUN  sed  -i  "s/#UsePrivilegeSeparation.*/UsePrivilegeSeparation no/g"  /etc/ssh/sshd_config    
RUN  sed  -i  "s/UsePAM.*/UsePAM no/g"  /etc/ssh/sshd_config    
EXPOSE 22    
ENTRYPOINT [ "/usr/bin/supervisord" ]

--------------------------------------------

2. 创建supervisord.conf配置文件

#创建supervisord主配置文件,事先将再成的配置文件复制一份出来即可。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# vi /root/base_ssh/supervisord.conf
[unix_http_server]   
file = /tmp/supervisor .sock   ; (the path to the socket  file )    
[supervisord]    
logfile= /tmp/supervisord .log ; (main log  file ;default $CWD /supervisord .log)    
logfile_maxbytes=50MB        ; (max main logfile bytes b4 rotation;default 50MB)    
logfile_backups=10           ; (num of main logfile rotation backups;default 10)    
loglevel=info                ; (log level;default info; others: debug,warn,trace)    
pidfile= /tmp/supervisord .pid ; (supervisord pidfile;default supervisord.pid)    
nodaemon= true                ; (start  in  foreground  if  true ;default  false )    
minfds=1024                  ; (min. avail startup  file  descriptors;default 1024)    
minprocs=200                 ; (min. avail process descriptors;default 200)    
[rpcinterface:supervisor]    
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface    
[supervisorctl]    
serverurl=unix: ///tmp/supervisor .sock ; use a unix: //  URL   for  a unix socket    
[include]    
files= /etc/supervisor .d/*.ini


# 创建sshd服务启动文件    

1
2
# vi /root/base_ssh/sshd.ini[program:sshd]   
command = /usr/sbin/sshd  -D


3. 通过Dockerfile创建镜像

[root@docker1 ~]# docker build -t centos:ssh_v2 /root/base_ssh/

过程略..

base_ssh为准备相关资源的目录,包括Dockerfile文件的位置。

[root@docker1 ~]# docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE   
centos              ssh_v2              71fb8b60cf9f        6 minutes ago       407.1 MB    
docker.io/centos    latest              8140d0c64310        2 weeks ago         192.5 MB


4. 通过镜像创建容器

[root@docker1 ~]# docker run -d -p 2223:22 --name sshtest1 centos:ssh_v2

说明: -p 2223:22 映射要机2223端口到容器22端口

image

然后可以通过ssh登录主机的2223端口访问容器ssh服务。






本文转自 koumm 51CTO博客,原文链接:http://blog.51cto.com/koumm/1936534,如需转载请自行联系原作者

相关文章
|
8月前
|
Linux 网络安全 Docker
盘古栈云,创建带ssh服务的linux容器
创建带ssh服务的linux容器
458 146
|
9月前
|
Ubuntu 网络安全 数据安全/隐私保护
搭建SSH服务于RK3399平台上的Ubuntu 18.04,实现远程连接
以上步骤涵盖从安 装 到配制再至实际使 用户建立Ssh 连接所需知识点 。务必注意,在对外提供Ssh 访问
461 2
|
应用服务中间件 网络安全 数据安全/隐私保护
网关服务器配置指南:实现自动DHCP地址分配、HTTP服务和SSH无密码登录。
哇哈哈,道具都准备好了,咱们的魔术秀就要开始了。现在,你的网关服务器已经魔法满满,自动分配IP,提供网页服务,SSH登录如入无人之境。而整个世界,只会知道效果,不会知道是你在幕后操控一切。这就是真正的数字世界魔法师,随手拈来,手到擒来。
585 14
|
Ubuntu 安全 网络安全
Docker镜像:Ubuntu支持systemctl、SSH和VNC
总的来说,Docker提供了一个灵活且强大的方式来创建和运行自定义的Ubuntu镜像。通过理解和使用Dockerfile,你可以轻松地创建一个支持systemctl、SSH和VNC的Ubuntu镜像。
944 21
|
Ubuntu Linux 网络安全
Ubuntu Docker镜像:支持systemctl、SSH、VNC
总的来说,创建一个支持systemctl、SSH和VNC的Ubuntu Docker镜像需要一些技术知识,但是通过学习和实践,我们可以掌握这些技术。这将使我们能够更有效地使用Docker,更好地管理我们的应用程序和服务。CentOS系统中的日志文件位置和管理
432 17
|
安全 Linux Shell
ssh 远程控制服务
SSH(Secure Shell)是一种用于远程登录的安全协议,相比FTP和Telnet,它提供了更高的安全性,避免了明文传输带来的风险。要使用SSH远程管理Linux系统,需要配置sshd服务。本文介绍了如何克隆Linux服务器、修改网络配置,并通过SSH连接两台服务器,最后在目标服务器上创建一个日志文件。
|
监控 安全 Ubuntu
在Linux中,如何进行SSH服务配置?
在Linux中,如何进行SSH服务配置?
|
监控 Ubuntu 网络安全
SSH服务
【7月更文挑战第16天】
301 6
|
网络安全 Windows
在Windows电脑上启动并配置SSH服务
在Windows电脑上启动并配置SSH服务
7635 0
|
网络安全 Windows
windows安装ssh服务
windows安装ssh服务
734 0