22.云原生之GitLab CICD实战及解析【干货】

云原生专栏大纲

文章目录

  • 准备工作
  • gitlab-ci.yml流水线
      • mven打包项目
      • 制作并推送镜像
        • kaniko方式
        • docker方式
      • 部署到k8s
      • 验证执行情况
  • GitLab Runner k8s执行器工作流程
  • 注册配置kubernetes runner
    • kubernetes runner配置
      • 通过修改 Pod 规范为每个构建作业创建一个 PVC
      • 自定义卷装载
      • 持久性并发构建卷
      • 为容器设置安全策略
      • 设置拉取策略
      • 配置 Pod DNS 设置
    • kubesphere应用仓库中部署
      • 部署细节
        • 启动命令
        • 环境变量
        • 挂载情况
          • config.toml
          • /configmaps 目录
          • /secrets
      • runner 默认配置问题
      • 最后生成config.toml 配置如下

准备工作

  1. 安装gitlab
  2. 安装配置gitlab-runner,参考本章节 《注册配置kubernetes runner》
  3. 登录gitlab配置需安全保护全局变量,如kube_config、harbor账号密码等。

image.png

gitlab-ci.yml流水线

可参考官网GitLab CI/CD examples | 预定义的 CI/CD 变量参考

CICD流程:

  1. 使用maven打包项目
  2. 制作docker镜像
  3. 推送镜像到harbor仓库
  4. 部署到k8s

mven打包项目

variables:MAVEN_OPTS: >--Dmaven.repo.local=/builds/maven #maven下载文件路径-Dorg.slf4j.simpleLogger.showDateTime=true-Djava.awt.headless=trueMAVEN_CLI_OPTS: >---batch-mode--errors--fail-at-end--show-version--no-transfer-progress-DinstallAtEnd=true-DdeployAtEnd=truepackage:stage: packageimage: maven:3.6.3-jdk-8tags:- k8sscript:- pwd- mvn clean package -Dmaven.test.skip=true# 将打包后target拷贝到指定目录- rm -rf /builds/project-target/devops-web- rm -rf /builds/project-target/devops-service# 将打包后制品拷贝到同一目录进行管理- cp -rf ./devops-web /builds/project-target/devops-web- cp -rf ./devops-service /builds/project-target/devops-service

制作并推送镜像

kaniko方式
build:stage: buildimage:name: registry.cn-hongkong.aliyuncs.com/cmi/kaniko-project_executor:debugentrypoint: [""]tags:- k8sscript:- /kaniko/executor--skip-tls-verify--insecure--context "${CI_PROJECT_DIR}"--dockerfile "/devops-web/Dockerfile"--destination "harbor.yxym.com/library/devops-web:kaniko"except:- tags
docker方式
docker-build:
#  image: docker:latestimage: docker:cliservices:- docker:dindstage: buildscript:- docker login -u admin -p Harbor12345 harbor域名- cd /builds/project-target- docker build -t devops-web:dind -f ./devops-web/Dockerfile  ./devops-web/- docker tag devops-web:dind harbor域名/library/devops-web:dind- docker push harbor域名/library/devops-web:dind

部署到k8s

deploy:image: registry.cn-hangzhou.aliyuncs.com/haoshuwei24/kubectl:1.16.6stage: deploytags:- k8sscript:- mkdir -p /etc/deploy# 该命令配置kube_config,用于获取k8s命令操作权限- echo $kube_config |base64 -d > $KUBECONFIG- kubectl apply -f /builds/project-target/devops-web/deploy.yml

验证执行情况

  1. 登录gitlab查看流水线:
    image.png

  2. 登录harbor查看镜像是否推送到仓库
    image.png

  3. 登录kubesphere查看部署情况
    在这里插入图片描述

GitLab Runner k8s执行器工作流程

image.png
在 GitLab Runner 中使用 Kubernetes (k8s) 执行器时,以下是其工作流程的一般概述:

  1. 配置 Kubernetes 集群:首先,你需要在 GitLab Runner 所在的机器上配置和连接到 Kubernetes 集群。这包括安装和配置 kubectl 命令行工具,并确保 Runner 具有访问 Kubernetes 集群的权限。
  2. 注册 Runner:使用 gitlab-runner register 命令注册一个新的 Runner,选择 kubernetes 作为执行器。在注册过程中,你需要提供 GitLab 实例的 URL、Runner 的描述、Kubernetes 集群的相关配置等信息。
  3. 配置 Runner:完成注册后,GitLab Runner 将生成一个配置文件,其中包含与 Kubernetes 执行器相关的配置信息,例如 Kubernetes API 的地址、访问凭证等。这些配置将被保存在 Runner 的配置目录中。
  4. 运行作业:当有作业需要执行时,GitLab CI/CD 将向 GitLab Runner 发送作业请求。Runner 将根据作业的定义和配置,使用 Kubernetes API 向 Kubernetes 集群提交一个 Pod 规范,描述作业的运行环境和要运行的容器。
  5. 创建 Pod:Kubernetes 集群接收到 Runner 提交的 Pod 规范后,将根据规范创建一个 Pod。Pod 是 Kubernetes 中的最小调度单位,可以包含一个或多个容器。
  6. 容器运行:一旦 Pod 创建成功,Kubernetes 将根据 Pod 规范在集群中选择一个合适的节点,并在该节点上创建和运行容器。容器将根据作业定义的镜像和命令来执行相应的操作,例如构建、测试或部署。
  7. 监听作业状态:GitLab Runner 会定期查询 Kubernetes API 来获取作业的状态信息。这包括容器的运行状态、日志输出等。Runner 将这些信息返回给 GitLab CI/CD,以便实时监控作业的进度和结果。
  8. 提交结果:作业完成后,GitLab Runner 将收集作业的结果,包括日志输出、环境变量等,并将其提交给 GitLab CI/CD。这些结果将在 GitLab CI/CD 界面上显示,并可以用于后续的流程控制和报告生成。
  9. 清理资源:一旦作业完成,Kubernetes 将根据配置自动清理相关的 Pod 和容器。这确保了资源的有效使用和释放。

通过将 GitLab Runner 与 Kubernetes 执行器结合使用,你可以在 Kubernetes 集群中动态地创建和管理容器化的作业环境,实现高度可扩展的持续集成和持续交付流程。

注册配置kubernetes runner

注册器kubernetes 的gitlab runner,使用参考Kubernetes executor官网。Executors | GitLab
执行器 | 极狐GitLab
helm方式部署优势:

  1. 省去了注册kubernetes执行器很多细节,kubernetes执行器是最复杂的一个

helm方式部署缺点:

  1. helm方式部署的github-runner使用了特定的镜像,启动后很多目录用户没有操作权限
  2. 该镜像不能以特权用户启动
  3. 配置挂载路径和gitlab官网使用镜像挂载路径存在区别

kubernetes runner配置

通过修改 Pod 规范为每个构建作业创建一个 PVC

若要为每个生成作业创建 PersistentVolumeClaim,请确保查看如何启用 Pod Spec 功能。

Kubernetes 允许创建一个附加到 Pod 生命周期的临时 PersistentVolumeClaim。 如果在 Kubernetes 集群上启用了动态预配,这将起作用,允许 每个请求一个新的卷,该卷也将与 Pod 的生命周期相关联。PVC

启用动态配置后,可以按如下方式修改:

[[runners.kubernetes.pod_spec]]name = "ephemeral-pvc"patch = '''containers:- name: buildvolumeMounts:- name: buildsmountPath: /builds- name: helpervolumeMounts:- name: buildsmountPath: /buildsvolumes:- name: buildsephemeral:volumeClaimTemplate:spec:storageClassName: <The Storage Class that will dynamically provision a Volume>accessModes: [ ReadWriteOnce ]resources:requests:storage: 1Gi'''

自定义卷装载

要存储作业的 builds 目录,请定义自定义卷挂载到 已配置(默认)。 如果您使用 PVC 卷, 基于接入模式, 您可能被限制为在一个节点上运行作业。builds_dir/builds

concurrent = 4[[runners]]# usual configurationexecutor = "kubernetes"builds_dir = "/builds"[runners.kubernetes][[runners.kubernetes.volumes.empty_dir]]name = "repo"mount_path = "/builds"medium = "Memory"

持久性并发构建卷

默认情况下,Kubernetes CI 作业中的构建目录是临时的。 如果您想在作业中持久化 Git 克隆(以使其正常工作), 您必须为生成文件夹装载持久性卷声明。 由于多个作业可以同时运行,因此您必须 使用一个卷,或为每个电位设置一个卷 同一运行器上的并发作业。后者可能性能更高。

concurrent = 4[[runners]]executor = "kubernetes"builds_dir = "/mnt/builds"[runners.kubernetes][[runners.kubernetes.volumes.pvc]]# CI_CONCURRENT_ID identifies parallel jobs of the same runner.# name是pvc名称如"build-pvc-$CI_CONCURRENT_ID"name = "k8s-running-pod-data"mount_path = "/mnt/builds"

为容器设置安全策略

  • 设置 Pod 安全上下文。
  • 重写以及生成和帮助程序容器。run_as_userrun_as_group
  • 指定所有服务容器都继承 Pod 安全上下文并从 Pod 安全上下文继承。run_as_userrun_as_group
concurrent = 4
check_interval = 30[[runners]]name = "myRunner"url = "gitlab.example.com"executor = "kubernetes"[runners.kubernetes]helper_image = "gitlab-registry.example.com/helper:latest"[runners.kubernetes.pod_security_context]run_as_non_root = truerun_as_user = 59417run_as_group = 59417fs_group = 59417[runners.kubernetes.init_permissions_container_security_context]run_as_user = 1000run_as_group = 1000[runners.kubernetes.build_container_security_context]run_as_user = 65534run_as_group = 65534[runners.kubernetes.build_container_security_context.capabilities]add = ["NET_ADMIN"][runners.kubernetes.helper_container_security_context]run_as_user = 1000run_as_group = 1000[runners.kubernetes.service_container_security_context]run_as_user = 1000run_as_group = 1000
选择类型必填描述
run_as_groupint用于运行容器进程入口点的 GID。
run_as_non_root布尔指示容器必须以非 root 用户身份运行。
run_as_userint用于运行容器进程入口点的 UID。
capabilities.add字符串列表运行容器时要添加的功能。
capabilities.drop字符串列表运行容器时要删除的功能。
selinux_type字符串与容器进程关联的 SELinux 类型标签。

设置拉取策略

使用文件中的参数指定单个或多个拉取策略。 该策略控制如何提取和更新映像,并应用于生成映像、帮助程序映像和任何服务。pull_policyconfig.toml
要确定要使用的策略,请参阅有关拉取策略的 Kubernetes 文档。
对于单个拉取策略:

[runners.kubernetes]pull_policy = "never"

对于多个拉取策略:

[runners.kubernetes]# use multiple pull policiespull_policy = ["always", "if-not-present"]

当您定义多个策略时,将尝试每个策略,直到成功获取映像。 例如,当您使用 时,如果策略由于临时注册表问题而失败,则使用该策略。[ always, if-not-present ]if-not-presentalways
要重试失败的拉取,请执行以下操作:

[runners.kubernetes]pull_policy = ["always", "always"]

GitLab 的命名约定与 Kubernetes 的命名约定不同。

运行器拉取策略Kubernetes 拉取策略描述
空白空白使用 Kubernetes 指定的默认策略。
if-not-presentIfNotPresent仅当执行作业的节点上尚不存在映像时,才会拉取该映像。您应该注意一些安全注意事项
alwaysAlways每次执行作业时都会拉取映像。
neverNever永远不会拉取映像,并且要求节点已经拥有它。

配置 Pod DNS 设置

使用以下选项配置 Pod 的 DNS 设置。

选项类型必须描述
nameserversstring 列表将用作 Pod 的 DNS 服务器的 IP 地址列表
optionsKubernetesDNSConfigOption一个可选的对象列表,其中每个对象可能有一个名称参数(必需)和一个值参数(可选)
searchesstring 列表用于在 Pod 中查找主机名的 DNS 搜索域列表

config.toml 文件中的配置示例:

concurrent = 1
check_interval = 30
[[runners]]name = "myRunner"url = "https://gitlab.example.com"token = "__REDACTED__"executor = "kubernetes"[runners.kubernetes]image = "alpine:latest"[runners.kubernetes.dns_config]nameservers = ["1.2.3.4",]searches = ["ns1.svc.cluster-domain.example","my.dns.search.suffix",][[runners.kubernetes.dns_config.options]]name = "ndots"value = "2"[[runners.kubernetes.dns_config.options]]name = "edns0"

KubernetesDNSConfigOption:

选项类型必须描述
name字符串配置选项名称。
value*string配置选项值。

kubesphere应用仓库中部署

  1. 添加仓库:https://charts.gitlab.io
  2. 修改values.yml
#以下两个在gitlab页面获取
gitlabUrl: http://192.168.31.3:83 # 使用k8s内部gitlab svc地址
runnerRegistrationToken: "GR1348941EfP6qKATzEULxDtvkvAg" #gitlab-runner注册用到的tockenconcurrent: 10 #最大作业并发数
checkInterval: 30 #新作业检查间隔
tags: "k8s" #runner的标签
#rbac权限打开
rbac:create: trueresources: ["pods", "pods/exec", "secrets","configmaps"]verbs: ["get", "list", "watch", "create", "patch", "delete","update"]
runners:# 下述配置config: |
  1. 查看部署情况

在kubesphere应用仓库部署结果如下,部署到了ksnode26节点上:
image.png

  1. 使用特权模式:在创建容器时,使用–privileged参数来启动特权模式。这将使容器拥有更高的权限,并允许执行需要特权的操作。例如,使用docker run --privileged命令来启动容器。
  2. 允许特权提升:如果你不想在整个容器中启用特权模式,可以使用–cap-add参数来允许特定的权限提升。例如,使用docker run --cap-add=SYS_ADMIN命令来允许容器在运行时获取系统管理权限。
  3. 挂载可写目录:如果根目录是只读的,你可以尝试将一个可写的目录挂载到容器中,并在该目录中执行需要写入的操作。使用-v参数来挂载目录,例如,使用docker run -v /path/on/host:/path/in/container命令将主机上的目录挂载到容器中。

部署细节

部署后进入终端发现一些目录无操作权限,这是Docker容器的安全限制导致,可设置容器访问控制
image.png

启动命令
/usr/bin/dumb-init,--,/bin/bash,/configmaps/entrypoint

查看/configmaps:
image.png
这个命令是使用了/usr/bin/dumb-init作为初始进程,然后运行/bin/bash作为子进程,并将/configmaps/entrypoint作为参数传递给/bin/bash。

/usr/bin/dumb-init是一个轻量级的进程初始化器,它可以帮助正确处理子进程的信号和进程间通信。它在容器环境中经常被使用,以确保进程的正确启动和终止。

/bin/bash是一个常见的Unix和Linux系统中的命令解释器。它提供了一个交互式的命令行界面,可以运行命令和脚本,并提供了丰富的功能和工具集。

/configmaps/entrypoint是一个文件路径,它可能是一个配置映射(ConfigMap)中的入口点脚本。ConfigMap是Kubernetes中用于存储配置数据的一种资源类型。入口点脚本通常用于在容器启动时执行一些初始化操作或配置加载。

综合起来,这个命令的作用是使用dumb-init作为初始进程,启动一个bash子进程,并将/configmaps/entrypoint作为参数传递给bash。这可能是在容器环境中运行的一个脚本或配置文件的启动方式。具体的功能和目的需要查看/configmaps/entrypoint文件的内容来确定。

环境变量

image.png

CI_SERVER_URL:http://192.168.31.3:83/
RUNNER_EXECUTOR:kubernetes
REGISTER_LOCKED:true
RUNNER_TAG_LIST:k8s

挂载情况

image.png

config.toml

配置文件使用临时挂载,挂载路径/home/gitlab-runner/.gitlab-runner/config.toml,默认配置如下

concurrent = 10
check_interval = 30
log_level = "info"
shutdown_timeout = 0[session_server]session_timeout = 1800[[runners]]name = "gitlab-k8s-runner-gitlab-runner-6fff86bf78-nbjrn"url = "http://192.168.31.3:83/"id = 7token = "HxBNrMvn89soRxaKiR4v"token_obtained_at = 2024-01-24T09:31:39Ztoken_expires_at = 0001-01-01T00:00:00Zexecutor = "kubernetes"[runners.cache]MaxUploadedArchiveSize = 0[runners.kubernetes]host = ""bearer_token_overwrite_allowed = falseimage = "alpine"namespace = "base"namespace_overwrite_allowed = ""node_selector_overwrite_allowed = ""pod_labels_overwrite_allowed = ""service_account_overwrite_allowed = ""pod_annotations_overwrite_allowed = ""[runners.kubernetes.pod_security_context][runners.kubernetes.init_permissions_container_security_context][runners.kubernetes.build_container_security_context][runners.kubernetes.helper_container_security_context][runners.kubernetes.service_container_security_context][runners.kubernetes.volumes][runners.kubernetes.dns_config]

/entrypoint文件

#!/bin/sh# gitlab-runner data directory
DATA_DIR="/etc/gitlab-runner"
CONFIG_FILE=${CONFIG_FILE:-$DATA_DIR/config.toml}
# custom certificate authority path
CA_CERTIFICATES_PATH=${CA_CERTIFICATES_PATH:-$DATA_DIR/certs/ca.crt}
LOCAL_CA_PATH="/usr/local/share/ca-certificates/ca.crt"update_ca() {echo "Updating CA certificates..."cp "${CA_CERTIFICATES_PATH}" "${LOCAL_CA_PATH}"update-ca-certificates --fresh >/dev/null
}if [ -f "${CA_CERTIFICATES_PATH}" ]; then# update the ca if the custom ca is different than the currentcmp -s "${CA_CERTIFICATES_PATH}" "${LOCAL_CA_PATH}" || update_ca
fi# launch gitlab-runner passing all arguments
exec gitlab-runner "$@"

这个Shell脚本的作用是更新GitLab Runner的CA证书。
首先,它定义了一些变量:

  • DATA_DIR 变量设置为 /etc/gitlab-runner,表示GitLab Runner的数据目录。
  • CONFIG_FILE 变量使用了KaTeX parse error: Expected '}', got 'EOF' at end of input: {CONFIG_FILE:-DATA_DIR/config.toml}的语法,表示如果CONFIG_FILE变量未定义,则使用$DATA_DIR/config.toml作为默认值。
  • CA_CERTIFICATES_PATH 变量使用了KaTeX parse error: Expected '}', got 'EOF' at end of input: …IFICATES_PATH:-DATA_DIR/certs/ca.crt}的语法,表示如果CA_CERTIFICATES_PATH变量未定义,则使用$DATA_DIR/certs/ca.crt作为默认值。
  • LOCAL_CA_PATH 变量设置为 /usr/local/share/ca-certificates/ca.crt,表示本地系统中的CA证书路径。

接下来,脚本定义了一个名为 update_ca 的函数。该函数的作用是更新CA证书。它执行以下操作:

  • 打印消息 “Updating CA certificates…”。
  • 使用 cp 命令将 C A C E R T I F I C A T E S P A T H 的内容复制到 {CA_CERTIFICATES_PATH}的内容复制到 CACERTIFICATESPATH的内容复制到{LOCAL_CA_PATH}。
  • 使用 update-ca-certificates --fresh 命令更新系统的CA证书。

然后,脚本使用条件语句检查${CA_CERTIFICATES_PATH}文件是否存在。如果文件存在,则执行以下操作:

  • 使用 cmp 命令比较 C A C E R T I F I C A T E S P A T H 和 {CA_CERTIFICATES_PATH}和 CACERTIFICATESPATH{LOCAL_CA_PATH}的内容是否相同。如果不相同,则调用 update_ca 函数更新CA证书。

最后,脚本使用 exec 命令运行 gitlab-runner 命令,并将脚本的参数(“$@”)传递给 gitlab-runner 命令。这将启动GitLab Runner并执行相应的操作。

总体而言,这个脚本的目的是确保GitLab Runner的CA证书是最新的,并在启动GitLab Runner之前执行必要的更新操作。

/configmaps 目录

image.png

  • check-live
#!/bin/bash
set -eou pipefailif ! /usr/bin/pgrep -f ".*register-the-runner"  > /dev/null && ! /usr/bin/pgrep -f "gitlab.*runner"  > /dev/null ; thenexit 1
finame=$(awk -F'"' '/^  name = ".*"/ { print $2 }' "${HOME%/root}/.gitlab-runner/config.toml")
url=$(awk -F'"' '/^  url = ".*"/ { print $2 }' "${HOME%/root}/.gitlab-runner/config.toml")gitlab-runner verify -n "$name" -u "$url" 2>&1 | grep -E "is alive|is valid"
  • config.template.toml
[[runners]][runners.kubernetes]namespace = "base"image = "alpine"
  • config.toml
shutdown_timeout = 0
concurrent = 10
check_interval = 30
log_level = "info"
  • entrypoint
#!/bin/bash
set -eexport CONFIG_PATH_FOR_INIT="/home/gitlab-runner/.gitlab-runner/"
mkdir -p ${CONFIG_PATH_FOR_INIT}
cp /configmaps/config.toml ${CONFIG_PATH_FOR_INIT}# Set up environment variables for cache
if [[ -f /secrets/accesskey && -f /secrets/secretkey ]]; thenexport CACHE_S3_ACCESS_KEY=$(cat /secrets/accesskey)export CACHE_S3_SECRET_KEY=$(cat /secrets/secretkey)
fiif [[ -f /secrets/gcs-applicaton-credentials-file ]]; thenexport GOOGLE_APPLICATION_CREDENTIALS="/secrets/gcs-applicaton-credentials-file"
elif [[ -f /secrets/gcs-application-credentials-file ]]; thenexport GOOGLE_APPLICATION_CREDENTIALS="/secrets/gcs-application-credentials-file"
elseif [[ -f /secrets/gcs-access-id && -f /secrets/gcs-private-key ]]; thenexport CACHE_GCS_ACCESS_ID=$(cat /secrets/gcs-access-id)# echo -e used to make private key multiline (in google json auth key private key is oneline with \n)export CACHE_GCS_PRIVATE_KEY=$(echo -e $(cat /secrets/gcs-private-key))fi
fiif [[ -f /secrets/azure-account-name && -f /secrets/azure-account-key ]]; thenexport CACHE_AZURE_ACCOUNT_NAME=$(cat /secrets/azure-account-name)export CACHE_AZURE_ACCOUNT_KEY=$(cat /secrets/azure-account-key)
fiif [[ -f /secrets/runner-registration-token ]]; thenexport REGISTRATION_TOKEN=$(cat /secrets/runner-registration-token)
fiif [[ -f /secrets/runner-token ]]; thenexport CI_SERVER_TOKEN=$(cat /secrets/runner-token)
fi# Register the runner
if ! sh /configmaps/register-the-runner; thenexit 1
fi# Run pre-entrypoint-script
if ! bash /configmaps/pre-entrypoint-script; thenexit 1
fi# Start the runner
exec /entrypoint run \--working-directory=/home/gitlab-runner

这个Shell脚本的作用是配置GitLab Runner的运行环境,并执行GitLab Runner的入口点命令。

首先,set -e 表示在脚本中如果有任何命令执行失败(返回非零退出码),则立即退出脚本。
接下来,脚本导出了一个名为 CONFIG_PATH_FOR_INIT 的环境变量,设置为 /home/gitlab-runner/.gitlab-runner/。然后使用 mkdir -p 命令创建了该路径。

然后,脚本使用 cp 命令将 /configmaps/config.toml 文件复制到 ${CONFIG_PATH_FOR_INIT} 目录中。

接下来,脚本使用条件语句检查一些文件是否存在。如果文件存在,则将其内容读取到相应的环境变量中。具体的环境变量如下:

  • CACHE_S3_ACCESS_KEY 和 CACHE_S3_SECRET_KEY:从 /secrets/accesskey 和 /secrets/secretkey 读取内容。
  • GOOGLE_APPLICATION_CREDENTIALS:从 /secrets/gcs-applicaton-credentials-file 或 /secrets/gcs-application-credentials-file 读取文件路径。
  • CACHE_GCS_ACCESS_ID 和 CACHE_GCS_PRIVATE_KEY:从 /secrets/gcs-access-id 和 /secrets/gcs-private-key 读取内容。
  • CACHE_AZURE_ACCOUNT_NAME 和 CACHE_AZURE_ACCOUNT_KEY:从 /secrets/azure-account-name 和 /secrets/azure-account-key 读取内容。
  • REGISTRATION_TOKEN:从 /secrets/runner-registration-token 读取内容。
  • CI_SERVER_TOKEN:从 /secrets/runner-token 读取内容。

然后,脚本分别执行 /configmaps/register-the-runner 和 /configmaps/pre-entrypoint-script 脚本。如果其中任何一个脚本执行失败(返回非零退出码),则脚本会退出并返回1。

最后,脚本使用 exec 命令执行 /entrypoint run 命令,并传递 --working-directory=/home/gitlab-runner 参数。这将启动GitLab Runner,并设置工作目录为 /home/gitlab-runner。

总体而言,这个脚本的目的是设置GitLab Runner的配置文件和环境变量,然后执行GitLab Runner的入口点命令以启动Runner。

  • pre-entrypoint-script

  • register-the-runner
#!/bin/bash
MAX_REGISTER_ATTEMPTS=30# Reset/unset the not needed flags when an authentication token
RUN_UNTAGGED=""
ACCESS_LEVEL=""for i in $(seq 1 "${MAX_REGISTER_ATTEMPTS}"); doecho "Registration attempt ${i} of ${MAX_REGISTER_ATTEMPTS}"/entrypoint register \${RUN_UNTAGGED} \${ACCESS_LEVEL} \--template-config /configmaps/config.template.toml \--non-interactiveretval=$?if [ ${retval} = 0 ]; thenbreakelif [ ${i} = ${MAX_REGISTER_ATTEMPTS} ]; thenexit 1fisleep 5
doneexit 0

/secrets

runner-token文件内容空
runner-registration-token文件内容:GR1348941EfP6qKATzEULxDtvkvAg

runner 默认配置问题

上述方式部署存在runner pod重启,config.toml配置被重置情况,原因在于下述启动命令中,/configmaps中的脚本。

/usr/bin/dumb-init,--,/bin/bash,/configmaps/entrypoint

/configmaps挂载为了ConfigMap,默认存在如下问题:

  1. 重启runner 后config.toml配置会被重置为初始配置
  2. 重启runner 后构建后的文件丢失
  3. 内网harbor域名解析问题

需修改ConfigMap下config.template.toml配置:
在这里插入图片描述
在这里插入图片描述

[[runners]]builds_dir = "/builds"[runners.kubernetes]namespace = "base"image = "alpine"pull_policy = "if-not-present"      # 拉取镜像策略,本地有是有本地无需拉取[[runners.kubernetes.volumes.pvc]]  # 挂载数据卷持久化name = "k8s-running-pod-data"mount_path = "/builds"[[runners.kubernetes.volumes.host_path]]  # 使用docker命令需要配置引擎name = "docker"mount_path = "/var/run/docker.sock"host_path = "/var/run/docker.sock"[[runners.kubernetes.host_aliases]]  # 用于解析内网中的harbor域名ip = "192.168.31.11"hostnames = ["harbor域名"][[runners.kubernetes.host_aliases]]  # 用于解析k8s集群中Kubernetes API Server 的地址ip = "192.168.31.21"               # k8s集群master iphostnames = ["lb.kubesphere.local"]

最后生成config.toml 配置如下

runner注册配置可直接修改config.toml 配置文件,无需重启即可生效

concurrent = 10
check_interval = 30
log_level = "info"
shutdown_timeout = 0[session_server]session_timeout = 1800[[runners]]name = "k8s-gitlab-runner-gitlab-runner-58cbcc57d5-8kbfz"url = "http://192.168.31.3:83"id = 65token = "Qvdu1hpsUpYNa3dzrjqP"token_obtained_at = 2024-01-29T05:21:04Ztoken_expires_at = 0001-01-01T00:00:00Zexecutor = "kubernetes"builds_dir = "/builds"[runners.cache]MaxUploadedArchiveSize = 0[runners.kubernetes]host = ""bearer_token_overwrite_allowed = falseimage = "alpine"namespace = "base"namespace_overwrite_allowed = ""pull_policy = ["if-not-present"]node_selector_overwrite_allowed = ""pod_labels_overwrite_allowed = ""service_account_overwrite_allowed = ""pod_annotations_overwrite_allowed = ""[runners.kubernetes.pod_security_context][runners.kubernetes.init_permissions_container_security_context][runners.kubernetes.build_container_security_context][runners.kubernetes.helper_container_security_context][runners.kubernetes.service_container_security_context][runners.kubernetes.volumes][[runners.kubernetes.volumes.host_path]]name = "docker"mount_path = "/var/run/docker.sock"host_path = "/var/run/docker.sock"[[runners.kubernetes.volumes.pvc]]name = "k8s-running-pod-data"mount_path = "/builds"[[runners.kubernetes.host_aliases]]ip = "192.168.31.11"hostnames = ["harbor域名"][[runners.kubernetes.host_aliases]]ip = "192.168.31.21"hostnames = ["lb.kubesphere.local"][runners.kubernetes.dns_config]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/439493.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

利用外卖系统源码构建高效的在线订餐平台

在当今数字化时代&#xff0c;外卖服务已成为人们日常生活中不可或缺的一部分。为了满足用户需求&#xff0c;许多创业者和企业都希望搭建自己的在线订餐平台。利用现有的外卖系统源码&#xff0c;可以快速构建一个高效、安全的在线订餐平台。本文将介绍如何利用外卖系统源码来…

方案:将vue项目放在SpringMVC中,并用tomcat访问

需要先将项目生成一次war包才能访问项目的webapp文件夹下的资源&#xff0c;否则tomcat的webapp文件夹下面不会生成对应资源文件夹就无法访问。 问题&#xff1a;目录如下&#xff1a; 今天我测试了一下将vue打包后&#xff0c;放入webapp下面访问&#xff0c;却发现vue项目无…

C# 使用WMI监听进程的启动和关闭

写在前面 Windows Management Instrumentation&#xff08;WMI&#xff09;是用于管理基于 Windows 操作系统的数据和操作的基础结构。具体的API可以查看 WMI编程手册。 WMIC 是WMI的命令行管理工具&#xff0c;使用 WMIC&#xff0c;不但可以管理本地计算机&#xff0c;还可…

Walrus 0.5发布:重构交互流程,打造开箱即用的部署体验

开源应用管理平台 Walrus 0.5 已于近日正式发布&#xff01; Walrus 0.4 引入了全新应用模型&#xff0c;极大程度减少了重复的配置工作&#xff0c;并为研发团队屏蔽了云原生及基础设施的复杂度。Walrus 0.5 在这一基础上&#xff0c;通过重构交互流程、增强抽象能力&#xff…

GPT栏目:yarn 安装

GPT栏目&#xff1a;yarn 安装 一、前言 在跟GPT交互的时候&#xff0c;发现最近gpt4给出的答案率有了比较明显的提高&#xff0c;简单记录一下&#xff0c;我用gpt4拿到的答案吧。 本人已按照这个步骤成功 二、具体步骤 要安装 yarn&#xff0c;你可以按照以下步骤进行操作…

如何从视频中提取高清图片?可以这样截取

如何从视频中提取高清图片&#xff1f;从视频中提取高清图片可以方便我们制作各种用途所需的素材&#xff0c;如海报、社交媒体配图等。此外&#xff0c;高清图片的细节和色彩也更丰富&#xff0c;可以更好地满足我们的视觉需求。从视频中提取高清图片是一项需要技巧的任务&…

百度输入法往选字框里强塞广告

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 国内几乎100%的输入法都有广告&#xff0c;只是你们没发现而已&#xff01;&#xff01;&#xff01; 百度输入法居然在输入法键盘上推送广告&#xff0c;近日&#xff0c;博主阑夕 表示&#xff0c;V2EX论坛上有…

笔记本从零安装ubuntu系统+多种方式远程控制

文章目录 前言ubuntu启动盘Windows远程Ubuntu安装XrdpXrdp卡顿问题解决Xrdp 二次登录会死机的问题Xrdp 卡顿问题 MobaXtermRustDesk 外网远程VNC 远程SSH远程其它设置 总结 前言 我有台老笔记本&#xff0c;上大学第一年的时候买的&#xff0c;现在已经不怎么好用了。打算刷个…

借助gpt生成ppt:文心一言(chatgpt)、chatppt

提供一种简单的基于gpt快速生成ppt的方式。前置条件&#xff1a; 文心一言chatpptwps/office ppt Step1: 下载chatppt插件 https://chat-ppt.com/invitelinke?share_code47949695&channelchat-ppt.com 注册地址 下载完成后&#xff0c;安装即可&#xff0c;安装完成后…

【MySQL】双写、重做日志对宕机时脏页数据落盘的作用的疑问及浅析

众所周知&#xff0c;双写机制、重做日志文件是mysql的InnoDB引擎的几个重要特性之二。其中两者的作用都是什么&#xff0c;很多文章都有分析&#xff0c;如&#xff0c;双写机制&#xff08;Double Write&#xff09;是mysql在crash后恢复的机制&#xff0c;而重做日志文件&am…

如何在centos7上配置为桥接模式

一、打开虚拟机的设置页面&#xff0c;设置虚拟机桥接模式如图&#xff1a;选择桥接模式&#xff08;复制物理网络连接可选&#xff09; 二、net0对应桥接模式的配置&#xff0c;如下方式选择 三、 在 CentOS 7 中&#xff0c;通过编辑网络配置文件来配置网络参数。找到 /etc…

c++入门语法—————引用,内联函数,auto关键字,基于范围的for循环,nullptr

文章目录 一.引用1.引例2.注意事项3.应用场景1.做参数&#xff08;a:输出型参数b:内容较大参数&#xff09;2.做返回值&#xff08;a:修改返回值&#xff0c;b:减少拷贝&#xff09; 4.引用和指针的区别 二.内联函数1.为什么有内联函数2.用法和底层3.特性 三.auto关键字1.基础示…