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
CDKでAppSyncのJavaScriptリゾルバを開発したい
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
ryome
July 07, 2023
Technology
310
0
Share
CDKでAppSyncのJavaScriptリゾルバを開発したい
CDKを使用してAppSyncのJavaScriptリゾルバを開発するメリットについて解説します。
ryome
July 07, 2023
More Decks by ryome
See All by ryome
AWSデスノート〜AWSの嫌いなところまとめ〜
ryome
0
40
AWS MCPを使ってみた
ryome
0
600
ClineでAWS CDKやインフラ構成図作ってみた
ryome
1
610
PlaywrightというE2Eテストツールを布教したい
ryome
0
83
Cursorという最強エディタを使いこなしたい
ryome
0
330
E2Eテストを自動化したい
ryome
0
87
AWS CodeBuildを高速化したい
ryome
0
680
Cognitoの複数IDP認証でユーザを統合したい
ryome
1
1.4k
OAuth2.0完全に理解した
ryome
0
270
Other Decks in Technology
See All in Technology
Claude code Orchestra
ozakiomumkj
3
780
Anthropic AIネイティブ・スタートアップ構築のプレイブック を理解する
nagatsu
0
230
NFLコンペ2026 解法
lycorptech_jp
PRO
0
130
大学生が本気でDatabricksを活用してDiscordサークルをデータ駆動させてみた
phantomjuju
1
300
Oracle AI Database@Azure:サービス概要のご紹介
oracle4engineer
PRO
6
1.8k
Strands Agents超入門
kintotechdev
1
150
イベントストーミングとKiroの仕様駆動開発で実現する要件の認識合わせプロセス
syobochim
7
980
TypeScript Compiler APIとPHP-Parserを活用し、TypeScriptとPHPで型を共有する
shuta13
0
270
string地獄を脱出する
sansantech
PRO
1
110
OpenClawとHermesAgentでAI新入社員を作った話
takanoriyanada
0
150
マーケットプレイス版Oracle WebCenter Content For OCI
oracle4engineer
PRO
5
1.7k
Unlocking the Apps
pimterry
0
130
Featured
See All Featured
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.7k
DevOps and Value Stream Thinking: Enabling flow, efficiency and business value
helenjbeal
1
210
Public Speaking Without Barfing On Your Shoes - THAT 2023
reverentgeek
1
410
Data-driven link building: lessons from a $708K investment (BrightonSEO talk)
szymonslowik
1
1.1k
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
440
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
190
Docker and Python
trallard
47
3.9k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
25
1.9k
Making the Leap to Tech Lead
cromwellryan
135
9.9k
Building Adaptive Systems
keathley
44
3k
WENDY [Excerpt]
tessaabrams
11
38k
Transcript
CDKでAppSyncの JavaScriptリゾルバを開発したい
AWS CDKおさらい • AWS CDKは、クラウドリソースのプロビジョニングを行うための 開発フレームワーク • AWS CDKを使うと、開発者は一般的なプログラミング言語を使用して、 クラウドリソースをプロビジョニングすることができる
• AWS CDKは、AWSリソースの高レベルな抽象化を提供し、開発者は インフラの詳細を深く理解しなくても、クラウドリソースの作成、 管理をすることができる • AWS CDKはAWS CloudFormationを内部的に使用して、 クラウドリソースをプロビジョニングする
AWS AppSyncおさらい • AWS AppSyncは、AWSが提供するフルマネージド型のGraphQLサービス • AWS AppSyncは、GraphQLのsubscription機能を使用して、 リアルタイムなデータ同期を可能にする •
AWS AppSyncは、Amazon DynamoDB、Amazon Auroraなどの異なる データソースからデータを取得し、単一のAPIエンドポイントで結合が可能 • GraphQLを採用しているため、AppSyncではクライアントが必要な データのみをクエリーすることができる
AppSyncリゾルバおさらい • AppSync では、データソース、リゾルバ、関数を定義することができる • リゾルバは AppSync に GraphQL リクエストの処理方法を指示し、
レスポンスを GraphQL タイプで返却する • AppSync のリゾルバは、パイプラインで最大10個の関数を設定でき、 それぞれがデータソースに接続できる • リゾルバが呼び出されると、各関数が順番に実行される GraphQL リ ク エ ス ト パ イ プ ラ イ ン リ ク エ ス ト 関 数 リ ク エ ス ト デ ー タ ソ ー ス 関 数 レ ス ポ ン ス パ イ プ ラ イ ン レ ス ポ ン ス GraphQL レ ス ポ ン ス ・・・
なぜ、CDKでAppSync開発?? • 共通言語利用:JavaScriptさえ習得すればインフラ、フロントエンド、バック エンドのコードが書ける(インフラに条件分岐・ループ等も使用可能) • 自動デプロイ:cdk watchコマンドを使用して、変更があった際に 自動的に検知してデプロイができる(cdk.jsonにwatch範囲を定義する) • コード短縮:CloudFormationテンプレートが数千行必要となるような
複雑なインフラを数百行程度のコードで実現できる • 静的な型チェックと自動補完:インフラ開発の初期段階で、 エラー検出が可能になり、IDEの自動補完機能をフル活用できる
共通言語利用 フロントエンド (React) バックエンド (AppSync) インフラ (CDK)
自動デプロイ ① 「 cdk watch --hotswap-fallback 」 コマンドを実行 ② 変更を自動検知して
デプロイを実行する
コード短縮 CDK CloudFormation 153行 909行
静的な型チェックと自動補完 IDEが自動補完 してくれる 引数の型が 決まっている
JavaScriptリゾルバによりVTLから解放 VTLのダメだったところ • 学習難易度:学習コストが高い かつ 他で使う場面が少ない • ドキュメント不足:VTLに関する記事が少ない JavaScriptになって良かったこと •
共通言語利用:JavaScriptさえ習得すればフロントエンドも バックエンドも書ける • ドキュメントが豊富: JavaScriptに関する記事は多い
機能一覧・インフラ構成図 ToDoリストアプリ • ログイン機能 • タスク一覧機能 • タスク作成機能 • タスク完了機能
• タスク削除機能 ソースコード等は以下に格納されています。 https://github.com/ryomeblog/cdk-js-resolvers-sample
シーケンス図 (初回起動・ログイン)
シーケンス図 (タスク作成)
シーケンス図 (タスク完了)
シーケンス図 (タスク削除)
動作確認 詳細はQiitaで解説。 https://github.com/ryomebl og/cdk-js-resolvers-sample
参考文献 • https://github.com/ryomeblog/cdk-js-resolvers-sample • https://dev.classmethod.jp/articles/cdk-watch-mode • https://cdkworkshop.com/ja/20-typescript/30-hello- cdk/300-cdk-watch.html