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
極力楽してKubernetes環境を構築したいwith AWS, terraform, EKS...
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
k.bigwheel (kazufumi nishida)
November 23, 2023
Technology
3k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
極力楽してKubernetes環境を構築したいwith AWS, terraform, EKS, Argo-CD
k.bigwheel (kazufumi nishida)
November 23, 2023
More Decks by k.bigwheel (kazufumi nishida)
See All by k.bigwheel (kazufumi nishida)
2022年マイベスト本紹介「FACTFULNESS」
bigwheel
0
1.5k
Other Decks in Technology
See All in Technology
トークン最適化のためのユーザーストーリー分析 / User Story Analysis for Token Optimization
oomatomo
0
110
ぼっちではじめた登壇が「51名」「241件」の発信に化けた
subroh0508
1
330
AIチャットの改善から見えた、良いAI体験とは / What Constitutes a Good AI Experience: Insights from Improving AI Chat
kubode
0
120
「ビジネスがわかるエンジニア」とは何か?
ryooob
0
340
週末にループ・エンジニアリングの理解を深めるためのスライド
nagatsu
0
520
When Platform Engineering Meets GenAI
sucitw
0
200
AIをフル活用してオンコール機能のプロトタイプを2日で作った話 / Building an AI-Powered On-Call Prototype in Just Two Days
nari_ex
0
140
初めてのDatabricks勉強会
taka_aki
2
170
AIに障害切り分けを全部やってもらった。 。 。 。
estie
0
230
自分が詳しくない領域でAIを使う #プロヒス2026
konifar
20
7.8k
40代で“やっとエンジニアになれた”――閉じた学びを開き、空の青さを知る / 20260628 Naoki Takahashi
shift_evolve
PRO
4
950
IaC コードを資産へ:AWS CDK 社内ライブラリと横断展開 / aws-summit-japan-2026
gotok365
10
1.6k
Featured
See All Featured
Making Projects Easy
brettharned
120
6.7k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
46
2.9k
GraphQLの誤解/rethinking-graphql
sonatard
75
12k
It's Worth the Effort
3n
188
29k
A designer walks into a library…
pauljervisheath
211
24k
Statistics for Hackers
jakevdp
799
230k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4.1k
[SF Ruby Conf 2025] Rails X
palkan
2
1.1k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.8k
How Software Deployment tools have changed in the past 20 years
geshan
0
34k
Raft: Consensus for Rubyists
vanstee
141
7.6k
Transcript
極力楽して Kubernetes環境を構築したい with AWS, terraform, EKS, Argo-CD 2020/08/26 Kubernetes Meetup
Tokyo #33 株式会社Speee DX事業本部 SREエンジニア 西田和史 (k_bigwheel)
弊事業部のインフラ • ベース • EKS使用 • シングルテナント (1サービスごとに1クラスタ) • Argo
CD • Terraformで管理
インフラ詳細
課題感 • 事業部内のサービスの増加速度に対してインフラの構築速度が間に合ってない ◦ もっと高速にインフラ 1セットを提供したい • ほぼ同じインフラを何度も作成 ◦ 2人のSREチームでは手間が馬鹿にならない
(トイル化) ◦ 毎回微妙な差分が発生 • 毎回ちょっとずつ進化・改善している ◦ 改善が過去に構築したインフラへ反映できていない
モジュール化(terraform module / helm)で解決? • 適切に使用すれば紋切り型コードが大幅に減少 ◦ 例: ウェブサービス用の helm
chart(Deployment, Service, Ingressのセット) • 一方で過度のモジュール化(共通化)は個別最適化の選択肢を奪う ◦ オペレータA, B, C, Dを内包するhelm chartは便利だけどBを入れたくないクラスタではとたんに 面倒になる • モジュールを十分小さくすれば選択的に使える? ◦ モジュールが増えると使い方を理解するコストが増え、モジュール間の グルーコードも増える
モジュール化できた次に挙がる問題、 グルーコード • 適切な粒度で十分な機能を持ったモジュールがあってさえ、 グルーコードは一定必要 ◦ 例: helmを可能な限り使った場合でも manifestファイルの行数合計が 780
コードをテンプレート化して自動 生成しよう!
• シンプルで汎用性の高いプロジェクトテンプレート作成ツール ◦ https://github.com/cookiecutter/cookiecutter • 使い方 a. テキストファイルの中で変数展開したい箇所を Jinja2フォーマット {{
変数名 }}で記述 b. cookiecutterコマンドを実行、ダイアログで変数の値を入力 c. 変数展開されたファイルが生成!
ここが自動生成できるようになった
プロジェクト初日にやること 1. AWSアカウントの作成 2. GitHubにリポジトリの作成 3. GitHub SecretsにCI用の Credentialsを設定 4.
右のコマンドを実行 # インフラコードの生成 cookiecutter
[email protected]
:speee/infra-template.git # CIでインフラを構築 git add . git push origin HEAD # k8s認証情報の設定 aws eks update-kubeconfig --name hogehoge # Argo CDのインストール kubectl create namespace argo-cd helm repo add argo https://argoproj.github.io/argo-helm helm install argo-cd argo/argo-cd -n argo-cd --set installCRDs=false # マニフェストファイルの生成 cookiecutter
[email protected]
:speee/manifest-template.git # Argo CDにマニフェストリポジトリを登録 git add . git push origin HEAD argocd repo add https://github.com/speee/hogehoge-manifest
以上のコマンドにより、
以上のコマンドにより、 ここ以外のすべてが 1時間でできるように なった!
課題は解決した? • もっと高速にインフラ1セットを提供したい ➢ 最短1日未満で提供できるようになりつつある • 2人のSREチームでは手間が馬鹿にならない(トイル化) ➢ 作業を大幅に簡略化 •
毎回微妙な差分が発生 ➢ テンプレート化で不要な差分は最小化 • 改善が過去に構築したインフラへ反映できていない ➢ インフラリポジトリ/マニフェストリポジトリの骨格が揃ったので足並みを揃えやすくなった
ご清聴 ありがとう ございました まとめ 1. モジュール化 a. Terraform module b.
helm 2. テンプレート(コード自動生成) a. cookiecutter より以下ができた • トイルの削減 • 高速な初期構築 • コードの標準化(正規化)