在AliCloud Serverless Kubernetes集群Gitlab Runner部署笔记

阿里云 Serverless Kubernetes 让您无需管理和维护集群与服务器,即可快速创建 Kuberentes 容器应用,并且根据应用实际使用的 CPU 和内存资源量进行按需付费。使用 Serverless Kubernetes,您可以专注于设计和构建应用程序,而不是管理运行应用程序的基础设施。它基于阿里云弹性计算基础架构,并且完全兼容 Kuberentes API 的解决方案,充分结合了虚拟化资源带来的安全性、弹性和 Kubernetes 生态。

由此定位,这种集群是很适合用来跑CI流程场景的。CI触发时创建对应资源,CI结束后销毁对应的资源。目前Serverless Kubernetes集群尚在公测当中,或多或少有一些不友好的体验,比如:

  • 不支持 RoleRoleBinding
  • 不能自定义CoreDNS/Kube-DNS配置。
  • 不能使用docker-in-docker方式构建镜像。
  • 不支持 PersistentVolumePersistentVolumeClaim

以上提及的四点就是本次部署Runner时需要解决的需求。

不支持 Role,RoleBinding

在触发CI流程时,Runner会在Kubenertes集群中创建对应的Pod进行CI,在不支持自定义 RoleRoleBinding的情况下,也就只有使用阿里云提供的kubeconfig文件了,将对应值粘贴到对应字段创建Secret,这里不再累述。最后Runner会引用到这个Secret

apiVersion: v1
kind: Secret
metadata:
  name: kubernetes-admin-cert
type: kubernetes.io/tls
data:
  ca.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUq......
  tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUR......
  tls.key: LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQp......

不能自定义CoreDNS/Kube-DNS配置

自定义CoreDNS/Kube-DNS配置是为了让集群内部应用不通过公网访问同一VPC下的其他应用直接通过内网即可,比如Gitlab,Harbor等。

解决方式一:

阿里云官方提供的解决方案是使用privateZone。但本文不介绍这种方式,为什么呢?这是一个谜一样的问题,这里不做深入探讨。

解决方式二:

👋注意:该方法Serverless Kubernetes集群尚不支持,未来将会支持,故现在解决此问题只能用方式一。

让Runner所生成的Pod使用HostAliases。但是官方提供的Runner并不支持这个功能,那就直接优化源码吧,优化详情参见此次提交

不能使用docker-in-docker方式构建镜像

解决方式:

使用kaniko进行镜像构建,这里我们将官方镜像中的可执行文件复制到自己的CI镜像中即可使用。

FROM gcr.io/kaniko-project/executor:v0.9.0
FROM registry.cn-hangzhou.aliyuncs.com/choerodon-tools/cibase:0.7.0
COPY --from=0 /kaniko/executor /usr/local/bin/kaniko

这是我build好可直接食用的镜像:

registry.cn-hangzhou.aliyuncs.com/setzero/gitlab-ci-slaver:0.1.0

待友好解决的问题:

  • Harbor界面不显示镜像信息issues,但如果原本就有该镜像的仓库那么是可以正常显示的。疑是Harbor版本太低的问题,目前使用的是v1.4.0。
  • 执行kaniko后会出现Deleting filesystem...操作,导致执行完kaniko后不能再执行其他命令,在CI中可以再分出一个stage来规避这个问题。

不支持 PV 和 PVC

在CI时我们需要缓存一些可复用的文件,或者上一job所产生的文件下个job会用到。

解决方式一:

先部署minio,minio通过nfs volume方式挂载nas,然后在.gitlab-ci.yml文件中使用cacheartifacts关键字。但本文不介绍这种方式,为什么呢?这是一个谜一样的问题,这里不做深入探讨。

相关资料:

解决方式二:

让Runner所生成的Pod使用nfs volume方式挂载nas,但是官方提供的Runner并不支持这个功能,那就直接优化源码吧,优化详情参见此次MR,故将这次CI生成的二进制文件覆盖官方原有的就行。

FROM gitlab/gitlab-runner:alpine-v11.8.0
ADD https://gitlab.com/TimeBye/gitlab-runner/-/jobs/174588999/artifacts/raw/out/binaries/gitlab-runner-linux-amd64 /usr/bin/gitlab-ci-multi-runner
RUN chmod +x /usr/bin/gitlab-ci-multi-runner

这是我build好可直接食用的镜像:

registry.cn-hangzhou.aliyuncs.com/setzero/gitlab-runner:alpine-v11.8.1

后记

优化Runner后的配置示例

concurrent = 3
check_interval = 0
[[runners]]
  name = "runner"
  url = "https://gitlab.com/"
  token = "2b388a2636d35b9d141348e972706b"
  executor = "kubernetes"
  output_limit = 51200
  environment = ["CHART_REPOSITORY=http://chart.com",
                 "SONAR_URL=http://sonarqube.com"]
  [runners.kubernetes]
    host = "https://abcde.serverless-1.kubernetes.cn-shanghai.aliyuncs.com:6443"
    cert_file = "/etc/gitlab-runner/tls.crt"
    key_file = "/etc/gitlab-runner/tls.crt"
    ca_file = "/etc/gitlab-runner/ca.crt"
    namespace = "default"
    pull_policy = "always"
    cpu_limit = "2"
    cpu_request = "2"
    memory_limit = "4Gi"
    memory_request = "4Gi"
    service_cpu_limit = "1"
    service_cpu_request = "1"
    service_memory_limit = "2Gi"
    service_memory_request = "2Gi"
    helper_cpu_limit = "250m"
    helper_cpu_request = "250m"
    helper_memory_limit = "512Mi"
    helper_memory_request  = "512Mi"
    helper_image = "gitlab/gitlab-runner-helper:x86_64-3fff1dcf"
    [runners.kubernetes.pod_annotations]
     # "k8s.aliyun.com/enable-eip" = "true"
    [runners.kubernetes.host_aliases]
      "127.0.0.1" = [ "foo.local", "bar.local" ]
      "127.0.0.2" = [ "oof.local", "rab.local" ]
    [runners.kubernetes.volumes]
      [[runners.kubernetes.volumes.nfs]]
        name = "runner-cache"
        mount_path = "/cache"
        server = "abcde-map64.cn-shanghai.nas.aliyuncs.com"
        nfs_path = "/runner/cache-pv"
      [[runners.kubernetes.volumes.nfs]]
        name = "runner-maven"
        mount_path = "/root/.m2"
        server = "abcde-map64.cn-shanghai.nas.aliyuncs.com"
        nfs_path = "/runner/maven-pv"
      [[runners.kubernetes.volumes.secret]]
        name = "docker-registry-secret"
        mount_path = "/root/.docker"
        read_only = false
        [runners.kubernetes.volumes.secret.items]
          "config.json" = "config.json"
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352