docker 搭建drone + gitee 的CI/CD

docker 搭建drone + gitee 的CI/CD准备创建OAuth应用程序创建一个GiteeOAuth应用程序。ConsumerKey和ConsumerSecret用于授权访问Gitee资源。授权回调URL必须与以下格式和路径匹配,并且必须使用您的确切服务器方案和主机。创建共享密钥创建一个共享密钥来验证跑步者和您的中央无人机服务器之间的通信。您可以使用openssl生成共享密钥:$opensslrand-hex16bea26a2221fd8090ea38720fc445ec.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

准备

创建 OAuth 应用程序

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

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

应用主页填写 http://111.111.121.189:8793

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

docker 搭建drone + gitee 的CI/CD

 

创建共享密钥

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

您可以使用 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.com 服务器地址https://gitee.com

  • DRONE_GITEE_API_SERVER

    可选字符串值提供 Gitee api 服务器地址。默认值为https://gitee.com/api/v5

  • DRONE_RPC_SECRET

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

  • DRONE_SERVER_HOST

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

  • 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 http://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 runner INFO[0000] starting the server INFO[0000] successfully pinged the remote server

开始使用 

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

docker 搭建drone + gitee 的CI/CD

 同步项目 

点击项目进入到 

docker 搭建drone + gitee 的CI/CD

点击setting/Activate Repository 进入 

docker 搭建drone + gitee 的CI/CD

 如上图配置 

点击Save Changes 

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

kind: pipeline
type: docker
name: build

steps:
  - name: build
    image: node:12-alpine
    volumes:
      - name: node-cache
        path: /data
    commands:
      - npm install --registry=https://registry.npm.taobao.org
      - npm run build
      - cp -r ./main_master/ /data
volumes:
  - name: node-cache
    host:
        path: /mnt/nginx/html
trigger:
    branch:
        - master
    event:
        - push

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

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

 drone + docker  部署 express 

.drone.yml 的配置

kind: pipeline
type: docker
name: build

steps:
  - name: docker
    image: docker
    volumes:
      - name: dockersock
        path: /var/run/docker.sock
    commands:
      - docker build -t tangxl/wx .
      - docker stop tangxlwx
      - docker rm tangxlwx
      - docker run -itd -p 8001:8001 --name tangxlwx tangxl/wx
volumes:
  - name: dockersock
    host:
        path: /var/run/docker.sock
trigger:
    branch:
        - master
    event:
        - push

Dockerfile 的配置

FROM node:12-alpine

RUN mkdir -p  /tangxlWx
WORKDIR /tangxlWx
COPY package.json /tangxlWx/package.json
RUN npm i  --registry=https://registry.npm.taobao.org

COPY . /tangxlWx/

ENV DOCKER=true
EXPOSE 8001
CMD npm start

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/170574.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • docker端口映射无法外部访问_docker用户映射

    docker端口映射无法外部访问_docker用户映射端口映射容器中可以运行一些应用,要让外部也可以访问这些应用,可以通过-P或-p参数来指定端口映射。当使用大写的-P标记时,Docker会随机映射一个物理机的49000~49900之间的端口到内部容器开放的网络端口。-p则可以指定想要映射的物理机端口,并且,在一个指定端口上只可以绑定一个容器。1.映射指定的本地IP和端口到容器端口dockerrun-it-p192.168.10.10:8000:80busybox2.映射本地指定IP的任意端口到

    2022年10月18日
  • docker(11)Dockerfile 中的COPY与ADD 命令[通俗易懂]

    docker(11)Dockerfile 中的COPY与ADD 命令[通俗易懂]前言Dockerfile中提供了两个非常相似的命令COPY和ADD,本文尝试解释这两个命令的基本功能,以及其异同点,然后总结其各自适合的应用场景。Build上下文的概念在使用dock

  • docker dockerfile详解_docker exec 进入容器

    docker dockerfile详解_docker exec 进入容器前言Dockerfile是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。Dockerfile简介Dockerfile是用来构建Docker镜像的构建文件,是由一系列

  • docker入门(利用docker部署web应用)[通俗易懂]

    docker入门(利用docker部署web应用)[通俗易懂]前言:本课程是在慕课网上学习第一个docker化的java应用课程时所做的笔记,供本人复习之用目录第一章什么是docker1.1docker的发展史1.2docker国内应用史1.3什么是Docker第二章了解docker2.1docker思想2.1.1集装箱2.1.2标准化2.1.3隔离2.2docker解决的问题2.2.1…

  • docker下载安装教程_mac docker 性能

    docker下载安装教程_mac docker 性能前言Docker提供轻量的虚拟化,你能够从Docker获得一个额外抽象层,你能够在单台机器上运行多个Docker微容器,而每个微容器里都有一个微服务或独立应用,例如你可以将Tomcat运行在一个D

  • docker搭建kafka集群

    docker搭建kafka集群docker搭建kafka集群我在M1mbp上使用的以下镜像新建文件zk-kafka-docker-compose.ymlversion:”2″services:zookeeper:user:rootimage:docker.io/zookeeperports:-“12181:2181″environment:-ALLOW_ANONYMOUS_LOGIN=yesvolumes:-zoo

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号