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
54
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
とある航空会社の飛行機の乗り方をお教えします。/20240913-lt
kwada
1
200
Building a Simple Navigation Guide Service Using GPS Devices/jaws-pankration2024
kwada
0
21
SORACOM UG Explorer 2023ハンズオンの裏側サービスを紹介 / soracom-ug-online-17
kwada
0
140
(2023.08.17 Update)Detecting and stopping recursive loops in AWS Lambda functionsでAWS Lambdaの無限ループを防ぐ! / jaws-ug-shizuoka
kwada
0
180
三国志好きの自分が一番最初に出会った三国志のゲームを令和になってやってみた / retrogstudy-8
kwada
0
79
意外と使われている3レターコードの話 / 20230715_katsuura
kwada
0
87
Press, Connect, Innovate: Exploring SORACOM IoT Button's Endless Possibilities / soracom-discovery-night-event-lt-jpn
kwada
0
120
Press, Connect, Innovate: Exploring SORACOM IoT Button's Endless Possibilities / soracom-discovery-night-event-lt
kwada
0
63
「AWSではじめるクラウドセキュリティ」感想LT- 某ロボットアニメのセキュリティインシデントに思いを馳せる- / jawsugchiba-20
kwada
0
230
Other Decks in Technology
See All in Technology
DuckDB雑紹介(1.1対応版)@DuckDB座談会
ktz
6
1.4k
Mocking in Rust Applications
taiki45
1
410
やってやろうじゃないかメカアジャイル! / Let's do it, mechanical agile!
psj59129
1
660
不動産売買取引におけるAIの可能性とプロダクトでのAI活用
zabio3
0
270
JEP 480: Structured Concurrency
aya_ebata
0
130
自作Cコンパイラ 8時間の奮闘
soukouki
0
840
20240911_New_Relicダッシュボード活用例
speakerdeckfk
0
110
ネットワークだけ隔離されたコンテナ作成デモ / Kichijoji.pm36
tenforward
1
230
Next.js のページ遷移を全力で止める
ypresto
6
3.2k
OCI で始める!! Red Hat OpenShift / Get Started OpenShift on OCI
oracle4engineer
PRO
1
180
スタッフエンジニアの道: The Staff Engineer’s Path
snoozer05
PRO
44
14k
グイグイ系QAマネージャーの仕事
sadonosake
0
330
Featured
See All Featured
Building Adaptive Systems
keathley
36
2.1k
GraphQLとの向き合い方2022年版
quramy
43
13k
The Invisible Customer
myddelton
119
13k
How GitHub Uses GitHub to Build GitHub
holman
472
290k
KATA
mclloyd
27
13k
Why Our Code Smells
bkeepers
PRO
334
56k
Become a Pro
speakerdeck
PRO
22
4.9k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
29
2.6k
Designing Experiences People Love
moore
138
23k
Being A Developer After 40
akosma
84
590k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
PRO
5
480
How To Stay Up To Date on Web Technology
chriscoyier
786
250k
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