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
AWS CodeBuildを使ったCI環境の構築
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
KINOSHITA Minoru
October 02, 2019
Programming
1k
2
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
AWS CodeBuildを使ったCI環境の構築
KINOSHITA Minoru
October 02, 2019
More Decks by KINOSHITA Minoru
See All by KINOSHITA Minoru
クロージャについて
krtx
0
900
次元型に基づくループ不変条件自動生成(Synthesizing Loop Invariants via Dimension Types)
krtx
0
500
Automatic Synthesis of Combiners in the MapReduce Framework -- An Approach with Right Inverse
krtx
0
63
Other Decks in Programming
See All in Programming
Technical Debt: Understanding it Rightly, Engaging it Rightly #LaravelLiveJP
shogogg
0
200
Spec Driven Development | AI Summit Lisbon
danielsogl
PRO
0
170
ADKを使って簡単にAIエージェントを作ってみよう
k1mu21
0
240
JJUG CCC 2026 Spring: JSpecify で実現する Kotlin フレンドリーな Java API 設計
ternbusty
1
150
CLIであることを活かしたGitHub Copilot CLI活用術 / GitHub Copilot CLI Pro Tips & Tricks
nao_mk2
1
1.2k
Semantic Version 単位で戦略を柔軟に変えて、パッケージアップデートを自動化する
daitasu
0
180
「エンジニアインターン、どうやって取った?」準備のリアルを語るLT会 Progate BAR
akiomatic
0
120
The NotImplementedError Problem in Ruby
koic
1
650
セキュリティの専門家じゃなくてもできる。「セキュリティ意識」をアップデートして サプライチェーン攻撃への耐性を高めよう。
tk3fftk
5
670
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
520
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
320
ふつうのFeature Flag実践入門
irof
7
3.6k
Featured
See All Featured
Designing Experiences People Love
moore
143
24k
Effective software design: The role of men in debugging patriarchy in IT @ Voxxed Days AMS
baasie
0
400
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.5k
The Curse of the Amulet
leimatthew05
1
13k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
8.2k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
3.4k
For a Future-Friendly Web
brad_frost
183
10k
職位にかかわらず全員がリーダーシップを発揮するチーム作り / Building a team where everyone can demonstrate leadership regardless of position
madoxten
62
54k
The Anti-SEO Checklist Checklist. Pubcon Cyber Week
ryanjones
0
160
Claude Code のすすめ
schroneko
67
230k
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
130
Impact Scores and Hybrid Strategies: The future of link building
tamaranovitovic
0
300
Transcript
AWS CodeBuildを使った CI環境の構築 2019/10/02 CI/CD Test Night #5
自己紹介 樹下 稔 (KINOSHITA Minoru) • KLab株式会社 ◦ 技術統括部 バックエンドアーキテクチャグループ
+ 案件の仕事 ▪ Jenkinsの話 ▪ Unityのアセットバンドルビルドの話 ▪ CIの話 ▪ ... ◦ 横断的に情報共有しつつ実案件での仕事ができるポジション
話す内容 • AWS CodeBuildを使った並列CI環境構築 • 目新しいことはあまりなく、事例の一つとして聞いてください
目次 • 背景 • CI構成 • 工夫した点、なんとかしたい所
背景 • 案件のメインのサーバリポジトリは自動テストが1時間以上かかる ◦ 以前はローカルマシンでやっていた(手動) • AWSが案件で既に利用中だったので、CodeBuildを使った構成を考えた ◦ CircleCIとかは導入してないので ◦
やってみたいからやった、という気持ちも少なからず...
CI構成 • 要件と方針 • 全体構成 • テストの実行 • ログ
要件と方針 • 並列でビルドできること • なるべく手間をかけないで保守できるようにする →LambdaでCodeBuildを複数起動しよう
CI構成
CI構成 .buildspec/test1.yml .buildspec/test2.yml .buildspec/test3.yml 特定のディレクトリに buildspecファイルを複 数入れておく test1.yml test2.yml test3.yml
Lambdaがbuildspecファ イル毎にCodeBuildを起 動する 全部終了したらGitHub Checksに結果を書き込む &Slackに通知
GitHub Checks
GitHub Checks
CI構成 CodeBuild(buildspec)で対応していないこと、工夫した点 1. 分割して並列実行 2. DBなどのサービス起動 3. ログ閲覧
テストの分割&並列実行 • ベースとなるjsonnetファイルから複数のbuildspecファイルを生成する • buildspecファイルは全てリポジトリにコミット • Lambdaがそれぞれのbuildspecファイルに対してCodeBuildを起動 phases: build: ...
phases: { build: { .... }}
jsonnet test.jsonnet local Test(name) = { person: { name: name,
welcome: "Hello " + name + "!" }, }; { "test-alice.yml": std.manifestYamlDoc(Test("Alice")), "test-bob.yml": std.manifestYamlDoc(Test("Bob")) } test-bob.yml "person": "name": "Bob" "welcome": "Hello Bob!" test-alice.yml "person": "name": "Alice" "welcome": "Hello Alice!" $ jsonnet -S -m . test.jsonnet
DBなどのサービス起動 • docker in dockerができるイメージでdocker-composeを実行する ◦ Pros ▪ 開発用のdocker-composeをそのまま流用できる ▪
ローカルでのCodeBuildのテストも可能になる ◦ Cons ▪ docker-composeのインストールやdockerdの起動など一手間必要 https://github.com/aws/aws-codebuild-docker-images ※CodeBuildのdockerイメージもある
ログ • LambdaでCodeBuildの出力をGitHub Checksに書き込む ◦ 権限の問題 ▪ AWSのアカウントを持っていないメンバーもいる ▪ GitHubなら全員アクセス可能
◦ 使いやすさの問題 ▪ AWSに慣れていないメンバーが多い ▪ CloudWatch Logsは使いにくい ▪ GitHubから直接結果が見れると便利
工夫した点、なんとかしたい点 • 前準備に時間がかかる • 意外とコードを書いてしまった
工夫した点、なんとかしたい点 • 前準備に時間がかかる • 意外とコードを書いてしまった
テストの前準備に時間がかかる • 前準備が(頑張って短縮して)3分程度 ◦ リポジトリのセットアップ ◦ docker imageのpull ◦ テーブル作成、テストデータのinsert
• 前準備のオーバヘッドが大きいと並列数をあげても台数効果が出ない
リポジトリのセットアップについて • たくさんのリポジトリをclone ◦ メインのリポジトリとそのsubmodule ◦ なぜか依存しているリポジトリとそのsubmodule • リポジトリのcloneの仕方を工夫すると時間が削減できる ◦
不要なリポジトリがあるのではないかという話もありつつ…
リポジトリのセットアップについて • 特定のブランチの最新コミットだけcloneする git clone --depth=1 --branch=<branch> <repository> • DL量は減る
リポジトリのセットアップについて • submoduleはブランチ名不明でハッシュしか分からないので git init git remote add origin <repo>
git fetch origin --depth=1 <hash> git reset --hard FETCH_HEAD • これが成功するのは<hash>が特定のrefに紐付いている場合のみ ◦ そうでないときは失敗するので諦めて普通にcloneする
リポジトリのセットアップについて • AWS CodeBuildにはローカルキャッシュの機能がある ◦ ホスト上にdockerイメージやソースリポジトリを保存して使い回す機能 ◦ 今回の場合ストレートには使えない ▪ dindだったり独自にgit
cloneしているため https://aws.amazon.com/jp/about-aws/whats-new/2019/02/aws-codebuild-now-supports-local-caching/ 任意のディレクトリをキャッシュできるのでやればできると思うが、キャッシュの生存期間は有限らしいので努力 に見合う効果があるのか?と思って試していない・・・
工夫した点、なんとかしたい点 • 前準備に時間がかかる • 意外とコードを書いてしまった
意外とコードを書いてしまった • ありものを使うので自前の処理はそこまで多くない想定だった • 実際にはLambda(js)を500行程度書いた ◦ buildspecファイルを探して指定 ◦ ビルド時間に制限 ◦
通知先チャンネルの指定 ◦ テストが全部終了したことを確認して通知 • 保守コストをほぼなくせるのではないかという目論見は外れた
意外とコードを書いてしまった • 汎用性(別リポジトリでの利用)のため独自CI機能を実装した ◦ .buildspec/meta.yml ▪ 複数ビルドがすべて終了したときにどのチャンネルに通知するか ▪ pushイベントに対して自動的にビルドを実行するブランチの指定 •
releaseブランチなど ◦ 既存CIサービスと比較すると当然見劣りする ▪ 頑張って作る必要があるかどうか微妙
まとめ • CodeBuildを使った並列ビルド環境を作った ◦ Lambdaでリポジトリの設定を読み込みCodeBuildを複数起動する ◦ GitHubからログが見れて便利 • 思ったよりコードを書いてしまった問題 ◦
保守コストに難 • リポジトリのセットアップに時間がかかる問題 ◦ cloneの仕方を工夫してある程度解決