ssh、nginx、tomcat基于Dockerfile制作镜像

ssh镜像制作

[root@server2 ~]# mkdir ssh
[root@server2 ~]# cd ssh/
生成Dockerfile文件
[root@server2 ssh]# vim Dockerfile
FROM centos:7
MAINTAINER project
RUN yum -y update
RUN yum -y install openssh* net-tools lsof telnet passwd
RUN echo '123456' | passwd --stdin root
RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config
RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key
RUN sed -i '/^session\s\+required\s\+pam_loginuid_so/s/^/#/' /etc/pam.d/sshd
RUN mkdir -p /root/.ssh && chown root.root /root && chmod 700 /root/.ssh
EXPOSE 22
CMD ["/usr/sbin/sshd","-D"]
生产镜像
[root@server2 ssh]# docker build -t ssh:new .
启动容器
[root@server2 ssh]# docker run -d -P ssh:new 
c794d4c09c61d1ad2acfc9735d5586290c6956dbbaf8167593bb289c314083af
[root@server2 ssh]# docker ps -a
CONTAINER ID        IMAGE               COMMAND               CREATED             STATUS              PORTS                                           NAMES
c794d4c09c61        ssh:new             "/usr/sbin/sshd -D"   15 seconds ago      Up 15 seconds       0.0.0.0:32770->22/tcp                           interesting_chatterjee
6f75a06b8cae        nginx:new           "/run.sh"             2 hours ago         Up 2 hours          0.0.0.0:32769->80/tcp, 0.0.0.0:32768->443/tcp   angry_jepsen
b05b3cb6aaf1        nginx:new           "/bin/bash"           3 hours ago         Up 3 hours          80/tcp, 443/tcp                                 zealous_khayyam
链接
[root@server2 ssh]# ssh localhost -p 32770
The authenticity of host '[localhost]:32770 ([::1]:32770)' can't be established.
RSA key fingerprint is SHA256:PVhvBXxrxebIuqRnZGltr/wp48y64LQ+WeE59LLPk5k.
RSA key fingerprint is MD5:45:c2:fa:1d:11:3c:83:90:53:1f:14:cf:04:0e:3e:67.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '[localhost]:32770' (RSA) to the list of known hosts.
root@localhost's password: 
[root@c794d4c09c61 ~]# exit

nginx镜像

创建目录并进入
[root@server2 ~]# mkdir nginx
[root@server2 ~]# cd nginx/
创建Dockerfile文件
[root@server2 nginx]# vim Dockerfile

FROM centos:7
MAINTAINER this is nginx images <chen>
RUN yum -y update
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
ADD nginx-1.12.2.tar.gz /usr/local/src
WORKDIR /usr/local/src
WORKDIR nginx-1.12.2
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
EXPOSE 80
EXPOSE 443
RUN echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]
编写run.sh脚本
[root@server2 nginx]# vim run.sh
#!/bin/bash
/usr/local/nginx/sbin/nginx
将需要的软件包放在同一级目录下
构建镜像
[root@server2 nginx]# docker build -t nginx:new .
运行
[root@server2 nginx]# docker run -d -P nginx:new

在这里插入图片描述

Tomcat

[root@server2 ~]# mkdir tomcat
[root@server2 ~]# cd tomcat/
[root@server2 tomcat]# vim Dockerfile
FROM centos:7
MAINTAINER this is tomcat
ADD jdk-8u91-linux-x64.tar.gz /usr/local
WORKDIR /usr/local
RUN mv jdk1.8.0_91 /usr/local/java
ENV JAVA_HOME /usr/local/java
ENV JAVA_BIN /usr/local/java/bin
ENV JRE_HOME /usr/local/java/jre
ENV PATH $PATH:/usr/local/java/bin:/usr/local/java/jre/bin
ENV CLASSPATH /usr/local/java/jre/bin:/usr/local/java/lib:/usr/local/java/jre/lib/charsets.jar
ADD apache-tomcat-8.5.16.tar.gz /usr/local
WORKDIR /usr/local
RUN mv apache-tomcat-8.5.16 /usr/local/tomcat8
EXPOSE 8080
ENTRYPOINT ["/usr/local/tomcat8/bin/catalina.sh","run"]
[root@server2 tomcat]# docker build -t tomcat:new .
[root@server2 tomcat]# docker run -dit --name tomcat -p 1111:8080 tomcat:new 
c77fc291380c171ed9f2945fbbcda9628f2c8072295432619632bfe36850c188

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值