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管理下においてみた / jaw...
Search
Kenichiro Wada
April 15, 2024
Technology
0
120
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
(全日本人)待望のS3トリガーのLambda無限ループ対応について / chibaraki-1
kwada
0
99
AWS Lambdaに出会って人生が変わった1人の10年間 /awslambda10th
kwada
0
66
GPSデバイスを使った簡易位置案内システムの構築をしてみた話。/jawsfesta2024
kwada
0
590
とある航空会社の飛行機の乗り方をお教えします。/20240913-lt
kwada
3
270
Building a Simple Navigation Guide Service Using GPS Devices/jaws-pankration2024
kwada
0
89
SORACOM UG Explorer 2023ハンズオンの裏側サービスを紹介 / soracom-ug-online-17
kwada
0
240
(2023.08.17 Update)Detecting and stopping recursive loops in AWS Lambda functionsでAWS Lambdaの無限ループを防ぐ! / jaws-ug-shizuoka
kwada
0
230
三国志好きの自分が一番最初に出会った三国志のゲームを令和になってやってみた / retrogstudy-8
kwada
0
130
意外と使われている3レターコードの話 / 20230715_katsuura
kwada
0
140
Other Decks in Technology
See All in Technology
20250326_管理ツールの権限管理で改善したこと
sasata299
1
380
ソフトウェアプロジェクトの成功率が上がらない原因-「社会価値を考える」ということ-
ytanaka5569
0
130
RAGの基礎から実践運用まで:AWS BedrockとLangfuseで実現する構築・監視・評価
sonoda_mj
0
440
SSH公開鍵認証による接続 / Connecting with SSH Public Key Authentication
kaityo256
PRO
2
220
DevinはクラウドエンジニアAIになれるのか!? 実践的なガードレール設計/devin-can-become-a-cloud-engineer-ai-practical-guardrail-design
tomoki10
3
1.3k
Dapr For Java Developers SouJava 25
salaboy
1
130
数百台のオンプレミスのサーバーをEKSに移行した話
yukiteraoka
0
680
セマンティックレイヤー入門
ikkimiyazaki
8
3.2k
パスキー導入の課題と ベストプラクティス、今後の展望
ritou
7
1.2k
一人QA時代が終わり、 QAチームが立ち上がった話
ma_cho29
0
290
お問い合わせ対応の改善取り組みとその進め方
masartz
1
370
3/26 クラウド食堂LT #2 GenU案件を通して学んだ教訓 登壇資料
ymae
1
200
Featured
See All Featured
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
44
7.1k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
29
2.5k
Bash Introduction
62gerente
611
210k
4 Signs Your Business is Dying
shpigford
183
22k
The World Runs on Bad Software
bkeepers
PRO
67
11k
It's Worth the Effort
3n
184
28k
Adopting Sorbet at Scale
ufuk
75
9.3k
[RailsConf 2023] Rails as a piece of cake
palkan
53
5.4k
How to Ace a Technical Interview
jacobian
276
23k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
46
2.4k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.2k
Documentation Writing (for coders)
carmenintech
69
4.7k
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