1.docker命令使用详解-上
2.docker命令使用详解-下
3.docker镜像制作简介
4.基于Dockerfile制作nginx镜像
5.镜像分层构建-上
6.镜像分层构建-下
7.镜像构建总结
1.docker命令使用详解-上
2.docker命令使用详解-下
3.docker镜像制作简介
4.基于Dockerfile制作nginx镜像
创建nginx基础镜像
==================
下载nginx源码包
下载源镜像:
创建目录环境
目录结构按照业务类型或系统类型等方式划分,方便后期镜像比较多的时候进行分类。
创建并配置nginx镜像所需文件
所有nginx镜像服务配置文件都放在统一目录all-in-one
0.Dockerfile 创建镜像制作必要Dockerfile文件
-------------------------------------------------
vim Dockerfile
FROM centos:7.8.2003
maintainer "jackie 985848343qq.com"
RUN yum install epel-release -y && yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop
构建1层nginx镜像
-t 名字加上标签版本
测试结果:
查看镜像执行过程
1.COPY Dockerfile文件添加一行
-------------------------------
copy只能复制到本地目录
vim Dockerfile
FROM centos:7.8.2003
maintainer "jackie 985848343qq.com"
RUN yum install epel-release -y && yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop
COPY nginx-1.18.0.tar.gz /usr/local/src/
构建2层镜像:
测试结果:
进入容器查看是否执行成功
测试:
2. ADD 添加,Dockerfile文件添加一行
-------------------------------------
自动解压tar包到指定目录
vim Dockerfile
FROM centos:7.8.2003
maintainer "jackie 985848343qq.com"
RUN yum install epel-release -y && yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop
ADD nginx-1.18.0.tar.gz /usr/local/src/
构建3层镜像:
测试结果:
测试:
3 RUM 进入解压文件夹后执行编译命令
--------------------------------
FROM centos:7.8.2003
maintainer "jackie 985848343qq.com"
RUN yum install epel-release -y && yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop
ADD nginx-1.18.0.tar.gz /usr/local/src/
RUN cd /usr/local/src/nginx-1.18.0 && ./configure --prefix=/apps/nginx --with-http_sub_module && make && make install
构建4层镜像:
测试结果:
进入容器并映射端口
启动容器中nginx服务
[root@2b360f893e0b /]
测试8080端口:
http://172.31.7.16:8080/
4.再添加一行RUN与两行ADD 修改编译安装nginx的主配置文件中代码存放位置
---------------------------------------------------------------------
vim Dockerfile
FROM centos:7.8.2003
maintainer "jackie 985848343qq.com"
RUN yum install epel-release -y && yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop
ADD nginx-1.18.0.tar.gz /usr/local/src/
RUN cd /usr/local/src/nginx-1.18.0 && ./configure --prefix=/apps/nginx --with-http_sub_module && make && make install
RUN useradd nginx -u 2022
ADD nginx.conf /apps/nginx/conf/nginx.conf
ADD code.tar.gz /data/nginx/html
修改并拷贝容器中的配置文件:/apps/nginx/conf/nginx.conf
user nginx;
location / {
root /data/nginx/html;
index index.html index.htm;
}
创建宿主机存放代码的目录
创建代码页面,并在当前目录给代码打包
移动到all-in-one目录下
构建5层镜像:
测试结果:
查看命令在容器内执行结果
[root@e8b497483ea7 /]
[root@51ab41728ef5 /]
[root@51ab41728ef5 /]
[root@51ab41728ef5 /]
[root@e8b497483ea7 /]
测试访问8080
http://172.31.7.16:8080/
5.CMD 启动容器服务默认命令的使用
-----------------------------------
vim Dockerfile
FROM centos:7.8.2003
maintainer "jackie 985848343qq.com"
RUN yum install epel-release -y && yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop
ADD nginx-1.18.0.tar.gz /usr/local/src/
RUN cd /usr/local/src/nginx-1.18.0 && ./configure --prefix=/apps/nginx --with-http_sub_module && make && make install
RUN useradd nginx -u 2022
ADD nginx.conf /apps/nginx/conf/nginx.conf
ADD code.tar.gz /data/nginx/html
ADD run_nginx.sh /apps/nginx/sbin/run_nginx.sh
EXPOSE 80 443
CMD ["/apps/nginx/sbin/run_nginx.sh"]
再次配置nginx.conf,使其前台执行
daemon off;
设置容器中的nginx服务启动脚本 run_nginx.sh
vim run_nginx.sh
echo "172.31.7.111" > /etc/hosts
/apps/nginx/sbin/nginx
添加执行权限
构建6层镜像
测试结果
测试访问:
http://172.31.7.16:8080/
例:
CMD 启动容器的服务默认的命令启用的另一种实现形式
---------------------------------------------------
vim Dockerfile
FROM centos:7.8.2003
maintainer "jackie 985848343qq.com"
RUN yum install epel-release -y && yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop
ADD nginx-1.18.0.tar.gz /usr/local/src/
RUN cd /usr/local/src/nginx-1.18.0 && ./configure --prefix=/apps/nginx --with-http_sub_module && make && make install
RUN useradd nginx -u 2022
ADD nginx.conf /apps/nginx/conf/nginx.conf
ADD code.tar.gz /data/nginx/html
EXPOSE 80 443
CMD ["/apps/nginx/sbin/nginx","-g","daemon off;"]
镜像文件以layer方式以层的方式存储
查看目录下文件的大小
20K /var/lib/docker/builder
72K /var/lib/docker/buildkit
5.镜像分层构建-上
再centos系统安装基础命令
=======================
1.创建Dockerfile文件
FROM centos:7.8.2003
LABEL maintainer="zhuzikang 985848343@qq.com"
RUN yum install epel-release -y && yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop && groupadd www -g 2022 && useradd www -u 2022 -g www
2.设置脚本后,启动时不在用镜像名字,执行脚本
传递参数变量
Tag=$1
docker build -t harbor.jackie.net/centos:${Tag} .
3.启动脚本
安装tomcat的依赖JDK服务
=======================
上传: jdk-8u281-linux-x64.tar.gz
修改容器内文件: profile
构建:
build-command.sh
Dockerfile
构建Dockerfile
FROM harbor.jackie.net/centos:7.8.2003
LABEL maintainer="zhuzikang 985848343@qq.com"
ADD jdk-8u281-linux-x64.tar.gz /usr/local/src
RUN ln -sv /usr/local/src/jdk1.8.0_281 /usr/local/jdk
ADD profile /etc/profile
ENV name jackie
ENV JAVA_HOME /usr/local/jdk
ENV JRE_HOME $JAVA_HOME/jre
ENV CLASSPATH $JAVA_HOME/lib/:$JRE_HOME/lib/
ENV PATH $PATH:$JAVA_HOME/bin
RUN rm -rf /etc/localtime && ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
构建build-command.sh
docker build -t harbor.jackie.com/centos-jdk-base:8u281 .
启动容器
测试数据
查看环境变量
export JAVA_HOME=/usr/local/jdk
export TOMCAT_HOME=/apps/tomcat
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$TOMCAT_HOME/bin:$PATH
export CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib:$JAVA_HOME/lib/tools.jar
JDK环境的创建结果
$ java -version
普通用户的java环境
完成JDK镜像
创建tomcat基础镜像
====================
配置tomcat启动程序路径
上传: apache-tomcat-9.0.38.tar.gz
构建:
build-command.sh
Dockerfile
构建: Dockerfile
FROM harbor.jackie.com/centos-jdk-base:8u281
LABEL maintainer="zhuzikang 985848343@qq.com"
RUN ln -sv /apps/apache-tomcat-9.0.38 /apps/tomcat
构建:
build-command.sh
docker build -t harbor.jackie.com/centos-tomcat-base:v9.0.39 .
启动tomcat
设置普通用户执行权限
使用普通用户启动tomcat
测试结果:
lrwxrwxrwx 1 root root 26 Apr 16 03:14 tomcat -> /apps/apache-tomcat-9.0.38
6.镜像分层构建-下
创建tomcat app1业务镜像
======================
The first step-创建: myapp
The two step-构建: Dockerfile文件、 build-command.sh
The three step-修改容器内tomcat配置文件: server.xml
The four step-创建启动容器服务脚本: run_tomcat.sh
创建: 代码目录myapp,并打包
<h1> jackie tomcat app1 web1 </h1>
构建: Dockerfile
vim Dockerfile
FROM harbor.jackie.com/centos-tomcat-base:v9.0.39
LABEL maintainer="jackie 985848343@qq.com"
ADD server.xml /apps/tomcat/conf/server.xml
ADD myapp.tar.gz /data/tomcat/webapps
RUN chown www.www /data/ /apps -R
EXPOSE 8080 8843
CMD ["/apps/tomcat/bin/run_tomcat.sh"]
拷贝已经修改过的配置文件到此目录下
修改容器内tomcat配置文件
<Host name="localhost" appBase="/data/tomcat/webapps"
unpackWARs="false" autoDeploy="false">
构建: build-command.sh
docker build -t harbor.jackie.com/tomcat-app1:app1 .
创建启动容器服务脚本:
su - www -c "/apps/tomcat/bin/catalina.sh start"
tail -f /etc/hosts
启动测试:
http://172.31.7.16:8080/myapp/
创建tomcat app2业务镜像
=======================
复制app1的业务镜像内容
修改代码
<h1> jackie tomcat app2 web2 </h1>
给代码打包
修改build_install.sh内容,使其创建的镜像为app2所用
vim build-command.sh
docker build -t harbor.jackie.com/tomcat-app2:app2 .
测试结果
-d 后台执行
--rm 退出容器以后,这个容器就被删除了,方便在临时测试使用
访问:
http://172.31.7.16:8080/myapp/
Haporxy镜像的构建
=================
构建dockerfile文件
构建build_install.sh
构建run_haproxy.sh启动脚本
构建haproxy反向代理文件
构建haproxy镜像
构建dockerfile文件
vim Dockerfile
FROM harbor.jackie.net/centos-base:7.8.2003
LABEL maintainer="jackie 985848343@qq.com"
RUN yum install libtermcap-devel ncurses-devel libevent-devel readline-devel gcc gcc-c++ glibc glibc-devel pcre pcre-devel openssl openssl-devel systemd-devel net-tools vim iotop bc zip unzip zlib-devel lrzsz tree screen lsof tcpdump wget ntpdate -y
ADD run_haproxy.sh /apps/haproxy/bin/run_haproxy.sh
ADD haproxy.cfg /etc/haproxy/haproxy.cfg
EXPOSE 80 9999
CMD ["/apps/haproxy/bin/run_haproxy.sh"]
构建build_install.sh
vim build_install.sh
docker build -t harbor.jackie.com/harproxy:v2.2.11 .
构建run_haproxy.sh启动脚本
vim run_haproxy.sh
/apps/haproxy/sbin/haproxy -f /etc/haproxy/haproxy.cfg
tail -f /etc/hosts
构建haproxy反向代理文件
global
maxconn 100000
chroot /apps/haproxy
stats socket /apps/haproxy/haproxy.sock mode 600 level admin
uid 99
gid 99
daemon
pidfile /apps/haproxy/haproxy.pid
log 127.0.0.1 local3 info
defaults
option http-keep-alive
option forwardfor
maxconn 100000
mode http
timeout connect 300000ms
timeout client 300000ms
timeout server 300000ms
listen stats
mode http
bind 0.0.0.0:9999
stats enable
log global
stats uri /haproxy-status
stats auth haadmin:123456
listen web_port
bind 0.0.0.0:80
mode http
log global
server web1 172.31.7.14:8080 check inter 3000 fall 2 rise 5
server web2 172.31.7.15:8080 check inter 3000 fall 2 rise 5
构建haproxy镜像
测试结果: haproxy是否开启
[root@ee64a17fb0e6 /]
[root@ee64a17fb0e6 /]
LISTEN 0 128 *:9999 *:*
LISTEN 0 128 *:80 *:*
测试结果: haproxy是否生效
http://172.31.7.16:9999/haproxy-status
用户名 haadmin
密码 123456
http://172.31.7.16/myapp/
jackie tomcat app15 web15
jackie tomcat app2 web2
172.31.7.14与172.31.7.15
------------------------
两台机器同时执行
D:\和彩云同步文件夹\Service optimization file\Docker\ubuntu1804\opt\dockerfile\web\tomcat\tomcat\tomcat-app2\harbor.jackie.com-tomcat-app2:app2.tar.gz
测试访问:
http://172.31.7.14:8080/myapp/
http://172.31.7.15:8080/myapp/
172.31.7.15
-------------
修改其代码
<h1> jackie tomcat app15 web15 </h1>
image-20210420152955106
image-20210420160050238
7.镜像构建总结
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具