リポジトリのミラーリング
ディープダイブ
2018年12月、Tiago BotelhoはGitLabPull Repository Mirroring機能に関するDeep Dive(GitLabチームメンバー限定:https://gitlab.com/gitlab-org/create-stage/-/issues/1 )を開催し、将来コードベースのこの部分に携わる可能性のある人に彼のドメイン固有の知識を共有しました。詳しくは 録画は YouTube で、スライドはPDF で見ることができます。このディープダイブで取り上げた内容はすべて GitLab 11.6 の時点でのもので、それ以降に具体的な詳細が変更されている可能性がありますが、それでも良い入門書として役立つはずです。
ミラーリングプロセスの説明
GitLabバージョン14は、APIコールがプルミラーをトリガーしたときに以下のステップを実行します。スケジュールされたミラーの更新も同様ですが、APIコールでは始まりません:
- リクエストは API 呼び出しから発生し、project_mirror.rbのstart_pull_mirroring_serviceをトリガーします。
- プルミラーリングサービス(start_pull_mirroring_service.rb)が開始します。プロジェクトの状態が更新され、ジョブが直ちに開始されます。
- プロジェクトのインポート状態が更新され、project_import_state.rbのupdate_all_mirrors_workerがトリガーされます。
- update all mirrors ワーカー (update_all_mirrors_worker.rb) は、project_import_scheduleワーカーを呼び出すことで、スタンプを回避しようとします。
- プロジェクトインポートスケジュールワーカー (project_import_schedule_worker.rb) は、プロジェクトの状態を更新し、インポート遷移プロセスを管理するために Rubystate_machineを起動します。
- プロジェクトの状態を更新する間、 project.rbのこの呼び出しはrepository_update_mirrorワーカーを起動します。
- Sidekiqバックグラウンドミラーワーカー(repository_update_mirror_worker.rb)はミラーリングタスクの状態を追跡し、良いエラー状態情報を提供します。このステップはGitのステップを管理するので、ここでプロセスがハングすることがあります。
- アップデートミラーサービス(update_mirror_service.rb)はGitオペレーションを実行します。
インポートとミラーの更新処理は、ミラーサービスの更新ステップの後で完了します。しかし、含まれる変更内容によっては、さらに多くのタスク (コミット用のパイプラインなど) が発生することもあります。
