基于 Docker 安裝 GitLab Runner

基于 Docker 安裝 GitLab Runner

本節(jié)視頻

GitLab Runner 簡(jiǎn)介

理解了上面的基本概念之后夺荒,有沒(méi)有覺(jué)得少了些什么東西 —— 由誰(shuí)來(lái)執(zhí)行這些構(gòu)建任務(wù)呢?

答案就是 GitLab Runner 了!

想問(wèn)為什么不是 GitLab CI 來(lái)運(yùn)行那些構(gòu)建任務(wù)罩抗?

一般來(lái)說(shuō)滩援,構(gòu)建任務(wù)都會(huì)占用很多的系統(tǒng)資源 (譬如編譯代碼)卷要,而 GitLab CI 又是 GitLab 的一部分赂苗,如果由 GitLab CI 來(lái)運(yùn)行構(gòu)建任務(wù)的話盏触,在執(zhí)行構(gòu)建任務(wù)的時(shí)候渗蟹,GitLab 的性能會(huì)大幅下降。

GitLab CI 最大的作用是管理各個(gè)項(xiàng)目的構(gòu)建狀態(tài)赞辩,因此雌芽,運(yùn)行構(gòu)建任務(wù)這種浪費(fèi)資源的事情就交給 GitLab Runner 來(lái)做拉!

因?yàn)?GitLab Runner 可以安裝到不同的機(jī)器上辨嗽,所以在構(gòu)建任務(wù)運(yùn)行期間并不會(huì)影響到 GitLab 的性能

基于 Docker 安裝 GitLab Runner

環(huán)境準(zhǔn)備

  • 創(chuàng)建工作目錄 /usr/local/docker/runner
  • 創(chuàng)建構(gòu)建目錄 /usr/local/docker/runner/environment
  • 下載 jdk-8u152-linux-x64.tar.gz 并復(fù)制到 /usr/local/docker/runner/environment
  • 下載 apache-maven-3.5.3-bin.tar.gz 并復(fù)制到 /usr/local/docker/runner/environment

daemon.json

/usr/local/docker/runner/environment 目錄下創(chuàng)建 daemon.json世落,用于配置加速器和倉(cāng)庫(kù)地址

{
  "registry-mirrors": [
    "https://registry.docker-cn.com"
  ],
  "insecure-registries": [
    "192.168.10.133:5000"
  ]
}

Dockerfile

/usr/local/docker/runner/environment 目錄下創(chuàng)建 Dockerfile

FROM gitlab/gitlab-runner
MAINTAINER Lusifer <topsale@vip.qq.com>

# 修改軟件源
RUN echo 'deb http://mirrors.aliyun.com/ubuntu/ xenial main restricted universe multiverse' > /etc/apt/sources.list && \
    echo 'deb http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted universe multiverse' >> /etc/apt/sources.list && \
    echo 'deb http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted universe multiverse' >> /etc/apt/sources.list && \
    echo 'deb http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse' >> /etc/apt/sources.list && \
    apt-get update -y && \
    apt-get clean

# 安裝 Docker
RUN apt-get -y install apt-transport-https ca-certificates curl software-properties-common && \
    curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | apt-key add - && \
    add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable" && \
    apt-get update -y && \
    apt-get install -y docker-ce
COPY daemon.json /etc/docker/daemon.json

# 安裝 Docker Compose
WORKDIR /usr/local/bin
RUN wget https://raw.githubusercontent.com/topsale/resources/master/docker/docker-compose
RUN chmod +x docker-compose

# 安裝 Java
RUN mkdir -p /usr/local/java
WORKDIR /usr/local/java
COPY jdk-8u152-linux-x64.tar.gz /usr/local/java
RUN tar -zxvf jdk-8u152-linux-x64.tar.gz && \
    rm -fr jdk-8u152-linux-x64.tar.gz

# 安裝 Maven
RUN mkdir -p /usr/local/maven
WORKDIR /usr/local/maven
# RUN wget https://raw.githubusercontent.com/topsale/resources/master/maven/apache-maven-3.5.3-bin.tar.gz
COPY apache-maven-3.5.3-bin.tar.gz /usr/local/maven
RUN tar -zxvf apache-maven-3.5.3-bin.tar.gz && \
    rm -fr apache-maven-3.5.3-bin.tar.gz
# COPY settings.xml /usr/local/maven/apache-maven-3.5.3/conf/settings.xml

# 配置環(huán)境變量
ENV JAVA_HOME /usr/local/java/jdk1.8.0_152
ENV MAVEN_HOME /usr/local/maven/apache-maven-3.5.3
ENV PATH $PATH:$JAVA_HOME/bin:$MAVEN_HOME/bin

WORKDIR /

docker-compose.yml

/usr/local/docker/runner 目錄下創(chuàng)建 docker-compose.yml

version: '3.1'
services:
  gitlab-runner:
    build: environment
    restart: always
    container_name: gitlab-runner
    privileged: true
    volumes:
      - ./config:/etc/gitlab-runner
      - /var/run/docker.sock:/var/run/docker.sock

注冊(cè) Runner

docker exec -it gitlab-runner gitlab-runner register

# 輸入 GitLab 地址
Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com/):
http://192.168.10.132/

# 輸入 GitLab Token
Please enter the gitlab-ci token for this runner:
1Lxq_f1NRfCfeNbE5WRh

# 輸入 Runner 的說(shuō)明
Please enter the gitlab-ci description for this runner:
可以為空

# 設(shè)置 Tag,可以用于指定在構(gòu)建規(guī)定的 tag 時(shí)觸發(fā) ci
Please enter the gitlab-ci tags for this runner (comma separated):
deploy

# 這里選擇 true 糟需,可以用于代碼上傳后直接執(zhí)行
Whether to run untagged builds [true/false]:
true

# 這里選擇 false屉佳,可以直接回車,默認(rèn)為 false
Whether to lock Runner to current project [true/false]:
false

# 選擇 runner 執(zhí)行器洲押,這里我們選擇的是 shell
Please enter the executor: virtualbox, docker+machine, parallels, shell, ssh, docker-ssh+machine, kubernetes, docker, docker-ssh:
shell

使用 Runner

GitLab CI 地址與令牌參數(shù)

項(xiàng)目 –> 設(shè)置 –> CI/CD –> Runner 設(shè)置

.gitlab-ci.yml

在項(xiàng)目工程下編寫 .gitlab-ci.yml 配置文件:

stages:
  - install_deps
  - test
  - build
  - deploy_test
  - deploy_production

cache:
  key: ${CI_BUILD_REF_NAME}
  paths:
    - node_modules/
    - dist/

# 安裝依賴
install_deps:
  stage: install_deps
  only:
    - develop
    - master
  script:
    - npm install

# 運(yùn)行測(cè)試用例
test:
  stage: test
  only:
    - develop
    - master
  script:
    - npm run test

# 編譯
build:
  stage: build
  only:
    - develop
    - master
  script:
    - npm run clean
    - npm run build:client
    - npm run build:server

# 部署測(cè)試服務(wù)器
deploy_test:
  stage: deploy_test
  only:
    - develop
  script:
    - pm2 delete app || true
    - pm2 start app.js --name app

# 部署生產(chǎn)服務(wù)器
deploy_production:
  stage: deploy_production
  only:
    - master
  script:
    - bash scripts/deploy/deploy.sh

上面的配置把一次 Pipeline 分成五個(gè)階段:

  • 安裝依賴(install_deps)
  • 運(yùn)行測(cè)試(test)
  • 編譯(build)
  • 部署測(cè)試服務(wù)器(deploy_test)
  • 部署生產(chǎn)服務(wù)器(deploy_production)

注意: 設(shè)置 Job.only 后武花,只有當(dāng) develop 分支和 master 分支有提交的時(shí)候才會(huì)觸發(fā)相關(guān)的 Jobs。

節(jié)點(diǎn)說(shuō)明:

  • stages:定義構(gòu)建階段杈帐,這里只有一個(gè)階段 deploy
  • deploy:構(gòu)建階段 deploy 的詳細(xì)配置也就是任務(wù)配置
  • script:需要執(zhí)行的 shell 腳本
  • only:這里的 master 指在提交到 master 時(shí)執(zhí)行
  • tags:與注冊(cè) runner 時(shí)的 tag 匹配

測(cè)試集成效果

所有操作完成后 push 代碼到服務(wù)器体箕,查看是否成功:

passed 表示執(zhí)行成功

其它命令

  • 刪除注冊(cè)信息
gitlab-ci-multi-runner unregister --name "名稱"
  • 查看注冊(cè)列表
gitlab-ci-multi-runner list

附:項(xiàng)目配置 Dockerfile 案例

FROM openjdk:8-jre

MAINTAINER Lusifer <topsale@vip.qq.com>

ENV APP_VERSION 1.0.0-SNAPSHOT
ENV DOCKERIZE_VERSION v0.6.1
RUN wget https://github.com/jwilder/dockerize/releases/download/$DOCKERIZE_VERSION/dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz \
    && tar -C /usr/local/bin -xzvf dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz \
    && rm dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz

RUN mkdir /app

COPY myshop-service-user-provider-$APP_VERSION.jar /app/app.jar
ENTRYPOINT ["dockerize", "-timeout", "5m", "-wait", "tcp://192.168.10.131:3306", "java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "/app/app.jar"]

EXPOSE 8501
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市挑童,隨后出現(xiàn)的幾起案子累铅,更是在濱河造成了極大的恐慌,老刑警劉巖站叼,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件娃兽,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡尽楔,警方通過(guò)查閱死者的電腦和手機(jī)投储,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)翔试,“玉大人轻要,你說(shuō)我怎么就攤上這事复旬】衙澹” “怎么了?”我有些...
    開封第一講書人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵驹碍,是天一觀的道長(zhǎng)壁涎。 經(jīng)常有香客問(wèn)我凡恍,道長(zhǎng),這世上最難降的妖魔是什么怔球? 我笑而不...
    開封第一講書人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上倒堕,老公的妹妹穿的比我還像新娘框冀。我一直安慰自己,他們只是感情好担汤,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開白布涎跨。 她就那樣靜靜地躺著,像睡著了一般崭歧。 火紅的嫁衣襯著肌膚如雪隅很。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,262評(píng)論 1 308
  • 那天率碾,我揣著相機(jī)與錄音叔营,去河邊找鬼。 笑死所宰,一個(gè)胖子當(dāng)著我的面吹牛绒尊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播仔粥,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼垒酬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了件炉?” 一聲冷哼從身側(cè)響起勘究,我...
    開封第一講書人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎斟冕,沒(méi)想到半個(gè)月后口糕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡磕蛇,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年景描,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秀撇。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡超棺,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出呵燕,到底是詐尸還是另有隱情棠绘,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站氧苍,受9級(jí)特大地震影響夜矗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜让虐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一紊撕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧赡突,春花似錦对扶、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至从媚,卻和暖如春逞泄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背拜效。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工喷众, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人紧憾。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓到千,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親赴穗。 傳聞我的和親對(duì)象是個(gè)殘疾皇子憔四,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359