容器化-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 文件夹 <font style="color:rgb(51, 51, 51);">mkdir nginx</font>

下载 nginx wget http://nginx.org/download/nginx-1.15.2.tar.gz

nginx 中创建 Nginx 脚本文件 nginx.sh <font style="color:rgb(51, 51, 51);">touch nginx.sh</font>

#!/bin/sh
/usr/local/nginx/sbin/nginx
/bin/bash -c 'while true; do sleep 200; done'

创建 Dockerfile 文件 <font style="color:rgb(51, 51, 51);">touch Dockerfile</font>

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 .

但是报错了

这个错误是在执行 <font style="color:rgba(0, 0, 0, 0.85);">yum install</font> 命令时发生的,具体问题是无法解析主机名 <font style="color:rgba(0, 0, 0, 0.85);">mirrorlist.centos.org</font>

针对 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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值