Distribution チームインフラとメンテナンス - dev.gitlab.org

手動パッケージのアップグレード/ダウングレードや GitLab 設定変更を含む dev.gitlab.org のメンテナンスガイドライン。

共通リンク

dev.gitlab.org

これは GitLab CE を実行している内部 GitLab インスタンスです。このサーバーの omnibus-gitlab パッケージは、動作を維持するために必要な設定が施された標準パッケージです。このノードでは通常の omnibus-gitlab コマンドを使用できます。

自動タスク

  1. ナイトリービルド: 毎日 UTC 1:30 に、dev.gitlab.org でナイトリービルドがトリガーされます。cron トリガー時刻は現在 dev.gitlab.org のスケジュールされたパイプラインページ で定義されています。

  2. デプロイ: 毎日 UTC 7:20 に、ナイトリー CE パッケージが dev.gitlab.org に自動的にデプロイされます。インストールプロセスでエラーが発生した場合は Sentry に記録されます。Slack 通知は #dev-gitlab に表示されます。cron タスクは現在 ロールファイル で定義されています。

メンテナンスタスク

このサーバーの GitLab インスタンスを運用可能な状態に維持することは Distribution チームの責任です。

要件:

パッケージの手動アップグレード/ダウングレード

最新デプロイに問題がある場合、修正が準備できるまでインストールを以前のナイトリーバージョンに戻し、デプロイをロックする必要があるかもしれません。これは dev.gitlab.org を利用する他のユーザーのために安定性を確保するために行います。

  1. 最初に、ダウングレードするインストールバージョンと関連 Issue へのリンクを詳述した Issue を team-tasks [issue-tracker] に作成します。Issue を自分自身にアサインします。

  2. 次に、パッケージをダウングレードする前に #announcements Slack チャンネルでアナウンスします:

    I will be manually downgrading package on dev.gitlab.org to <version> as latest nightly is not working as expected. <link to issue>
    
  3. アップグレード中にデータが変更されないよう、sidekiq と unicorn を停止します。

    sudo gitlab-ctl stop sidekiq
    sudo gitlab-ctl stop unicorn
    
  4. 以前の動作バージョンのパッケージを見つけてそのバージョンにダウングレードします:

    sudo apt-get install gitlab-ce=<version to be installed>
    

    例えば、バージョンが 10.4.0+rnightly.75436.44501791-0 の場合、以下を実行します:

    sudo apt-get install gitlab-ce=10.4.0+rnightly.75436.44501791-0
    

    これにより reconfigure が自動的に実行され、必要な変更が適用されます。

  5. reconfigure が完了したら、すべてのサービスが稼働していることを確認します。

    sudo gitlab-ctl status
    
  6. https://dev.gitlab.org/help にアクセスして、正しいバージョンがデプロイされていることを確認します。

  7. 自動アップグレードを防ぐためにパッケージをホールドします:

    sudo apt-mark hold gitlab-ce
    

    ホールドが設定されていることを確認します。

    sudo apt-mark showhold
    
  8. #announcements チャンネルに戻り、ダウングレードが完了したことをメッセージで伝えます:

    Downgrade completed. The package has also been put on hold to prevent automatic upgrades. <link to issue>
    

Issue が解決したら、パッケージのホールドを解除して最新バージョンにアップグレードしてください。

  1. まず #announcements チャンネルでアナウンスします

    I will be removing the package hold and manually upgrading package on dev.gitlab.org to the latest nightly. <link to issue>
    
  2. 次に、パッケージのホールドを解除します:

    sudo apt-mark unhold gitlab-ce
    
  3. アップグレードを続けます:

    sudo apt-get update
    sudo apt-get install gitlab-ce
    
  4. アップグレードが完了したら、https://dev.gitlab.org/help にアクセスして最新バージョンがインストールされていることを確認します。

  5. 最後に、#announcements チャンネルにメモを残します

    Upgrade completed. dev.gitlab.org now runs <version>.
    

GitLab 設定の変更

何らかの理由で /etc/gitlab/gitlab.rb に変更を適用する必要がある場合、その変更は dev-gitlab-org ロール で導入する必要があります。

このリポジトリへのアクセス権がなく、ホットパッチや設定テストを行う必要がある場合は、以下の手順を実行できます:

  1. このノードで chef-client を停止します:

    sudo service chef-client stop
    
  2. インスタンスを再び動作させるために必要な変更を行います。gitlab.rb ファイルへの変更が必要な場合は、手動で変更して reconfigure を実行します。

  3. gitlab.rb の設定変更を Chef サーバーにコミットするために、Production チームに連絡してサポートを求めます。

  4. これが適用されたら、ノードで chef-client を起動します: sudo service chef-client start

  5. 行ったすべての変更が Issue に記録されていることを確認してください!パッケージに修正が適用されたら、このノードへの変更を元に戻すことはあなたの責任です!