Dockerfile镜像部署

一、环境部署
构建SSH镜像

1、创建镜像目录方便管理

mkdir /opt/sshd
cd /opt/sshd

2、创建编写dockerfile文件

vim Dockerfile

#第一行必须指明基于的基础镜像
FROM centos:7
#作者信息
MAINTAINER this is ssh image <jzm 2022-3-9>
#镜像的操作指令
RUN yum -y update
RUN yum -y install openssh* net-tools lsof telnet passwd #安装一些需要的程序
RUN echo 'abc1234' | passwd --stdin root #修改root登录码
RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config #不使用PAM认证
RUN sed -ri '/^session\s+required\s+pam_loginuid.so/s/^/#/' /etc/pam.d/sshd #取消pam限制
RUN ssh-keygen -t rsa -A  这保存在/etc/ssh/sshd_config 中的hostkey #生成密钥认证文件
RUN mkdir -p /root/.ssh && chown root.root /root && chmod 700 /root/.ssh #
EXPOSE 22 #开启22号端口
CMD ["/usr/sbin/sshd" , "-D"] -D指的是守护进程 #指定默认执行的命令

在这里插入图片描述
在这里插入图片描述
3、生成镜像

docker build -t sshd:centos .

在这里插入图片描述
4、启动容器并修改root登录码

docker run -d -P sshd:centos
docker ps -a
ssh localhost -p 49163

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

构建Systemctl镜像

1、创建镜像目录方便管理

mkdir /opt/systemctl
cd /opt/systemctl

2、创建编写dockerfile文件

vim Dockerfile
 
FROM sshd:centos
MAINTAINER this is systemctl image <jzm 2022-03-09>
ENV container docker
#除了systemd-tmpfiles-setup.service,删除其它所有文件
RUN (cd /lib/systemd/system/sysinit.target.wants/; for i in *; do [ $i == systemd-tmpfiles-setup.service ] || rm -f $i; done); \
rm -f /lib/systemd/system/multi-user.target
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值