docker-compose快速搭建gitea+drone自动部署-简单快速

docker-compose.yml文件完整内容放在最后,安装docker-compose

docker-compose up -d一键运行即可

Gitea

Gitea 是一个轻量级全功能的 DevSecOps 平台软件。从开发计划到产品成型的整个软件生命周期,他都能够高效而轻松的帮助团队和开发者。

在设置中添加 OAuth2 应用程序

点击应用,往下翻,其中应用名称自定义,http://172.30.12.123:3100/login为drone服务地址,点击创建应用

复制保存客户端ID客户端密钥,配置drone服务时会使用

配置说明 | Gitea Documentationicon-default.png?t=N7T8https://docs.gitea.cn/administration/config-cheat-sheet

提交代码没有drone没有自动部署查看日志发现:

webhook只能调用允许的HTTP服务器(请检查您的webhook.allowed_HOST_LIST设置)

./gitea/gitea/conf/目录下的app.ini文件添加一下内容:

[webhook]
ALLOWED_HOST_LIST = *

出于安全原因,Webhook 仅能调用允许的主机。以逗号分隔的列表

  • loopback:IPv4 的 127.0.0.0/8 和 IPv6 的 ::1/128,包括 localhost。

  • private:RFC 1918(10.0.0.0/8,172.16.0.0/12,192.168.0.0/16)和 RFC 4193(FC00::/7)。也称为 LAN/Intranet。

  • external:一个有效的非私有单播 IP,您可以访问公共互联网上的所有主机。

  • *:允许所有主机。

 #使用OpenSSL生成一个16字节(即128位)的随机十六进制字符串,如:5e606ad37742ffc34e0ee46asd881215
 openssl rand -hex 16
 

Drone

Drone by Harness™ 是一个现代化的持续集成平台,能让繁忙的团队利用强大的云原生管道引擎自动完成构建、测试和发布工作流。

drone文档:

Drone CI / CD | Droneicon-default.png?t=N7T8https://docs.drone.io/

报错:

linter: untrusted repositories cannot mount host volumes

解决:

完整docker-compose.yml文件内容:

记得修改为你适当的内容

version: "3"

services:
  drone:
    image: drone/drone:latest
    restart: always
    container_name: drone
    ports:
      - "3000:80" #端口映射
      #- "443:443"
    environment:
      - DRONE_GITEA_SERVER=http://172.30.12.123:3000 #gitea地址
      - DRONE_GITEA_CLIENT_ID=123123 #客户端ID
      - DRONE_GITEA_CLIENT_SECRET=321321 #客户端密钥
      - DRONE_RPC_SECRET=8899 #密钥,与runner中的相同
      - DRONE_SERVER_HOST=172.30.12.123:3100  #drone服务器地址
      #- DRONE_GIT_ALWAYS_AUTH=true #克隆公共仓库时进行身份验证。只有当你的源代码管理系统启用了私有模式时才需要这样做。
      - DRONE_SERVER_PROTO=http 
      - DRONE_USER_CREATE=username:drone,admin:true     #,token:5e606ad37742ffc34e0ee46b13881215   #为系统提供管理账户
      - DRONE_GIT_USERNAME=username
      - DRONE_GIT_PASSWORD=password #可选字符串值。覆盖用于验证和克隆私有仓库的默认 git 用户名和密码。
      - TZ=Asia/Shanghai
    volumes:
      - ./drone_data:/data
      
  runner:
    image: drone/drone-runner-docker:latest
    container_name: runner
    restart: always
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
    environment:
      - DRONE_RPC_PROTO=http #http 或 https
      - DRONE_RPC_HOST=drone #连接 Drone 服务器的主机名(和可选端口)
      - DRONE_RPC_SECRET=8899 #设置密钥
      - DRONE_RUNNER_CAPACITY=2 #限制运行程序可同时执行的管道数量
      - DRONE_RUNNER_NAME=runner
      - DRONE_TRACE=true #跟踪级别日志记录
      - DRONE_DEBUG=true #启用调试级日志记录
      - TZ=Asia/Shanghai
    ports:
      - "3030:3000"
    depends_on:
      - drone

  gitea:
    image: gitea/gitea:1.21
    container_name: gitea
    environment:
      - USER_UID=1000
      - USER_GID=1000
      - GITEA__database__DB_TYPE=mysql
      - GITEA__database__HOST=db:3306 #使用主机名为db的服务
      - GITEA__database__NAME=gitea
      - GITEA__database__USER=gitea
      - GITEA__database__PASSWD=gitea
    restart: always
    volumes:
      - ./gitea:/data
      - /etc/timezone:/etc/timezone:ro
      - /etc/localtime:/etc/localtime:ro
    ports:
      - "3000:3000"
      #- "222:22"

  db:
    image: mysql:8
    restart: always
    container_name: db-gitea
    environment:
      - MYSQL_ROOT_PASSWORD=gitea #数据库root用户密码
      - MYSQL_USER=gitea #用户名
      - MYSQL_PASSWORD=gitea #用户密码
      - MYSQL_DATABASE=gitea #数据库名
    volumes:
      - ./gitea-db:/var/lib/mysql #
    #未加端口映射,仅作为gitea的数据库


.drone.yml 参考

kind: pipeline
type: docker
name: MyService

steps:
  - name: build
    image: gradle:jdk11
    volumes:
      - name: service-root
        path: /app/build
      - name: gradle-cache
        path: /root/.gradle
    commands:
      - ./gradlew bootJar
      - cp /drone/src/app-api/build/libs/*.jar /app/build/my-service-latest.jar

volumes:
  - name: service-root
    host:
      path: /root/service
  - name: gradle-cache
    host:
      path: /root/.gradle

参考博主:Drone + Gitea + Docker 实现JAVA项目自动化代码提交部署的一次实践案例(适合轻量化小型团队使用)_容器化自动部署 java代码提交git 自动部署-CSDN博客

代码厂库ip+端口访问 Gitea和Drone ,代码提交到gitea 自动构建打包部署

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值