首页 » Web前端 » php空间搭建goagent技巧_docker安装gocdagent

php空间搭建goagent技巧_docker安装gocdagent

访客 2024-11-07 0

扫一扫用手机浏览

文章目录 [+]

FROM gocd/gocd-agent-alpine-3.12:v21.1.0MAINTAINER xxx "xxx@163.com"# 切换到 root 用户USER root# 安装 expect、jdk、dockerRUN 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.0MAINTAINER xxx "xxx@163.com"# 切换到 root 用户USER root# 安装 expect、jdk、dockerRUN 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的时候会报如下的错。

php空间搭建goagent技巧_docker安装gocdagent

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

php空间搭建goagent技巧_docker安装gocdagent
(图片来自网络侵删)

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.0MAINTAINER xxx "xxx@163.com"# 切换到 root 用户USER rootRUN 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、dockerRUN 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 govi 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”。

标签:

相关文章

QQ伪装黑客代码大全技术与风险警示

网络安全问题日益凸显。QQ作为一种流行的社交工具,成为了黑客攻击的主要目标之一。本文将针对QQ伪装黑客代码大全进行深入剖析,揭示其...

Web前端 2025-03-02 阅读1 评论0