オンプレ環境

  • CentOS : 7.2.1511
  • Docker : 1.13.1
  • Docker Compose : 1.11.1
  • GitLab : 10.1.1
  • GitLab Runner : 11.1.0
  • 極力 GitLab とバージョンは合わせたほうが良いと思います。

前提条件

  • オンプレ上で GitLab が動いていること
  • 自分の場合、Docker Composeで環境構築してます
  • https://github.com/sameersbn/docker-gitlab
  • GitLab のバージョンは 8.0 以上であること
  • 8.0のメジャーアップデートで GitLab CI が GitLab CE/EE に統合されたため
  • GitLab Runner は Docker で構築します(Shellでも可)

.gitlab_ci.yml

プロジェクト直下に .gitlab_ci.yml を作成する

ex. Node App を Heroku にデプロイするケース

image: node:latest

stages:
  - production

production:
  type: deploy
  stage: production
  image: ruby:latest
  script:
    - apt-get update -qy
    - apt-get install -y ruby-dev
    - gem install dpl
    - dpl --provider=heroku --app=zyyx-slack-bots --api-key=$HEROKU_API_KEY
  only:
    - master

$HEROKU_API_KEY は GitLab に隠蔽します。
Project > Settings > CI/CD > Secret variables

CI___CD_Settings_·CI___CD·00000_zyyxall___zyyx-slack-bots·_GitLab.png

GitLab Runner

Shared Runners と Specific Runners の違い

Shared Runners

  • プロジェクト毎にいちいちRunnerの環境を構築しなくても良くなる
  • Runnerがアイドリング状態で遊び続け、リソースが無駄になることを抑止できる

Specific Runners

  • 自分のプロジェクトのビルドを実行する際に、他のプロジェクトのビルドが完了するまで待たされることが無い
  • Runnerにプロジェクト固有の設定を追加できる
  • 別ユーザーと隔離された環境で自分のプロジェクトのジョブを実行できるのでセキュリティレベルを担保しやすい

https://dev.classmethod.jp/ci/gitlab-runner-ci-cd-1/ より引用

Shared Runners

  1. Admin アカウントで GitLab にログイン
  2. Admin Area (ex. https://my-gitlab.com/admin) にアクセス
  3. 左ナビ Overview > Runners から URLとトークンを取得(以下キャプチャ)
Admin_Area_·_GitLab.png

Specific Runners

  1. 任意プロジェクトの Master 権限以上のアカウントで GitLab にログイン
  2. 任意プロジェクトの 左ナビ Settings > CI/CD > Runners settings から URLとトークンを取得(以下キャプチャ)
CI___CD_Settings_·CI___CD·00000_zyyxall___aws_controller·_GitLab.png

Runner 登録手順

Docker のみでも動かすこと可能ですが GitLab を Docker Compose で動かしているため、GitLab Runner も Docker Compose を使用しました。

YAMLファイルの中身は以下の通りです。

version: '2'

services:
  runner:
    restart: always
    image: gitlab/gitlab-runner:v11.1.0
      # v11.1.0 は、任意のバージョンを指定
      # [Released Tags] https://hub.docker.com/r/gitlab/gitlab-runner/tags/
    volumes:
      - /home/docker/gitlab_ci/runner:/etc/gitlab-runner
      - /var/run/docker.sock:/var/run/docker.sock
      - /etc/ssl/certs:/etc/ssl/certs
        # 最終行は、自己証明書の場合のみ必要
        # ホストの公開鍵を GitLab Runner が動くコンテナにマウント
  1. GitLab Runner 用のディレクトリを作成&移動
    $ mkdir -p /usr/local/docker/gitlab_ci/ && cd /usr/local/docker/gitlab_ci/
  2. YAMLファイルを作成(中身は上記参照)
    $ vi docker-compose.yml
  3. Dockerコンテナの起動&プロセスの確認
    $ docker-compose up -d && docker-compose ps
  4. コンテナに接続
    $ docker exec -it gitlabci_runner_1 bash
  5. GitLab Runner 登録コマンドを実行し、情報を入力して完了
$ gitlab-runner register
Running in system-mode.                            
                                                   
Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com/):
[Shared/Specific Runners の URL]
Please enter the gitlab-ci token for this runner:
[Shared/Specific Runners の トークン]
Please enter the gitlab-ci description for this runner:
[8c8a66fc1750]: [任意]
Please enter the gitlab-ci tags for this runner (comma separated):
[任意]
Registering runner... succeeded                     runner=-w4gGJzV
Please enter the executor: parallels, shell, ssh, virtualbox, docker, docker-ssh, docker+machine, docker-ssh+machine, kubernetes:
[docker]
Please enter the default Docker image (e.g. ruby:2.1):
[任意]
Runner registered successfully. Feel free to start it, but if it's running already the config should be automatically reloaded! 

Docker Compose を使わず、Docker 単体で動かしたい場合
手順1〜3の代わりに、以下のコマンドを実行する

$ docker run -d --name gitlab-runner --restart always \
    -v /srv/gitlab-runner/config:/etc/gitlab-runner \
    -v /var/run/docker.sock:/var/run/docker.sock \
    -v /etc/ssl/certs:/etc/ssl/certs \
    gitlab/gitlab-runner:v11.1.0

登録済みの Runner

Admin アカウントで Admin Area > Overview > Runners (ex. https://my-gitlab.com/admin/runners) から確認可能です。

Admin_Area_·_GitLab.png

GitLab CI/CD

各プロジェクトの CI/CD > Pipeline から実行可能です。

Pipelines_·00000_zyyxall___zyyx-slack-bots·_GitLab.png

参考URL