创建一个 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
必需的字符串值提供您的外部协议方案。该值应设置为http
或https
。如果您配置 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 上安装 Docker 运行器。Docker runner 打包为一个最小的 Docker 镜像,分布在DockerHub上,可用于以下架构:
安装 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小时内删除。
留言与评论(共有 0 条评论) |