容器化-Docker自定义镜像
自定义镜像的核心是 Dockerfile。
Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。
镜像构建需要一个基础镜像,和其他命令一起来完成。
Dockerfile 的指令
FROM :指定基础镜像(FROM是必备的指令,并且必须为第一条指令)。 RUN : 用来执行命令行命令。其基本格式: shell格式: RUN <命令> ,输入在bash环境中的命令即可,一个dockerfile允许使用RUN不得超过127层,所以,使用一次RUN, 使用 ‘ \ ’ 换行,使用‘ && ’执行下一条命令。一般使用此种格式; exec格式: RUN <"可执行文件", "参数1", "参数2">,此种方式像是函数调用中的格式; COPY : 复制文件。 其基本格式: 格式1:COPY <源路径>...<目标路径> 格式2:COPY [“<源路径1>”,....."<目标路径>"] ADD : 更高级的复制文件,在COPY的基础上增加了一些功能,如果复制的是压缩包的话,会直接解压,而不需要在使用RUN解压; CMD :容器启动命令。其基本格式: shell格式: CMD <命令> exec格式: CMD ["可执行文件", "参数1", "参数2"...] 参数列表格式: CMD [“参数1”, “参数2”...],在指定了ENTRYPOINT指令后,用CMD指定具体的参数 ENTRYPOINT : 入口点。其基本格式分为exec和shell, ENTRYPOINT的目的和CMD一样,都是在指定容器启动程序及参数。ENTRYPOINT在运行中可以替代,不过比CMD繁琐,需要通过docker run 的参数--entrypoint 来指定。当指定了ENTRYPOINT后,CMD的含义就发生了改变,不在是直接运行其命令,而是将CMD的内容作为参数传递给ENTRYPOINT指令。其执行时就变成了: <ENTRYPOINT> "<CMD>" ENV : 设置环境变量。(都可以使用这里使用的变量)其基本格式: 格式1:ENV <key> <value> 格式2:ENV <key1>=<value1> <key2>=<value>... ARG : 构建参数。构建参数和ENV的效果一样,都是设置环境变量,所不同的是ARG所构建的环境变量在将来容器运行时是不存在的。其基本格式: 格式1: ARG <参数名> [=<默认值>] 格式2: 该默认值可以在构建命令 docker build 中用 --build-arg <参数名>=<值> 来覆盖 VOLUME : 定义匿名卷。 其基本格式: 格式1: VOLUME ["<路径1>", "<路径2>"...] 格式2: VOLUME <路径> EXPOSE : 暴露端口。EXPOSE指令是声明运行时容器所提供的端口,在启动容器时不会在因为这个声明而开启端口。 其基本格式: 格式1: EXPOSE <端口1> [<端口2>...] WORKDIR : 指定工作目录。其基本格式: 格式1: WORKDIR <工作目录路径> USER : 指定当前用户。USER是帮助你切换到指定用户。 其基本格式: 格式1: USER <用户名> HEALTCHECK : 健康检查,判断容器的状态是否正常。 其基本格式: 格式1: HEALTCHECK [选项] CMD <命令> :设置检查容器健康状况的命令 格式2: HEALTCHECK NONE: 如果基础镜像有健康检查指令,使用此格式可以屏蔽掉其健康检查指令
Dockerfile 的核心指令
FROM 指定基础镜像构建 写法: FROM 指定基础镜像 COPY 复制命令。从上下文目录中复制文件或者目录到容器里指定路径。 写法: COPY 源路径,目标路径 COPY ["源路径","目标路径"] RUN 运行指令。构建的时候运行的指令 主要在于镜像构建的时候运行,运行build命令的时候 后面接的命令就是shell输入的命令 写法 RUN shell命令 参数1 参数2 RUN ["shell命令 ","参数1"," 参数2"] 例如: RUN ["echo",">"," /usr/share/index.html"] CMD 运行指令。运行容器时候运行的指令 主要在于镜像运行容器的时候生成,运行run的时候运行 写法 CMD <shell 命令> CMD ["<可执行文件或命令>","<param1>","<param2>",...] 例如: CMD ["dotnet","rmcore.dll"] 缺点:在run 命令后面可以进行覆盖 docker run -d -P rmcore dotnet rmcore.dll 进行覆盖掉 ENTRYPOINT 运行指令。运行容器时候运行的指令(不会被覆盖) 写法 ENTRYPOINT ["<executeable>","<param1>","<param2>",...] 可以和CMD动态结合,设置动态的配置参数 例如 ENTRYPOINT ["nginx", "-c"] 定参 CMD ["/etc/nginx/nginx.conf"]变参 EXPOSE 暴露端口指令 仅仅声明端口,就是指定镜像暴露的端口 在run 的时候,通过docker run -p 会自动随机映射到EXPOSE端口 写法 EXPOSE 端口 EXPOSE 端口 例如 EXPOSE 5000 EXPOSE 5001 WORKDIR 工作目录指令 用于应用在容器内的工作目录,就好比:ruanmou目录 写法 WORKDIR <工作目录路径> 例如 WORKDIR /rmcore 或者 WORKDIR /nginx
nginx 做成一个镜像
Linux上面:如何运行nginx
1 安装 nginx需要工具 yum -y install gcc make pcre-devel zlib-devel tar zlib 2 下载nginx wget http://nginx.org/download/nginx-1.15.2.tar.gz 3 nginx解压/nginx目录 tar -zxvf nginx-1.15.2.tar.gz 4 切换到/nginx/nginx-1.15.2 执行./configure make make install 进行安装 5 切换到/usr/local/nginx/sbin 执行 ./nginx 启动nginx
docker 中容器运行 nginx 那也是这5个步骤
创建 nginx 文件夹 mkdir nginx
下载 nginx wget http://nginx.org/download/nginx-1.15.2.tar.gz
nginx 中创建 Nginx 脚本文件 nginx.sh touch nginx.sh
#!/bin/sh /usr/local/nginx/sbin/nginx /bin/bash -c 'while true; do sleep 200; done'
创建 Dockerfile 文件 touch Dockerfile
FROM centos RUN yum -y install gcc make pcre-devel zlib-devel tar zlib WORKDIR /nginx COPY nginx-1.15.2.tar.gz /nginx RUN tar -zxvf nginx-1.15.2.tar.gz RUN cd nginx-1.15.2 && ./configure && make && make install EXPOSE 80 COPY nginx.sh /nginx.sh RUN chmod 755 /nginx.sh CMD ["/nginx.sh"]
在 nginx 文件夹下有 Dockerfile 文件的目录,执行构建镜像命令
docker build -t mynginx .
但是报错了
这个错误是在执行 yum install
命令时发生的,具体问题是无法解析主机名 mirrorlist.centos.org
。
针对 CentOS 7 的镜像源问题,最有效的解决方案是替换为阿里云或其他可用的镜像源。以下是修改后的 Dockerfile:
FROM centos:7 # 替换CentOS 7镜像源为阿里云 RUN sed -i 's|^mirrorlist=|#mirrorlist=|g' /etc/yum.repos.d/CentOS-* && \ sed -i 's|^#baseurl=http://mirror.centos.org|baseurl=https://mirrors.aliyun.com|g' /etc/yum.repos.d/CentOS-* && \ # 安装必要的软件包 yum -y install gcc make pcre-devel zlib-devel tar zlib && \ # 清理yum缓存以减小镜像大小 yum clean all && \ rm -rf /var/cache/yum WORKDIR /nginx COPY nginx-1.15.2.tar.gz /nginx RUN tar -zxvf nginx-1.15.2.tar.gz && \ cd nginx-1.15.2 && \ ./configure && \ make && \ make install && \ # 清理编译文件 cd .. && \ rm -rf nginx-1.15.2 nginx-1.15.2.tar.gz EXPOSE 80 COPY nginx.sh /nginx.sh RUN chmod 755 /nginx.sh CMD ["/nginx.sh"]
成功构建镜像
运行 nginx 镜像 docker run -d -P mynginx
进入容器 docker exec -it nginx /bin/bash 退出容器 exit命令
随后在浏览器中访问 32768 端口即可访问。
Docker自定义镜像总结
1、Dockerfile
2、了解Docker 指令
3、配置Dockerfile:使用指令操作 原始Linux运行nginx命令
4、构造自定义镜像
5、运行自定义镜像,得到容器
Docker自定义 .NET 项目镜像
1、安装.NET7 SDK
yum
2、切换到pulish中
cd pulish
3、运行项目
dotnet MyWebApi.dll
FROM mcr.microsoft.com/dotnet/aspnet:7.0 WORKDIR /publish EXPOSE 80 EXPOSE 443 COPY publish/ /publish ENTRYPOINT ["dotnet", "MyWebApi.dll"]
docker build -t mywebapi . docker run -d -P mywebapi
本文来自博客园,作者:龙猫•ᴥ•,转载请注明原文链接:https://www.cnblogs.com/nullcodeworld/p/18964065
【推荐】100%开源!大型工业跨平台软件C++源码提供,建模,组态!
【推荐】2025 HarmonyOS 鸿蒙创新赛正式启动,百万大奖等你挑战
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】开源 Linux 服务器运维管理面板 1Panel V2 版本正式发布
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步