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
IaCジェネレーターを使って、昔に作ったLambda関数をCDK管理下においてみた / jaws-ug-josys-30
Search
Kenichiro Wada
April 15, 2024
Technology
0
24
IaCジェネレーターを使って、昔に作ったLambda関数をCDK管理下においてみた / jaws-ug-josys-30
2024.04.15 JAWS-UG 情シス支部 #30 の登壇資料です。
てか、発表終わってから、IaCツールじゃない、IaCジェネレーターやん!って気づいて、タイトル直してますorz
Kenichiro Wada
April 15, 2024
Tweet
Share
More Decks by Kenichiro Wada
See All by Kenichiro Wada
SORACOM UG Explorer 2023ハンズオンの裏側サービスを紹介 / soracom-ug-online-17
kwada
0
110
(2023.08.17 Update)Detecting and stopping recursive loops in AWS Lambda functionsでAWS Lambdaの無限ループを防ぐ! / jaws-ug-shizuoka
kwada
0
150
三国志好きの自分が一番最初に出会った三国志のゲームを令和になってやってみた / retrogstudy-8
kwada
0
57
意外と使われている3レターコードの話 / 20230715_katsuura
kwada
0
46
Press, Connect, Innovate: Exploring SORACOM IoT Button's Endless Possibilities / soracom-discovery-night-event-lt-jpn
kwada
0
110
Press, Connect, Innovate: Exploring SORACOM IoT Button's Endless Possibilities / soracom-discovery-night-event-lt
kwada
0
35
「AWSではじめるクラウドセキュリティ」感想LT- 某ロボットアニメのセキュリティインシデントに思いを馳せる- / jawsugchiba-20
kwada
0
170
GPSマルチユニットの紹介-いざ鎌倉- / kintone-cafe-soracom-ug-1
kwada
0
60
現地初参加(と思われていない)の人のAWS re:Invent 2022 & AWS Lambda SnapStart for Java functionsについて / jawsugchiba-19
kwada
0
200
Other Decks in Technology
See All in Technology
Babylon.jsと色々なものを組み合わせる:ブラウザのAPIやガジェットや2D描画ライブラリなど / Babylon.js 勉強会 vol.3
you
PRO
0
160
Google Cloud Next '24 Recap(Cloud Run/k8s)
mokocm
0
320
MapLibreとAmazon Location Service
dayjournal
1
180
実例で紹介するRAG導入時の知見と精度向上の勘所
yamahiro
5
1.5k
require(ESM)とECMAScript仕様
uhyo
4
950
Kernel MemoryでAzure OpenAI Serviceとお手軽データソース連携
mitsuzono
1
280
推しは推せるときに推せ! プロダクトにフィードバックしていこう
nakasho
0
450
On Your Data を超えていく!
hirotomotaguchi
2
750
ルーターでプレゼンする
puhitaku
1
3.2k
Gradle Build Scanを使ってビルドのことを知ろう potatotips #87
tomorrowkey
2
150
コードファーストの考え方。 Amplify Gen2から学ぶAWS次世代のWeb開発体験
yoshiitaka
1
290
Cracking the KubeCon CfP
inductor
2
270
Featured
See All Featured
Fantastic passwords and where to find them - at NoRuKo
philnash
38
2.5k
Side Projects
sachag
451
41k
How To Stay Up To Date on Web Technology
chriscoyier
782
250k
Principles of Awesome APIs and How to Build Them.
keavy
121
16k
A designer walks into a library…
pauljervisheath
201
23k
Visualization
eitanlees
137
14k
Adopting Sorbet at Scale
ufuk
69
8.6k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
34
8.9k
Ruby is Unlike a Banana
tanoku
96
10k
Build your cross-platform service in a week with App Engine
jlugia
226
17k
WebSockets: Embracing the real-time Web
robhawkes
59
7k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
11
1k
Transcript
BXT KBXTVH KBXTVHγε"846TFS(SPVQT BXTDPNNVOJUZ 2024.04.15 JAWS-UG 情シス⽀部 #30 和⽥健⼀郎@Keni_W *B$πʔϧδΣωϨʔλʔΛͬͯɺੲʹ࡞ͬͨ
-BNCEBؔΛ$%,ཧԼʹ͓͍ͯΈͨ
⾃⼰紹介 ⽒名:和⽥ 健⼀郎 アイレット株式会社 エンジニア JAWS-UG 千葉 運営メンバー SORACOM UG東京
運営メンバー X: @Keni_W Facebook : kenichiro.wada.3 好きなAWSサービス : AWS Lambda AWS Community Builder(Serverless) SORACOM MVC 2022 iretテクニカルアンバサダー 2023
会社紹介 開発 Development 構築 MSP※ 請求代行 Resale AWS:2010年開始 ・世界中でのサービス提供 ・洗練されたツールによる
MSP ・英語サポート ・AWS取扱量は毎年大幅増 ・パブリック クラウド 日本トップクラスの取扱量 ・アプリケーション開発 ・サーバーレス開発 ・デザイン / Webシステム開発 ・ゲーム開発 ・ITコンサルティング 開発 デザイン インフラ Infrastructure ※MSP: マネージド サービス プロバイダー / 監視運用保守 アイレットは、クラウドの導入設計から構築・保守・運用をトータルでサポートする「cloudpack」および「Rackspace」 そしてシステム設計・開発・デザインをワンストップで行う「開発」を提供しています。 セキュリティ Security IoT AWS:2020年開始 KCPS (RPC-Vベアメタル)
ࣗݾհଓ͖ • ロールはアプリケーションエンジニア • 普段の業務は、社内開発というチームで、 社内で使うアプリの開発等を担当 • 主にPHP、Node.js(TypeScript)、 Pythonでコード書いてる •
GoとかRubyもあったりする • 実は昔はJavaな⼈(最近全く書いてない) +"846(γεࢧ෦-5KBXTVHγε
ࣗݾհଓ͖ 社内で使うアプリと⾔っても、多種多様 • EC2上で動いているWebアプリ • EventBridge + SQS + Lambda
+ S3を 構築された定期バッチ • Step Functions + Lambdaで構築された 他システム連携処理 • Amplify で構築されたWebアプリ ・・・などなど +"846(γεࢧ෦-5KBXTVHγε
ࣗݾհଓ͖ 社内で使うアプリと⾔っても、多種多様 • EC2上で動いているWebアプリ • EventBridge + SQS + Lambda
+ S3を 構築された定期バッチ • Step Functions + Lambdaで構築された 他システム連携処理 • Amplify で構築されたWebアプリ ・・・などなど +"846(γεࢧ෦-5KBXTVHγε
+"846(γεࢧ෦-5KBXTVHγε 今年初めのこと・・ チームリーダー : 前に作った連携システムに 〜な機能を追加よろしく! 昔⾃分が作ったシステム ですね!。 了解です。 IaCジェネレーター使った&CDK
Migrationしてみた
IaCジェネレーター使った&CDK Migrationしてみた • Lambdaはコンソールで⼿動でデプロイ • それが全部で5つ • 今回処理追加で呼び出すLambdaが追加 • ランタイムバージョンが混在すること
に • Step FunctionsではMap使っているけど、 Distributed Mapを利⽤したい +"846(γεࢧ෦-5KBXTVHγε
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε Lambdaは コンソールで デプロイ AWS CDK でデプロイ 作業を容易
にしたい Lambdaの バージョン 混在 全部作り直せ ばいいやん
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε CDKのProjectととして、 新しく作って、 リリースは マルっと置き換えること にしよう!
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε ってことを決めた頃、 登場したのがこのアップデート https://aws.amazon.com/jp/blogs/news/import-entire-applications-into-aws-cloudformation/
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε これは使うしかない!ってことになりまして、 早速使ってみることに
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε ⼿順としては、以下 • リソースのスキャン • テンプレート⽣成 • CDK
Migrate • (L2 Constructs化) https://qiita.com/KbSota/items/be3b4063deea52815d50
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε ・リソースのスキャン ここのボタンをクリック して、終わるのを待つ
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε 説明には、 とありますが、 結果としては、10000ちょいのリソースがあ りましたが、12分ほどでスキャン終了
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε ・テンプレート⽣成 ※ここが肝 Scanしたリソースを探して選ぶ
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε 個⼈的には、 AWS Lambdaの検索が名前でできるようにな ると嬉しい Tagに名前でもセットしておけ・・・っての はそうなんだけも
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε ⽣成が終わると、そのままCloudFormation のStackとしてインポート可能 今回はAWS CDKで使いたいので、AWS CDK のタブに移動して、テンプレートファイルを ダウンロード
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε https://aws.amazon.com/jp/blogs/news/announcing-cdk-migrate-a-single-command-to-migrate- to-the-aws-cdk/ ・CDK Migrate 後で気づいたんですが、ほぼ同時期に登場し てたんですね。このコマンド
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε 落としてきたファイルを適当な場所に置いて、 記載してあるコマンドを実⾏ 注意点は、コマンド実⾏は、テンプレートを ⽣成したリージョンをデフォルトリージョン にする必要があり ※cdk deploy⾃体はリージョン変えても⼤丈
夫(そりゃそうだ)
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε デプロイ時の注意点 Migrateコマンド実⾏すると、migrate.json というファイルが⽣成される これが残っていると、cdk deploy時にリソー スがないといってエラー発⽣ (cdk
diffの時はエラーにならない) (そのまま使うならいいけど)
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε ・L2 Constructs 化 CDKのProjectとして取り込めればOK ただ、⽣成されたCDKのStackファイルは、 L1 Constructs
で構成されている 可能であれば、L2 Constructs化した⽅が、 メンテナンスは楽では?
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε ⾃分の開発環境で試した例 L1 Constructs Ver. : 244⾏ L2
Constructs Ver. : 65⾏ ¼ぐらいなので、いい削減量ですし、 可読性が上がりますので、L2化がおすすめ
IaCジェネレーター使った&CDK Migrationしてみた +"846(γεࢧ෦-5KBXTVHγε 今回の作り直しに関して⾔えば、 CDK管理化 -> 達成 デプロイ作業の単純化 -> 達成
とまあ、いいことずくめで、 先⽇、無事に本番リリースおよび処理置き換 えを完了済
まとめ +"846(γεࢧ෦-5KBXTVHγε • IaCジェネレーターは既存リソースのAWS CDK等IaC管理下に置く際に⾮常に便利 • しかも無料 • その他、リソースの洗い出しに便利説あ り
• 30⽇後には再Scanが必要なので、 Lambdaあたりで、定期実⾏すると継続 的にリソース取得できそう
まとめ +"846(γεࢧ෦-5KBXTVHγε
͓͠·͍ +"846(γεࢧ෦-5KBXTVHγε ご清聴ありがとうございました。 本⽇の資料のベースは -> https://bit.ly/3vZKb5l