Docker 配置 Gitea + Drone 搭建 CI/CD 平台

Docker 配置 Gitea + Drone 搭建 CI/CD 平台

配置 Gitea 服务器来管理项目版本

本文的IP地址是为了方便理解随便打的,不要乱点

首先使用 docker 搭建 Gitea 服务器,用于管理代码版本,数据库选择mysql

Gitea 服务器的 docker-compose.yml 配置文件如下:

version: "3"services:server:image: gitea/gitea:1.19.3container_name: giteaenvironment:- USER_UID=1000- USER_GID=1000- GITEA__database__DB_TYPE=mysql- GITEA__database__HOST=123.45.54.123:3306- GITEA__database__NAME=gitea- GITEA__database__USER=root- GITEA__database__PASSWD=123456restart: alwaysvolumes:- ./gitea:/data- /etc/timezone:/etc/timezone:ro- /etc/localtime:/etc/localtime:roports:- "3002:3000"- "2222:22"

运行前先去数据库服务器中新建一个名为 gitea 的数据库

命令:CREATE DATABASE gitea

编写完成后在当前目录下运行 docker compose up -d 即可运行 docker 容器

搭建 Drone 服务器与 Drone Runner

再使用 Docker 搭建 Drone 服务器,用于自动化部署的 CI/CD 平台

浏览器中打开上一步配置好的Gitea,点击右上角头像,点击设置,进入设置页面

点击应用选项卡,在页面底部输入应用名称(随便写一个就好,例如:Drone CI),输入重定向URI(Drone服务链接+’/login‘,如’http://123.45.54.123:3991/login‘)

点击创建应用

客户端ID即为下方配置文件的DRONE_GITEA_CLIENT_ID

客户端密钥即为下方配置文件的DRONE_RPC_SECRET

记录后点击完成即可

接着在服务器中输入

openssl rand -hex 16

生产一个密钥,记录后写到下方配置文件的DRONE_RPC_SECRET中

drone 服务器的 docker-compose.yml 配置文件如下:

version: "3"services:drone:image: drone/drone:2container_name: droneenvironment:- DRONE_GITEA_SERVER=http://123.45.54.123:3002- DRONE_GITEA_CLIENT_ID=客户端ID- DRONE_GITEA_CLIENT_SECRET=客户端密钥- DRONE_RPC_SECRET=生成的密钥- DRONE_SERVER_HOST=123.45.54.123:3991- DRONE_SERVER_PROTO=http- DRONE_USER_CREATE=username:Gitea,admin:true # 开启管理员账户restart: alwaysvolumes:- ./drone:/dataports:- 3991:80- 3992:443

其中 3002 是上一步搭建 Gitea 服务器的端口号,3991 和 3992 是新开的端口号。

编写完成后在当前目录下运行 docker compose up -d 即可运行 docker 容器

Drone Runner 相当于 Worker ,用于执行任务

drone runner的 docker-compose.yml 配置文件如下:

DRONE_RUNNER_NAME是随便起的,3993 同样是新开的端口

version: "3"services:runner:image: drone/drone-runner-docker:1container_name: runnerenvironment:- DRONE_RPC_PROTO=http- DRONE_RPC_HOST=123.45.54.123:3991  # Drone服务器的地址- DRONE_RPC_SECRET=生成的密钥,应与Drone服务器的一致- DRONE_RUNNER_CAPACITY=2- DRONE_RUNNER_NAME=my-first-runnerrestart: alwaysvolumes:- /var/run/docker.sock:/var/run/docker.sockports:- 3993:3000

同样编写完成后在当前目录下运行 docker compose up -d 即可运行 docker 容器

一定一定一定要注意不要乱加 ‘/’ ,不乱写 ‘http://’,不然可能踩坑,按照上方配置文件作为模板改写即可

至此,环境搭建完成,接下来用编写项目进行测试

项目测试

在代码生成器项目根目录下添加以下三个配置文件

.drone.yml

kind: pipeline # 定义对象类型,还有secret和signature两种类型
type: docker # 定义流水线类型,还有kubernetes、exec、ssh等类型
name: test_drone # 定义流水线名称steps: # 定义流水线执行步骤,这些步骤将顺序执行- name: build-jar # 流水线名称image: maven:3.8.5-openjdk-8 # 定义创建容器的Docker镜像volumes: # 将容器内目录挂载到宿主机,仓库需要开启Trusted设置- name: maven-cachepath: /home/Gettler/.m2 # 将maven下载依赖的目录挂载出来,防止重复下载- name: maven-buildpath: /app/build/generator # 将应用打包好的Jar和执行脚本挂载出来commands:- $MAVEN_HOME/bin/mvn -v- $MAVEN_HOME/bin/mvn clean package -DskipTests=true# 将打包后的jar包,拷贝到 /root/testDrone 目录- cp target/*.jar  /app/build/generator- cp Dockerfile /app/build/generator- cp run.sh /app/build/generator- name: build-docker # 流水线名称image: plugins/dockervolumes: # 将容器内目录挂载到宿主机,仓库需要开启Trusted设置- name: maven-buildpath: /app/build/generator # 将应用打包好的Jar和执行脚本挂载出来- name: dockerpath: /var/run/docker.sock # 挂载宿主机的dockersettings:dockerfile: /app/build/generator/Dockerfilecommands:- cd /app/build/generator- chmod +x run.sh- sh run.sh- docker psvolumes: # 定义流水线挂载目录,用于共享数据- name: maven-buildhost:path: /app/build/generator   #jar包目录可以修改从宿主机中挂载的目录- name: maven-cachehost:path: /home/Gettler/docker/maven/cache- name: dockerhost:path: /var/run/docker.sock

Dockerfile

#指定基础镜像(一般指定程序所依赖的环境)
#本例子是构建SpringBoot所以我指定的jdk环境变量
FROM openjdk:8#将./hello-world.jar添加到容器的/opt目录中
COPY ./*.jar /opt#指定dockerfile的命令在哪个目录下执行
WORKDIR /opt#指定容器和外界交互的端口
EXPOSE 80#容器运行后执行的命令(该命令在WORKDIR指定的工作目录下执行)
#注意:多个CMD指令只有最后一个会生效
CMD java -jar *.jar#在构建镜像时执行的命令
#我这边用它来打印java的环境变量
RUN java -version#添加该镜像的元数据
LABEL version="1.0" description="代码生成器服务" by="Gettler"

run.sh

#!/bin/sh
# 定义应用组名
group_name='power'
# 定义应用名称
app_name='generator'
# 定义应用版本
app_version='latest'
echo '----copy jar----'
docker stop ${app_name}
echo '----stop container----'
docker rm ${app_name}
echo '----rm container----'
docker rmi ${group_name}/${app_name}:${app_version}
echo '----rm image----'
# 打包编译docker镜像
docker build -t ${group_name}/${app_name}:${app_version} .
echo '----build image----'
docker run -p 4001:80 --name ${app_name} \
-e TZ="Asia/Shanghai" \
-v /etc/localtime:/etc/localtime \
-d ${group_name}/${app_name}:${app_version}
echo '----start container----'

然后新建gitea仓库,将其push到远程仓库后,然后以Gitea用户(管理员身份)进入Drone服务 http://123.45.54.123:3991/,点击continue即可关联到gitea服务授权登录。

登录后点击右上角SYNC按钮同步仓库,看到刚刚新建的仓库后点进去,激活,然后点击Setting页面,勾选trust

image-20231107102207218

勾选trust后,每次代码push都可以自动进行版本发布

也可以手动发布,点击右上角new build按钮,选择代码分支,即可进行部署。

点击对应build可以查看日志,出现绿色对勾后即为发布成功

image-20231107102348398

再附上一手前端项目配置

Vue 项目配置

.drone.yml

kind: pipeline # 定义一个管道
type: docker # 当前管道的类型
name: test # 当前管道的名称steps: # 定义管道的执行步骤- name: deploy # 步骤名称image: node:18 # 当前步骤使用的镜像,我是node18,也可以修改其他镜像settings:mirror: # Docker镜像加速地址depends_on: [clone] # 依赖的步骤volumes: # 挂载数据卷(此为容器内的目录)- name: node_modules # 数据卷名称path: /drone/src/node_modules # 容器内目录 绝对路径- name: deploy_pathpath: /app/build/frontcommands: # 当前步骤执行的命令- pwd # 查看当前目录- npm config set registry https://registry.npm.taobao.org # 切换淘宝镜像- yarn # 安装node_modules包(我的项目用yarn,看项目也可使用其他命令)- yarn build # 执行编译(我的项目用yarn,看项目也可使用其他命令)- cp -r ./dist/* /app/build/front/html/- cp Dockerfile /app/build/front- cp default.conf /app/build/front- cp run.sh /app/build/front- name: build # 流水线名称image: plugins/dockerdepends_on: [deploy]volumes: # 将容器内目录挂载到宿主机,仓库需要开启Trusted设置- name: deploy_pathpath: /app/build/front # 将应用打包好的Jar和执行脚本挂载出来- name: dockerpath: /var/run/docker.sock # 挂载宿主机的dockersettings:mirror: # Docker镜像加速地址dockerfile: /app/build/front/Dockerfilecommands:- cd /app/build/front- chmod +x run.sh- sh run.sh- docker psvolumes: # 声明数据卷(此为服务器中的实际目录)- name: node_modules # 数据卷名称host:path: /home/Gettler/docker/node_modules- name: deploy_pathhost: path: /app/build/front- name: dockerhost:path: /var/run/docker.sock

记得修改Docker镜像加速地址!

Dockerfile

# 设置基础镜像
FROM nginx:latest# 将dist文件中的内容复制到 /usr/share/nginx/html/ 这个目录下面
COPY html /usr/share/nginx/html
# 用本地的 default.conf 配置来替换nginx镜像里的默认配置
COPY default.conf /etc/nginx/conf.d/default.confEXPOSE 80LABEL version="1.0" description="前端服务" by="Gettler"

run.sh

#!/bin/sh
# 定义应用组名
group_name='power'
# 定义应用名称
app_name='front'
# 定义应用版本
app_version='latest'
docker stop ${app_name}
echo '----stop container----'
docker rm ${app_name}
echo '----rm container----'
docker rmi ${group_name}/${app_name}:${app_version}
echo '----rm image----'
# 打包编译docker镜像
docker build -t ${group_name}/${app_name}:${app_version} .
echo '----build image----'
docker run -p 3995:80 --name ${app_name} \
-e TZ="Asia/Shanghai" \
-v /etc/localtime:/etc/localtime \
-d ${group_name}/${app_name}:${app_version}
echo '----start container----'

img

若要修改 docker-compose.yml 文件,修改后再次输入 docker compose up -d 即可重新加载有变化的容器,过程中会删除之前的容器。而 docker compose up -d --no-create 命令可以在存在yaml文件中描述的容器的情况下启动容器,不会重建容器。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/423383.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

赛氪受邀参加安徽省翻译协会2023年年会

安徽省翻译协会于近日在合肥成功举办2023年年会暨学术研讨会。本次会议旨在服务党和国家工作大局,广泛汇聚翻译界力量,推动翻译行业高质量发展,同时总结一年来我省翻译界成果,谋划明年工作。 安徽省翻译协会2023年年会暨学术研讨会…

MySQL JSON数据类型

在日常开发中,我们经常会在 MySQL 中使用 JSON 字段,比如很多表中都有 extra 字段,用来记录一些特殊字段,通过这种方式不需要更改表结构,使用相对灵活。 目前对于 JSON 字段的实践各个项目不尽相同,MySQL 表…

【Kafka】开发实战和Springboot集成kafka

目录 消息的发送与接收生产者消费者 SpringBoot 集成kafka服务端参数配置 消息的发送与接收 生产者 生产者主要的对象有: KafkaProducer , ProducerRecord 。 其中 KafkaProducer 是用于发送消息的类, ProducerRecord 类用于封装Kafka的消息…

k8s中服务器容器tcp连接数量优化

netty的http1服务器在运行一段时间后会无法提供服务,返回客户端socket hang up 使用apipost测试抓包显示三次握手后被reset 修改net/core/somaxconn 登录容器,cat /proc/sys/net/core/somaxconn显示128,对于一个服务器来说,这个…

深入理解Kubernetes探针和.NET服务健康检查机制

前言 随着越来越多的软件采用云原生和微服务架构,我们面临着更多的技术挑战,比如: Kubernetes如何在容器服务异常终止、死锁等情况下,发现并自动重启服务;当服务依赖的关键服务(例如数据库,Red…

python-大数据分析-基于大数据的QQ音乐数据分析系统设计与实现

设计说明 国内外数字音乐市场经过几百年的发展, 收录的音乐作品总数量已经达到了相当可观的程度, 面对数量如此庞大的音乐作品, 如何更加便捷、高效的让用户听到喜欢的音乐作品, 是音乐平台必须要考虑的事情, 也是科研人员非常感兴趣的研究课题。 本文首先对数据分析中涉及到了…

【心得】java反序列化漏洞利用启蒙个人笔记

目录 前置基础概念 java的反序列化利用概念baby题 例题1 例题2 java反序列化启蒙小结: URLDNS链 一句话总结: 简单分析: 利用点: 示例: 前置基础概念 序列化 类实例->字节流 反序列化 字节流->类实…

一文(10图)了解Cornerstone3D核心概念(万字总结附导图)

Cornerstone3D介绍 Cornerstone3D是一个专门为处理三维医学影像而设计的JavaScript库。 它是Cornerstone项目的一部分,旨在为医学影像社区提供高性能、可扩展且易于使用的开源Web工具,专注于提供交互式的3D医学图像浏览体验,适用于多种医学…

【代码随想录】刷题笔记Day54

前言 差单调栈就结束代码随想录一刷啦,回家二刷打算改用python补充进博客,小涛加油!!! 647. 回文子串 - 力扣(LeetCode) 双指针法 中心点外扩,注意中心点可能有一个元素可能有两个…

VsCode容器开发 - VsCode连接远程服务器上的docker

VsCode容器开发 - VsCode连接远程服务器上的docker 前言 之前在服务器上的Docker内开发,文件编辑起来就很不爽。不如使用VsCode直接打开远程服务器上的Docker,这样就能在VsCode里直接无缝编辑Docker里的文件了。 但是百度和必应得到的中文结果都很奇葩…

excel统计分析——S-N-K法多重比较

参考资料:生物统计学 S-N-K法全称Newman-Keuls或Student-Newman-Keuls法,又称复极差检验法或q检验法。最小显著极差的计算与Tukey法相同,只是将第一自由度换成了秩次距m,即计算临界值时,df1m,df2df&#xf…

数据分析的理念、流程、方法、工具(上)

一、数据的价值 1、数据驱动企业运营 从电商平台的「猜你喜欢」到音乐平台的「心动模式」,大数据已经渗透到了我们生活的每一个场景。不论是互联网行业,还是零售业、制造业等,各行各业都在依托互联网大数据(数据采集、数据存储、…