Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
ラクマにおけるGitOps導入事例
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Hidekazu Miyamoto
May 26, 2021
Technology
1.4k
0
Share
ラクマにおけるGitOps導入事例
https://resources.github.com/webcasts/jp-github-infocus-devops/
Hidekazu Miyamoto
May 26, 2021
More Decks by Hidekazu Miyamoto
See All by Hidekazu Miyamoto
#DevOpsDaysTokyo ラクマとGitHub ActionsとGitOps
hiiiide
1
760
Other Decks in Technology
See All in Technology
AWSアップデートから考える継続的な運用改善
toru_kubota
2
320
最新技術を"今は選ばない"という技術選定
leveragestech
PRO
0
320
LookerとADKで作る社内AIエージェント
chanyou0311
0
280
ECSのTerraformモジュールにコントリビュートした話
harukasakihara
0
260
PdM・Eng・QAで進めるAI駆動開発の現在地/aidd-with-pdm-eng-qa
shota_kusaba
0
260
20260515 ⾃分のアカウントとプライバシーを守る認証と認可の話〜利⽤者向け〜
oidfj
0
810
AWS運用におけるAI Agent活用術 / JAWS-UG 神戸 #11 LT大会
genda
1
310
実践 TanStack Start ― 新規プロダクトを開発して確立した、サーバーとクライアント境界の設計パターン / Practical TanStack Start Server-Client Boundary Patterns
kaminashi
1
140
The Making of AI Chips
pfn
PRO
0
490
20260515 ログイン機能だけではないアカウント管理を全体で考える~サービス設計者向け~
oidfj
1
870
なぜ、IAMロールのプリンシパルに*による部分マッチングが使えないのか? / 20260518-ssmjp-iam-role-principal
opelab
2
140
AI時代に、 データアナリストがデータエンジニアに異動して
jackojacko_
0
1.1k
Featured
See All Featured
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
Docker and Python
trallard
47
3.8k
First, design no harm
axbom
PRO
2
1.2k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
430
The Curse of the Amulet
leimatthew05
1
12k
Code Review Best Practice
trishagee
74
20k
How to Ace a Technical Interview
jacobian
281
24k
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
140
Rails Girls Zürich Keynote
gr2m
96
14k
Transcript
May 26th, 2021 GitHub InFocus Hidekazu Miyamoto C2C Service Development
Section. Rakuten Group, Inc. ラクマにおけるGitOps導⼊事例
2 Hidekazu Miyamoto Tech Lead, Rakuma SRE Team Hello!
3
4 ラクマSREについて ラクマSREチームについて
5 SREチームの任務 • サービスを提供するインフラシステムの設計・構築・運⽤ • 24/365のサービスの安定稼働 • パフォーマンスチューニング • ⼈でスケールするのではなく、システムでスケールさせること
6 課題 • 新たな機能をどんどん追加してサービスを成⻑させないといけない時期 SRE
7 課題 • 新たな機能をどんどん追加してサービスを成⻑させないといけない時期 • 新機能追加時の構成相談や、設定変更依頼、インフラに関する問い合わせが増加 Consultation Capacity Consultation Architect
Change setting request Trouble Shooting SRE Support
8 課題 • 新たな機能をどんどん追加してサービスを成⻑させないといけない時期 • 新機能追加時の構成相談や、設定変更依頼、インフラに関する問い合わせが増加 • サービスの稼働率の担保、監視、障害対応も並⾏して⾏わないといけない Consultation Capacity
Consultation Architect Change setting request Trouble Shooting Monitoring CI/CD Incident Audit SRE Oparation Support
9 課題 • 新たな機能をどんどん追加してサービスを成⻑させないといけない時期 • 新機能追加時の構成相談や、設定変更依頼、インフラに関する問い合わせが増加 • サービスの稼働率の担保、監視、障害対応も並⾏して⾏わないといけない Consultation Capacity
Consultation Architect Change setting request Trouble Shooting Monitoring CI/CD Incident Audit SRE Oparation Support
10 監査の証跡集めに必要なもの • いつ、誰が、どのような変更をしたのか • 責任者の承認をえた上で変更作業を実施しているのか
11 ラクマSREについて GitOpsについて
12 GitOpsとは https://www.weave.works/blog/gitops-operations-by-pull-request • 2017年に公開されたWeaveworks社のブログで “GitOps”という⾔葉が誕⽣ • 要約すると、⼈の⼿を介さずにインフラに関するのコードをGitで管理する思想 • 主にKubernetesのリソース管理で使われることが多い
• インフラの変更に関する追跡情報が集約されているため、監査の証跡集めとしても有効
13 ラクマSREについて Terraformの実⾏環境の仕組み
14 実現したい事 - 開発編 Cloud Platform Developer GitHub Actions 1.
PullRequest 2. Action 4. plan terraform-repo 3. init, fmt 5. Add the result to comment
15 実現したい事 – リリース編 Cloud Platform Developer GitHub Actions 1.
Approve 3. Action 4. apply terraform-repo Code Owner 2. Merge
None
None
None
19 Sample Code https://gist.github.com/hiiiide/1ae69bebb8c0335c177a8b32763e505e
20 ラクマSREについて Kubernetesのリソース管理を どのようなGitHub Actionsを組み合わせて GitOps化したか
21 実現したい事 Developer application-repo k8s-manifest-repo GitHub Actions Container Registry 1.
Push 2. Action 3. Push Image 4. Push manifest file 5. Polling 6. apply
22 コンテナのビルドとプッシュ Developer application-repo k8s-manifest-repo GitHub Actions Container Registry 1.
Push 2. Action 3. Push Image 4. Push manifest file 5. Polling 6. apply
23 コンテナのビルドとプッシュ
24 コンテナのビルドとプッシュ コンテナレジストリのログイン処理 ビルド、プッシュ処理 初期処理
25 マニフェストファイルの更新 + Pull Request作成 Developer application-repo k8s-manifest-repo GitHub Actions
Container Registry 1. Push 2. Action 3. Push Image 4. Push manifest file 5. Polling 6. apply
26 マニフェストファイルの更新 + Pull Request作成 • 外部のレポジトリ(k8s-manifest-repo)のチェックアウトが必要 • デフォルトで⽤意されているCheckoutで実現可能 •
対象のレポジトリを⽤意するだけでOK(pathの指定は任意)
27 マニフェストファイルの更新 + Pull Request作成 • マニフェストファイル(Deployment)をGitHub Actions内で変更する • 今回はrubyスクリプトを⽤意して、コンテナイメージのタグを更新
• もっとシンプルにしたい場合は yq コマンドを使⽤すると良い
28 マニフェストファイルの更新 + Pull Request作成
29 マニフェストファイルの更新 + Pull Request作成
30 マニフェストファイルの更新 + Pull Request作成
31 GitOpsのブランチ戦略について
32 前提 • Kustomizeを使⽤したKubernatesのマニフェストファイルを、どのようなブランチ戦略で管理してくか に焦点を当てる • Kustomizeとは、Kubernetesのyamlを効率よく運⽤するのに特化したパッケージングツール
33 PRD K8S Cluster staging branch develop branch main branch
feature branch STG K8S Cluster DEV K8S Cluster ブランチ戦略 Pattern1 3. merge 2. merge 1. checkout 4. merge
34 PRD K8S Cluster staging branch develop branch main branch
feature branch STG K8S Cluster DEV K8S Cluster ブランチ戦略 Pattern2 4. merge 3. merge 2. merge 1. checkout
35 PRD K8S Cluster main branch feature branch STG K8S
Cluster DEV K8S Cluster ブランチ戦略 Pattern3 - overlay更新時 2. merge 1. checkout
36 PRD K8S Cluster main branch feature branch STG K8S
Cluster DEV K8S Cluster ブランチ戦略 Pattern3 - base更新時 2. merge 1. checkout
37 Pattern3 Pros Cons List Pattern1 Pattern2 Pros Cons Pattern1
ブランチが固定になっている為わかりやすい overlaysの対応を⾏う時に他のbranchへのマージ漏れが出てくる可能性があ る Pattern2 ブランチが固定になっている為わかりやすい Pattern1で懸念していたマージ漏れは回避できる 対応するフローが多く⾯倒 Pattern3 ブランチの構成がシンプル Pattern1で懸念していたマージ漏れは回避できる baseの対応時のbranch切り替え作業が⾯倒
38 まとめ • インフラの設定管理もコードで管理すれば、監査対応も楽になる • 何かやりたいことがあれば、まずはGitHub MarketplaceでActionsを探そう • GitOpsを導⼊するときはブランチ戦略を考えてから実戦に挑もう
None