【踩坑系列-Docker】基于Alibaba Cloud Linux3基础镜像安装Nginx

发布于:2024-07-31 ⋅ 阅读:(136) ⋅ 点赞:(0)
Author:赵志乾
Date:2024-07-26
Declaration:All Right Reserved!!!

1. 问题描述

        使用Alibaba Cloud Linux3作为基础镜像,在其上安装Nginx,对应的Dockerfile内容如下:

# 指定基础镜像
FROM alibaba-cloud-linux-3-registry.cn-hangzhou.cr.aliyuncs.com/alinux3/alinux3:latest
# 安装nginx软件包
RUN dnf install -y nginx
# 设置nginx为前台运行模式
RUN echo "daemon off;" >> /etc/nginx/nginx.conf
# 暴漏80和8080端口
EXPOSE 80 8080
# 复制自定义的Nginx配置文件
COPY nginx.conf /etc/nginx/nginx.conf
# 启动nginx
CMD nginx

         打包镜像的时候报如下错误:

2. 问题分析

        由错误信息可知,是yum软件包管理器的仓库配置中开启了gpg签名检查,且域名mirrors.cloud.aliyuncs.com无法解析。故可采取如下两种方式进行解决:

        方式1:关闭gpg签名检查;

        方式2:将域名mirrors.cloud.aliyuncs.com换为mirrors.aliyun.com;

3. 解决方案

        yum软件包管理器的仓库配置所在目录为/etc/yum.repos.d,使用sed进行目录下各文件内容替换,修改后的Dockerfile文件内容如下:

        方式1:关闭gpg签名检查

# 指定基础镜像
FROM alibaba-cloud-linux-3-registry.cn-hangzhou.cr.aliyuncs.com/alinux3/alinux3:latest
# 关闭gpg签名检查
RUN sed -i 's/gpgcheck=1/gpgcheck=0/' /etc/yum.repos.d/*.repo
# 安装nginx软件包
RUN dnf install -y nginx
# 设置nginx为前台运行模式
RUN echo "daemon off;" >> /etc/nginx/nginx.conf
# 暴漏80和8080端口
EXPOSE 80 8080
# 复制自定义的Nginx配置文件
COPY nginx.conf /etc/nginx/nginx.conf
# 启动nginx
CMD nginx

        方式2: 更改域名

# 指定基础镜像
FROM alibaba-cloud-linux-3-registry.cn-hangzhou.cr.aliyuncs.com/alinux3/alinux3:latest
# 更换域名
RUN sed -i 's/mirrors.cloud.aliyuncs.com/mirrors.aliyun.com/' /etc/yum.repos.d/*.repo
# 安装nginx软件包
RUN dnf install -y nginx
# 设置nginx为前台运行模式
RUN echo "daemon off;" >> /etc/nginx/nginx.conf
# 暴漏80和8080端口
EXPOSE 80 8080
# 复制自定义的Nginx配置文件
COPY nginx.conf /etc/nginx/nginx.conf
# 启动nginx
CMD nginx