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
72
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
AWS Lambdaに出会って人生が変わった1人の10年間 /awslambda10th
kwada
0
46
GPSデバイスを使った簡易位置案内システムの構築をしてみた話。/jawsfesta2024
kwada
0
380
とある航空会社の飛行機の乗り方をお教えします。/20240913-lt
kwada
3
240
Building a Simple Navigation Guide Service Using GPS Devices/jaws-pankration2024
kwada
0
61
SORACOM UG Explorer 2023ハンズオンの裏側サービスを紹介 / soracom-ug-online-17
kwada
0
160
(2023.08.17 Update)Detecting and stopping recursive loops in AWS Lambda functionsでAWS Lambdaの無限ループを防ぐ! / jaws-ug-shizuoka
kwada
0
210
三国志好きの自分が一番最初に出会った三国志のゲームを令和になってやってみた / retrogstudy-8
kwada
0
100
意外と使われている3レターコードの話 / 20230715_katsuura
kwada
0
120
「AWSではじめるクラウドセキュリティ」感想LT- 某ロボットアニメのセキュリティインシデントに思いを馳せる- / jawsugchiba-20
kwada
0
270
Other Decks in Technology
See All in Technology
あの日俺達が夢見たサーバレスアーキテクチャ/the-serverless-architecture-we-dreamed-of
tomoki10
0
420
小学3年生夏休みの自由研究「夏休みに Copilot で遊んでみた」
taichinakamura
0
140
ずっと昔に Star をつけたはずの思い出せない GitHub リポジトリを見つけたい!
rokuosan
0
150
権威ドキュメントで振り返る2024 #年忘れセキュリティ2024
hirotomotaguchi
2
730
複雑性の高いオブジェクト編集に向き合う: プラガブルなReactフォーム設計
righttouch
PRO
0
110
re:Invent をおうちで楽しんでみた ~CloudWatch のオブザーバビリティ機能がスゴい!/ Enjoyed AWS re:Invent from Home and CloudWatch Observability Feature is Amazing!
yuj1osm
0
120
Microsoft Azure全冠になってみた ~アレを使い倒した者が試験を制す!?~/Obtained all Microsoft Azure certifications Those who use "that" to the full will win the exam! ?
yuj1osm
1
110
Oracle Cloud Infrastructure:2024年12月度サービス・アップデート
oracle4engineer
PRO
0
160
UI State設計とテスト方針
rmakiyama
2
320
日本版とグローバル版のモバイルアプリ統合の開発の裏側と今後の展望
miichan
1
120
継続的にアウトカムを生み出し ビジネスにつなげる、 戦略と運営に対するタイミーのQUEST(探求)
zigorou
0
510
ブラックフライデーで購入したPixel9で、Gemini Nanoを動かしてみた
marchin1989
1
520
Featured
See All Featured
Fireside Chat
paigeccino
34
3.1k
No one is an island. Learnings from fostering a developers community.
thoeni
19
3k
Being A Developer After 40
akosma
87
590k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
38
1.9k
Building a Modern Day E-commerce SEO Strategy
aleyda
38
7k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
48
2.2k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
28
4.3k
Fantastic passwords and where to find them - at NoRuKo
philnash
50
2.9k
Thoughts on Productivity
jonyablonski
67
4.4k
Designing for humans not robots
tammielis
250
25k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
665
120k
Designing Experiences People Love
moore
138
23k
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