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
RDSプロキシは未来を変えるか
Search
TomoyaIwata
June 26, 2020
Technology
2
26k
RDSプロキシは未来を変えるか
Developers.IO 2020 CONNECTの発表資料です
TomoyaIwata
June 26, 2020
Tweet
Share
More Decks by TomoyaIwata
See All by TomoyaIwata
これでLambdaが不要に?!Step FunctionsのJSONata対応について
iwatatomoya
2
4.1k
Qdrantでベクトルデータベースに入門してみよう
iwatatomoya
0
380
詳解 AWS Lambdaコールドスタート
iwatatomoya
1
1.9k
真のサーバーレスへ向けたAuroraの進化Aurora Limitless Database
iwatatomoya
1
4.5k
AWS SDKのClientはFactory経由で作ろう
iwatatomoya
1
730
OpentelemetryでアプリケーションのObservabilityを強化しよう
iwatatomoya
0
950
AWS Lambdaは俺が作った
iwatatomoya
2
2.3k
SnapStartの未来についての期待と妄想
iwatatomoya
1
1.3k
実例から学ぶ! AWSを活用したシステム開発の勘所
iwatatomoya
1
3k
Other Decks in Technology
See All in Technology
0→1事業こそPMは営業すべし / pmconf #落選お披露目 / PM should do sales in zero to one
roki_n_
PRO
1
920
ドメイン駆動設計の実践により事業の成長スピードと保守性を両立するショッピングクーポン
lycorptech_jp
PRO
6
710
Docker Desktop で Docker を始めよう
zembutsu
PRO
0
140
PaaSの歴史と、 アプリケーションプラットフォームのこれから
jacopen
7
1.2k
実践! ソフトウェアエンジニアリングの価値の計測 ── Effort、Output、Outcome、Impact
nomuson
0
2k
「隙間家具OSS」に至る道/Fujiwara Tech Conference 2025
fujiwara3
6
6.3k
2025年の挑戦 コーポレートエンジニアの技術広報/techpr5
nishiuma
0
140
AWSサービスアップデート 2024/12 Part3
nrinetcom
PRO
0
140
Copilotの力を実感!3ヶ月間の生成AI研修の試行錯誤&成功事例をご紹介。果たして得たものとは・・?
ktc_shiori
0
330
Reactフレームワークプロダクトを モバイルアプリにして、もっと便利に。 ユーザに価値を届けよう。/React Framework with Capacitor
rdlabo
0
110
信頼されるためにやったこと、 やらなかったこと。/What we did to be trusted, What we did not do.
bitkey
PRO
0
2.1k
AWSの生成AIサービス Amazon Bedrock入門!(2025年1月版)
minorun365
PRO
7
460
Featured
See All Featured
How GitHub (no longer) Works
holman
312
140k
Into the Great Unknown - MozCon
thekraken
34
1.6k
Done Done
chrislema
182
16k
Scaling GitHub
holman
459
140k
Speed Design
sergeychernyshev
25
730
The World Runs on Bad Software
bkeepers
PRO
66
11k
Raft: Consensus for Rubyists
vanstee
137
6.7k
Designing Experiences People Love
moore
139
23k
GitHub's CSS Performance
jonrohan
1030
460k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
230
52k
Why Our Code Smells
bkeepers
PRO
335
57k
Rebuilding a faster, lazier Slack
samanthasiow
79
8.8k
Transcript
RDS Proxyは世界を変えるか︖ 2020年6⽉26⽇ CX事業本部 岩⽥ 智哉
⾃⼰紹介 CX事業本部 ⻄⽇本チーム サーバーサイドエンジニア 2020 Japan APN Ambassadors 2020 APN
ALL AWS Certifications Engineer 岩⽥ 智哉 2
⼤事なこと 資料作成時点でRDS Proxyは まだGAされていません なのでRDS Proxy⾃体の話はあまりしません…
2020年は サーバーレス元年︖
直近1年間でのLambda関連アップデート •VPC Lambdaのアーキテクチャ改善 •Lambda Destinations •並列化係数のサポート •Provisioned Concurrency •RDS Proxy(まだプレビュー)
•EFS統合(NEW!!) 5
Lambda×RDBはアンチパターン︖︖ •コールドスタートの問題 •IPアドレスやENIの枯渇問題 •スケールアップとスケールアウト の相性問題 6
Lambda×RDBはアンチパターン︖︖ •コールドスタートの問題 •IPアドレスやENIの枯渇問題 •スケールアップとスケールアウトの 相性問題 7
LambdaとRDSの ミスマッチを緩和する技術として RDS Proxyに期待
そもそもコネクションプーリングとは︖ プログラムがデータベース管理システム(DBMS) へアクセスする際、アクセス要求のたびに接続や 切断を繰り返すのではなく、⼀度形成した 接続窓⼝(コネクション)を維持し続けて 使い回す⼿法。[1] [1]:IT⽤語辞典 e-Words より引⽤ http://e-words.jp/w/コネクションプーリング
9
• 各プログラミング⾔語のライブラリ アプリでプーリング • アプリとDBの間にプロキシを挟む • Ex)Pgpool-II,PgBouncer… ミドルウェアでプーリング コネクションプーリングざっくり分類 10
アプリでプーリングするパターン コネクションプール connection worker worker connection connection worker connection Users
Application Database 11
ミドルウェアでプーリングするパターン コネクションプール connection worker worker worker connection connection Users Application
Database Middle ware 12
コネクションプーリングのメリット •接続のオーバーヘッド削減 •論理的接続と物理的接続の分離 13
接続の オーバーヘッド削減
コネクションプーリング 無い時
コネクションプーリングが無い時 16
コネクションプーリングが無い時 リクエスト 17
コネクションプーリングが無い時 接続要求 • TCPの3WAYハンドシェイク • DBユーザーの認証/認可 • …etc 18
コネクションプーリングが無い時 接続確⽴ 19
コネクションプーリングが無い時 SQL 20
コネクションプーリングが無い時 切断 21
コネクションプーリングが無い時 レスポンス 22
コネクションプーリングが無い時 最初に戻る 23
コネクションプーリング ある時
コネクションプーリングがある時 未使⽤ 使⽤中 25
コネクションプーリングがある時 未使⽤ 使⽤中 接続 26
コネクションプーリングがある時 未使⽤ 使⽤中 connection プーリング 27
コネクションプーリングがある時 未使⽤ 使⽤中 connection リクエスト 28
コネクションプーリングがある時 未使⽤ 使⽤中 connection プール済のコネクションを チェックアウトして利⽤ SQL 29
コネクションプーリングがある時 未使⽤ 使⽤中 connection 使⽤済みのコネクションは プールの未使⽤領域に戻る レスポンス 30
論理的接続と 物理的接続の分断
コネクションプーリング ある時
コネクションプーリングがある時 物理 論理 connection リクエスト 33
コネクションプーリングがある時 物理 論理 connection connection 接続 34
コネクションプーリングがある時 物理 論理 SQL connection connection 35
コネクションプーリングがある時 物理 論理 connection connection DBアクセスを 伴わない処理 36
コネクションプーリングがある時 物理 論理 connection connection リクエスト 37
コネクションプーリングがある時 物理 論理 connection connection connection 接続 38
コネクションプーリングがある時 物理 論理 connection SQL connection connection 39
コネクションプーリングがある時 物理 論理 connection connection connection DBアクセスを 伴わない処理 40
コネクションプーリングがある時 物理 論理 connection connection レスポンス 41
コネクションプーリングがある時 物理 論理 connection レスポンス 42
スパイク耐性の向上
コネクションプーリング 無い時
コネクションプーリングのメリット 25 30 35 40 45 50 55 60 リクエスト数
接続エラー コネクションプーリングを使わない場合 最⼤同時接続数を超過した接続要求はエラー 45
コネクションプーリングが無い時 46
コネクションプーリングが無い時 リクエスト 47
コネクションプーリングが無い時 接続要求 48
コネクションプーリングが無い時 接続確⽴ connection 49
コネクションプーリングが無い時 リクエスト connection 50
コネクションプーリングが無い時 接続要求 connection 51
コネクションプーリングが無い時 最⼤同時接続数超過エラー connection 52
コネクションプーリングが無い時 DB接続エラー connection 53
コネクションプーリング ある時 コネクションプーリング ある時
コネクションプーリングのメリット プーリングレイヤがDBへの流量を制御 25 30 35 40 45 50 55 60
プールへのリクエスト数 DBへのリクエスト数 55
コネクションプーリングがある時 物理 論理 connection リクエスト 56
コネクションプーリングがある時 物理 論理 connection connection 接続 57
コネクションプーリングがある時 物理 論理 SQL connection connection 58
コネクションプーリングがある時 物理 論理 リクエスト SQL connection connection 59
コネクションプーリングがある時 物理 論理 connection 接続 SQL connection connection 60
コネクションプーリングがある時 物理 論理 connection SQL SQL connection connection 61
コネクションプーリングがある時 物理 論理 connection 利⽤可能な物理接続が無い場合はWAIT SQL SQL connection connection 62
コネクションプーリングがある時 物理 論理 connection SQL 物理接続が利⽤可能になったら処理続⾏ connection connection 63
コネクションプーリング 良い事づくめ︖︕
よく⽿にする話… Lambdaは コネクションプーリングが 使えない︖︖
Lambdaのアーキテクチャ • Lambda実⾏環境はコンテナ内に構築される • リクエストに応じてLambda実⾏環境を⽣成 • アイドル状態のLambda実⾏環境は破棄される • 1つのLambda実⾏環境に対して同時に ルーティングされるリクエストは1つだけ
66
アプリ側でプーリングしても有効活⽤されない Lambda 実⾏環境 Database Users connection worker connection Lambda 実⾏環境
connection worker connection 無駄 無駄 67
Lambdaの プログラミングモデル
Lambdaのプログラミングモデル 関数・メソッド 実⾏ ランタイム 起動・初期化 コールドスタート時、 ウォームスタート時共に毎回実⾏ コールドスタート時のみ実⾏ 69
Lambdaのプログラミングモデル 初期化処理の中でDBに接 続することで、ウォーム スタート時は接続処理を スキップ可能 ただし、接続クローズは Lambda 実⾏環境破棄の タイミングになる 70
アイドル状態の実⾏環境がコネクションを消費する Lambda Function 2 Lambda 実⾏環境 connection Lambda Function 1
Lambda 実⾏環境 connection Lambda 実⾏環境 connection Users Database 71
アイドル状態の実⾏環境がコネクションを消費する Lambda 実⾏環境 connection Lambda Function 2 Lambda 実⾏環境 connection
Lambda Function 1 Lambda 実⾏環境 connection Lambda 実⾏環境 connection Users Database 72
Lambdaにおけるコネクションプーリング • 物理的接続と論理的接続を分割するメリットが薄い • 接続を永続化することに懸念事項が多い アプリでプーリング • ⾃前でEC2を⽴てるほどのメリットがあるのか︖ • サーバーレスとは︖
ミドルウェアでプーリング 73
Lambdaはコネクショ ンプーリングを活⽤ しづらい
と思いきや… re:invent2019にて RDS Proxy発表
RDSプロキシとは • RDS向けのフルマネージドなDBプロキシ • MySQLとPostgreSQLに対応(Aurora含む) • IAM認証にも対応 76
77 RDSプロキシのメリット •⼀般的なコネクションプーリングと 同様のメリット •フルマネージド •負荷に応じて⾃動的にスケール •フェイルオーバー時間の短縮
78 RDSプロキシのデメリット •料⾦が増える •5ms程度のレイテンシ増加 •障害点が増える
RDSプロキシの料⾦体系 •基となるデータベースインスタンス のvCPU数に応じて課⾦ •0.018USD/時間 ※2020/6時点の東京リージョンにおける料⾦体系 79
RDSプロキシが向いている ワークロード
RDSプロキシが向いているワークロード • DBアクセスを伴わない処理が 多くの割合を占める場合 • トランザクションを使⽤しない 場合 81
RDSプロキシが不向きな ワークロード
RDSプロキシが不向きなワークロード • DBアクセスを伴う処理が 多くの割合を占める場合 • ロングトランザクション • リクエストが多すぎる場合 • 「ピン留め」を誘発するよう
なワークロード 83
RDSプロキシが無意味なパターン 25 30 35 40 45 50 55 60 リクエスト数
接続エラー DBスペックに対してリクエスト数が 多すぎる場合はどうしようもない 84
ロングトランザクション 物理 論理 BEGIN connection connection 85
ロングトランザクション 物理 論理 connection connection Idle in transaction 86
ロングトランザクション 物理 論理 リクエスト connection connection Idle in transaction 87
ロングトランザクション 物理 論理 connection SQL connection connection Idle in transaction
88
ロングトランザクション 物理 論理 connection SQL connection connection Idle in transaction
connection 89
ピン留め • プールされた接続が特定のクライアントに固定され 複数のクライアント間で共有できない状況 • クライアントからのリクエストによりDBセッション 固有の情報が変更された場合、以後のリクエストは 変更後の状態に依存するため発⽣ 90
ピン留めが発⽣する場合 物理 論理 SET WORK_MEM=‘1MB’ connection connection WORK_MEM=‘2MB’ 91
ピン留めが発⽣する場合 物理 論理 connection connection connection WORK_MEM=‘1MB’ リクエスト 92
ピン留めが発⽣する場合 物理 論理 connection connection connection connection WORK_MEM=‘1MB’ WORK_MEM=‘2MB’ パラメータが更新されており、再利⽤できない
93
ピン留めが発⽣するケース https://docs.aws.amazon.com/ja_jp/AmazonRDS/latest/AuroraUserGuide/rds-proxy.html#rds-proxy-pinning Amazon RDS Proxy (プレビュー) による接続の管理 ピン留めを回避する • ⼀時テーブルを作成した場合
• プリペアドステートメント • 拡張クエリプロトコルの使⽤(PostgreSQLの場合) …etc 94
RDSプロキシ以外の 選択肢は無いのか︖
RDS Proxy以外に検討したいポイント •DBエンジンは適切なのか︖ •RDBという選択肢は適切なのか︖ •そもそもLambdaは適切なのか︖ 96
まとめ まとめ
98 まとめ RDS ProxyによってLambdaとRDSの相性の 悪さを緩和することができる。 緩和はあくまで緩和 まずはDynamoDBから検討したい
99 まとめ • RDS Proxyが有効に機能するかは ワークロードに依存 • 思考停⽌的に導⼊するのではなく 事前分析と検証を •
場合によってはアプリの改修も
None