jenkins打包镜像时遇到Failed to execute goal io.fabric8:docker-maven-plugin returned a non-zero code:

测试环境 jenkins 打包,推送docker 镜像到harbor 总是卡在 打包镜像的步骤
Failed to execute goal io.fabric8:docker-maven-plugin:0.37.0:build (build-image) on project thinglinks-auth: Unable to build image [192.168.1.100:5000/dispatcher/xxx1.0.0.RELEASE] : “The command ‘/bin/sh -c mkdir -p /opt/app && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo “Asia/Shanghai” > /etc/timezone && apt-get update && apt-get install -y curl wget vim redis iproute2 iputils-ping net-tools && rm -rf /var/lib/apt/lists/*’ returned a non-zero code: 100”

项目的pom 插件配置

   <plugin>
                <groupId>io.fabric8</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>0.37.0</version>
                <configuration>
                    <!-- Docker 远程管理地址-->
                    <dockerHost>http://192.168.1.100:2375</dockerHost>
                    <!-- Docker 推送镜像仓库harbor地址-->
                    <pushRegistry>http://192.168.1.100:5000</pushRegistry>

                    <authConfig>
                        <username>xxx</username>
                        <password>yyyy</password>
                    </authConfig>

                    <images>
                        <image>
                            <!--由于推送到私有镜像仓库,镜像名需要添加仓库地址-->
                            <name>192.168.1.100:5000/dispatcher/${project.artifactId}:${project.version}</name>
                            <!--定义镜像构建行为-->
                            <build>
                                <dockerFileDir>${project.basedir}</dockerFileDir>
                            </build>
                        </image>
                    </images>
                </configuration>

                <executions>
                    <execution>
                        <id>build-image</id>
                        <phase>install</phase>
                        <goals>
                            <goal>build</goal>
                            <goal>push</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

想到可能是 jenkins 在打包镜像时,软件源的问题。由于我的 jenkins 也是docker 部署的,脑子糊涂了,以为是 要讲 jenkins 容器本身的 debian源替换掉, 由于 jenkins 是 2.514 版本 ,所以 debain 是 12.11 所以 ,要 用 docker 映射挂载 /etc/apt/sources.list.d/debain.sources文件,替换成aliyun ,文件如下

Types: deb
# http://snapshot.debian.org/archive/debian/20230919T000000Z
URIs: http://mirrors.aliyun.com/debian
Suites: bookworm bookworm-updates
Components: main
Signed-By: /usr/share/keyrings/debian-archive-keyring.gpg

Types: deb
# http://snapshot.debian.org/archive/debian-security/20230919T000000Z
URIs: http://mirrors.aliyun.com/debian-security
Suites: bookworm-security
Components: main
Signed-By: /usr/share/keyrings/debian-archive-keyring.gpg

重新启动jenkins

  docker run --name jenkins -u root -d -p 12300:8080 -p 50000:50000  -e JAVA_OPTS="-Duser.timezone=Asia/Shanghai"   -v /etc/localtime:/etc/localtime  -v /opt/jenkins:/var/jenkins_home   -v /usr/bin/docker:/usr/bin/docker -v /opt/jdk:/opt/jdk -v /opt/maven/maven-mvnd-1.0.2-linux-amd64/mvn/:/opt/maven/apache-maven-3.8.8 -v /opt/maven/repository:/opt/maven/repository  -v /var/run/docker.sock:/var/run/docker.sock  -v /opt/conf/debian.sources:/etc/apt/sources.list.d/debian.sources  jenkins/jenkins:2.514

重新编译 仍然卡住,后来在jenksins 容器里,手动 docker build 某个 Dockerfile 文件,才发现如下错误

E: Failed to fetch http://mirrors.ustc.edu.cn/debian-security/pool/updates/main/v/vim/vim-common_8.2.2434-3%2bdeb11u3_all.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian/pool/main/libp/libpsl/libpsl5_0.21.0-1.2_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian-security/pool/updates/main/w/wget/wget_1.21-1%2bdeb11u2_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian/pool/main/b/brotli/libbrotli1_1.0.9-2%2bb2_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian-security/pool/updates/main/c/cyrus-sasl2/libsasl2-modules-db_2.1.27%2bdfsg-2.1%2bdeb11u1_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian-security/pool/updates/main/c/cyrus-sasl2/libsasl2-2_2.1.27%2bdfsg-2.1%2bdeb11u1_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian-security/pool/updates/main/o/openldap/libldap-2.4-2_2.4.57%2bdfsg-3%2bdeb11u1_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian-security/pool/updates/main/n/nghttp2/libnghttp2-14_1.43.0-1%2bdeb11u2_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian/pool/main/r/rtmpdump/librtmp1_2.4%2b20151223.gitfa8646d.1-2%2bb2_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian/pool/main/libs/libssh2/libssh2-1_1.9.0-2%2bdeb11u1_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian-security/pool/updates/main/c/curl/libcurl4_7.74.0-1.3%2bdeb11u15_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:
E: Failed to fetch http://mirrors.ustc.edu.cn/debian-security/pool/updates/main/c/curl/curl_7.74.0-1.3%2bdeb11u15_amd64.deb  Unable to connect to mirrors.ustc.edu.cn:80:

原来是Dockerfile 文件里换源的 语句,使用的中科大的源,尝试使用aliyun的源 ,顺利解决

FROM openjdk:8-jre

RUN sed -i 's/deb.debian.org/mirrors.aliyun.com/g' /etc/apt/sources.list
RUN sed -i 's/security.debian.org/mirrors.aliyun.com/g' /etc/apt/sources.list

# 原来使用的是ustc
#RUN sed -i 's/deb.debian.org/mirrors.ustc.edu.cn/g' /etc/apt/sources.list
#RUN sed -i 's/security.debian.org/mirrors.ustc.edu.cn/g' /etc/apt/sources.list

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值