Gitlab CI:-如何在不依赖任何系统的Gitlab中创建Shared Runner?

如何解决Gitlab CI:-如何在不依赖任何系统的Gitlab中创建Shared Runner?

我研究了Gitlab Runner这两种类型,一种是Custom Runner,另一种是Shared Runner

我已使用Custom Runner中的docker之类的Gitlab来创建 apk Android。并且它可以正常工作并创建所需的构建。但是通过这种方式,我遇到一个问题,这取决于我的系统,这意味着当我的系统打开时,我的Custom Runner可以正常工作,但是当我的系统关闭时,则Gitlab无法执行操作,因为它取决于我的系统运行程序。

我已经了解了Shared Runner,它不依赖任何内容并执行该操作。我已经阅读了文档,但没有获得正确的实现方法。

请在下面查看我的 .gitlab-ci.yml 文件

image: jangrewe/gitlab-ci-android

stages:
  - build

before_script:
  - export GRADLE_USER_HOME=$(pwd)/.gradle
  - chmod +x ./gradlew

cache:
  key: ${CI_PROJECT_ID}
  paths:
    - .gradle/

build:
  stage: build
  tags:
    - dev-ci
  script:
    - ./gradlew assembleDevelopment assembleProduction assembleStaging
  artifacts:
    paths:
      - app/build/outputs/

请帮助我Shared Runner中的Gitlab

解决方法

注册共享运行程序的步骤:

先决条件:应该已经安装了Gitlab-Runner。遵循本文档的Installing Runner

  • 登录到Gitlab。转到管理区域 >> 概述 >> 赛跑者 >> 手动设置共享的赛跑者

enter image description here

  • 使用root用户或您安装了Runner的用户(例如gitlab-runner)登录到安装了Runner的服务器。在这里,我们使用root用户注册运行程序。运行以下命令:

    gitlab-runner register

  • 根据您的设置填写以下详细信息:

    • 请输入gitlab-ci协调器URL: https://example.com/gitlab/

      (在gitlab中的手动设置共享的运行器下查找网址)

    • 请为此跑步者输入gitlab-ci令牌: jiRS-3KxGaEdkLo6tToZ

      (在gitlab中的手动设置共享的运行器下查找令牌)

    • 请为此跑步者输入gitlab-ci描述: my-first-shred-runner

      (输入跑步者的名字)

    • 请为此跑步者输入gitlab-ci标签(逗号分隔): ci-shared,ci-task

      (输入要与跑步者相关联的任何标签)

    • 请输入执行程序:docker-ssh,并行,virtualbox,docker +计算机,kubernetes,自定义,docker,docker-ssh +计算机,shell,ssh: shell

      (输入您需要跑步者使用的执行人,根据执行人的选择,您将获得其他选择。请查看executors的文件)

现在,您可以看到消息运行者已经注册。

enter image description here

您可以在Gitlab中进行验证。转到Gitlab,管理区域>>概述>>运行程序>>手动设置共享运行程序,您会看到运行程序已注册为名称为 my-first-shred-runner strong>

enter image description here

在Gitlab中为项目启用Shared Runner的步骤:

  1. 转到Gitlab中的项目。
  2. 然后,在项目页面中,设置>> CI / CD >>赛跑者>>共享赛跑者
  3. 然后,单击Enable shared runners。现在,您可以将共享运行程序用于Gitlab CI / CD。
  4. .gitlab-ci.yml中使用与共享运行器关联的标签,以便作业将使用共享运行器运行。

enter image description here

更改.gitlab-ci.yml

中的标签
image: jangrewe/gitlab-ci-android

stages:
  - build

before_script:
  - export GRADLE_USER_HOME=$(pwd)/.gradle
  - chmod +x ./gradlew

cache:
  key: ${CI_PROJECT_ID}
  paths:
    - .gradle/

build:
  stage: build
  tags:
    - ci-shared
  script:
    - ./gradlew assembleDevelopment assembleProduction assembleStaging
  artifacts:
    paths:
      - app/build/outputs/

注册特定跑步者的步骤:

  1. 登录到Gitlab。转到项目,然后设置>> CI / CD >>跑步程序>>手动设置特定的跑步程序
  2. 接下来,按照上述第2步中与注册共享运行程序
  3. 相同的步骤进行操作

enter image description here

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

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res