docker安装定制gocd-agent

文章讲述了如何在Docker容器中定制Gocd-Agent,解决在Alpine3.12版本中安装openjdk17的问题,通过更新Alpine仓库并使用--allow-untrusted选项安装所需的软件包。
摘要由CSDN通过智能技术生成

一、定制gocd-agent

FROM gocd/gocd-agent-alpine-3.12:v21.1.0
MAINTAINER xxx "xxx@163.com"
# 切换到 root 用户
USER root
# 安装 expect、jdk、docker
RUN apk update && apk add expect && apk add openjdk8 && apk add docker && apk add openrc && apk add maven && apk add make
# 将 entrypoint.sh 复制到容器中
COPY entrypoint.sh .
# 给脚本添加执行权限
RUN chmod +x entrypoint.sh
# 容器启动时执行脚本
ENTRYPOINT ["/entrypoint.sh"]
# 切换到 go 用户
USER go
FROM gocd/gocd-agent-alpine-3.12:v21.1.0
MAINTAINER xxx "xxx@163.com"
# 切换到 root 用户
USER root
# 安装 expect、jdk、docker
RUN apk update && apk add expect && apk add openjdk17 && apk add docker && apk add openrc && apk add maven && apk add make
# 将 entrypoint.sh 复制到容器中
COPY entrypoint.sh .
# 给脚本添加执行权限
RUN chmod +x entrypoint.sh
# 容器启动时执行脚本
ENTRYPOINT ["/entrypoint.sh"]
# 切换到 go 用户
USER go

很多人会想为什么要把openjdk8、maven、make等命令打包到docker容器里面,因为docker容器里面是不带这些命令的,但是我们在打包部署的时候需要用到这些命令。所以需要把这些命令一起打成镜像,一起部署。

上面打了两个镜像一个是openjdk8,一个是openjdk17的,但是在打openjdk17的时候会报如下的错。

首先在docker里面使用apk add openjdk17来安装,使用的是apk包管理器,在alpine:v3.12的版本里面是没有openjdk17的,如果你安装openjdk8是没有问题的,安装openjdk17所以才会报上面那个错误。那怎么办呢?

http://dl-cdn.alpinelinux.org/alpine/v3.12/main/x86_64/APKINDEX.tar.gz

http://dl-cdn.alpinelinux.org/alpine/v3.12/community/x86_64/APKINDEx.tar.gz

这个时候需要换alpine的版本了,在agent.dockerfile文件里面添加

RUN echo "http://dl-cdn.alpinelinux.org/alpine/v3.16/main/" > /etc/apk/repositories && echo "http://dl-cdn.alpinelinux.org/alpine/v3.16/community/" >> /etc/apk/repositories

然后再每个apk的后面加上--allow-untrusted。

最终的脚本就是这样的。

FROM gocd/gocd-agent-alpine-3.12:v21.1.0
MAINTAINER xxx "xxx@163.com"
# 切换到 root 用户
USER root
RUN echo "http://dl-cdn.alpinelinux.org/alpine/v3.16/main/" > /etc/apk/repositories && echo "http://dl-cdn.alpinelinux.org/alpine/v3.16/community/" >> /etc/apk/repositories
# 安装 expect、jdk、docker
RUN apk update --allow-untrusted && apk add expect --allow-untrusted && apk add openjdk17-jdk --allow-untrusted && apk add docker --allow-untrusted && apk add openrc --allow-untrusted && apk add maven --allow-untrusted && apk add make --allow-untrusted 
# 将 entrypoint.sh 复制到容器中
COPY entrypoint.sh .
# 给脚本添加执行权限
RUN chmod +x entrypoint.sh
# 容器启动时执行脚本
ENTRYPOINT ["/entrypoint.sh"]
# 切换到 go 用户
USER go

vi entrypoint.sh

#!/bin/bash

# 将 docker.sock 授权给 go 用户,否则 docker 命令无法正常工作
chown go /var/run/docker.sock
# 启动 gocd-agent 程序
bash /docker-entrypoint.sh

构建新的gocd-agent

docker build -f agent.dockerfile -t gocd-agent-xxx .
docker pull xxx/gocd-agent-xxx

一、安装gocd-agent

docker run --name gocd-agent -d -e GO_SERVER_URL=http://ip:port/go xxx/gocd-agent-xxx:latest

二、安装完之后,可以启动gocd-server。

http://ip:port/

然后开始点击“Pipeline”。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值