docker 搭建drone + gitee 的CI/CD

阅读: 评论:0

docker 搭建drone + gitee 的CI/CD

docker 搭建drone + gitee 的CI/CD

准备

创建 OAuth 应用程序

创建一个 Gitee OAuth 应用程序。Consumer Key 和 Consumer Secret 用于授权访问 Gitee 资源。 

授权回调 URL 必须与以下格式和路径匹配,并且必须使用您的确切服务器方案和主机。

应用主页填写 111.111.121.189:8793

应用回调地址填写 111.111.121.189:8793/login

 

创建共享密钥

创建一个共享密钥来验证跑步者和您的中央无人机服务器之间的通信。

您可以使用 openssl 生成共享密钥:

$ openssl rand -hex 16
bea26a2221fd8090ea38720fc445eca6

下载

Drone 服务器作为轻量级 Docker 映像分发。镜像是自包含的,没有任何外部依赖。

$ docker pull drone/drone:2

配置

Drone 服务器使用环境变量进行配置。本文引用了配置选项的子集,定义如下。有关配置选项的完整列表,请参阅配置。

  • DRONE_GITEE_CLIENT_ID

    必需的字符串值提供您的 Gitee oauth 客户端 ID。

  • DRONE_GITEE_CLIENT_SECRET

    必需的字符串值提供您的 Gitee oauth 客户端密码。

  • DRONE_GITEE_SERVER

    可选的 url 值提供 Gitee 服务器地址。默认值为 gitee 服务器地址

  • DRONE_GITEE_API_SERVER

    可选字符串值提供 Gitee api 服务器地址。默认值为

  • DRONE_RPC_SECRET

    必需的字符串值提供在上一步中生成的共享密钥。这用于验证服务器和运行器之间的 rpc 连接。必须为服务器和运行器提供相同的秘密值。

  • DRONE_SERVER_HOST

    必需的字符串值提供您的外部主机名或 IP 地址。如果使用 IP 地址,您可以包括端口。例如,drone.domain

  • DRONE_SERVER_PROTO

    必需的字符串值提供您的外部协议方案。该值应设置为httphttps。如果您配置 ssl 或 acme,此字段默认为 https。

启动服务器

可以使用以下命令启动服务器容器。容器是通过环境变量配置的。请记住将下面的占位符值替换为适当的值。

 docker run --volume=/var/lib/drone:/data  --env=DRONE_GITEE_CLIENT_ID=DRONE_GITEE_CLIENT_ID --env=DRONE_GITEE_CLIENT_SECRET=DRONE_GITEE_CLIENT_SECRET --env=DRONE_RPC_SECRET=DRONE_RPC_SECRET  --env=DRONE_USER_CREATE=username:yourUsername,admin:true  --env=DRONE_SERVER_HOST=111.111.121.189:8793 --env=DRONE_SERVER_PROTO=http --publish=8793:80 --publish=443:443 --restart=always --detach=true  --name=drone drone/drone:2

yourUsername 可以通过

curl -i 111.111.121.189:8793/api/user

>-H "Authorization: Bearer 738899333"

相似命令查看  然后替换 yourUsername  其实也是码云的用户名 

安装  docker drone runner 

在 Linux 上安装

本文介绍如何在 Linux 上安装 Docker 运行器。Docker runner 打包为一个最小的 Docker 镜像,分布在DockerHub上,可用于以下架构:

  • amd64
  • 手臂
  • arm64

下载

安装 Docker 并拉取公共镜像:

$ docker pull drone/drone-runner-docker:1

配置

Docker 运行器是使用环境变量配置的。本文引用了以下配置选项。有关配置选项的完整列表,请参阅配置。

  • DRONE_RPC_HOST

    提供 Drone 服务器的主机名(和可选端口)。运行程序连接到主机地址的服务器以接收管道以执行。

  • DRONE_RPC_PROTO

    提供用于连接 Drone 服务器的协议。该值必须是 http 或 https。

  • DRONE_RPC_SECRET

    提供用于向 Drone 服务器进行身份验证的共享密钥。这必须与您的 Drone 服务器配置中定义的密钥匹配。

安装

下面的命令创建一个容器并启动 Docker 运行器。请记住将下面的环境变量替换为您的 Drone 服务器详细信息。

docker run --detach --volume=/var/run/docker.sock:/var/run/docker.sock --env=DRONE_RPC_PROTO=http --env=DRONE_RPC_HOST=111.111.121.189:8793 --env=DRONE_RPC_SECRET=DRONE_RPC_SECRET --env=DRONE_RUNNER_CAPACITY=2  --env=DRONE_RUNNER_NAME=my-first-runner --publish=8793:3000 --restart=always --name=runner drone/drone-runner-docker:1

确认

使用docker logs命令查看日志并验证 runner 是否成功与 Drone 服务器建立连接。

$ docker logs runnerINFO[0000] starting the server
INFO[0000] successfully pinged the remote server

开始使用 

先进到111.111.121.189:8793 /页面 点击按钮 跳转到码云进行授权

 同步项目 

点击项目进入到 

点击setting/Activate Repository 进入 

 如上图配置 

点击Save Changes 

然后在项目根目录添加.l文件配置

kind: pipeline
type: docker
name: buildsteps:- name: buildimage: node:12-alpinevolumes:- name: node-cachepath: /datacommands:- npm install --registry= npm run build- cp -r ./main_master/ /data
volumes:- name: node-cachehost:path: /mnt/nginx/html
trigger:branch:- masterevent:- push

./main_master/ 是打包后的文件夹名称  

/mnt/nginx/html  是需要放到的宿主环境的目录 我这里是nginx的 html文件夹 的宿主环境目录

 drone + docker  部署 express 

.l 的配置

kind: pipeline
type: docker
name: buildsteps:- name: dockerimage: dockervolumes:- name: dockersockpath: /var/run/docker.sockcommands:- docker build -t tangxl/wx .- docker stop tangxlwx- docker rm tangxlwx- docker run -itd -p 8001:8001 --name tangxlwx tangxl/wx
volumes:- name: dockersockhost:path: /var/run/docker.sock
trigger:branch:- masterevent:- push

Dockerfile 的配置

FROM node:12-alpineRUN mkdir -p  /tangxlWx
WORKDIR /tangxlWx
COPY package.json /tangxlWx/package.json
RUN npm i  --registry= . /tangxlWx/ENV DOCKER=true
EXPOSE 8001
CMD npm start

本文发布于:2024-02-01 08:46:04,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170674836635371.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:drone   docker   gitee   CD   CI
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23