Upgrade to Pro — share decks privately, control downloads, hide ads and more …

introduction-lambda-rust

 introduction-lambda-rust

Avatar for Junki Ishigaki

Junki Ishigaki

February 27, 2026
Tweet

More Decks by Junki Ishigaki

Other Decks in Technology

Transcript

  1. 石垣潤樹 / Junki Ishigaki - 所属 → 株式会社シーズ - やっていること

    → インフラエンジニア - やっていること → AWSとかさわってます - 好きなAWSサービス → S3 - Community - JAWS-UG Kyoto - Platform Engineering Kaigi(PEK) 2 社内で使ってるアイコン x.com/tokyo_jjjx 自己紹介 クラウドネイティブ会議 やります@名古屋 2026/5/14-15 https://kaigi.cloudnativedays.jp/ 「人呼んでjun」
  2. re:Invent2025にて - [DEV405] Compile blazing-fast MCP servers in Rust -

    MCP サーバーってPythonだったりTypeScriptだったりするけどRustで爆速の やつ作ろうぜ的なセッション(CodeTalk) - https://www.youtube.com/watch?v=mr7ZuLRxXzA - [DEV307] Unleash Rust's potential on AWS - Rustいいよ的なBreakoutSession - AWS内部のデータプレーンはデフォルトRust - https://www.youtube.com/watch?v=buBBQ5mXAi8 6 IAM Auto Pilot(IAMポリシー生成用のMCP Server)もそういえばRustで書かれてますね
  3. cargo lambda 9 - Rust製Lambda関数の開発・デプロイを効率化するCLIツール。 ## プロジェクト作成 ## HTTP Lambda関数のテンプレートを生成

    cargo lambda new hello-rust --http ## ビルド ## provided.al2023ランタイム用のネイティブバイナリ(bootstrap)を生成。約1分。 cargo lambda build --release
  4. cargo lambda 10 ## ローカルテスト ## ローカルでLambda環境をエミュレート。コード変更時は自動リビルド。 # ターミナル1: エミュレータ起動

    cargo lambda watch # ターミナル2: 関数呼び出し # カスタムペイロード cargo lambda invoke --data-ascii '{"queryStringParameters": {"name": "Rust"}}' 開発者体験◦
  5. cargo lambda 11 ## AWSへデプロイ ## 説明: IAMロール自動作成、zipアップロード、Lambda関数作成を一発実行。開発用 途に便利。 cargo

    lambda deploy ## リモートテスト ## 説明: デプロイ済みのLambda関数をAWS上で直接実行。 cargo lambda invoke --remote hello-rust --data-example apigw-request
  6. cargo lambda -> cargo-lambda-cdk 12 - なるほど - 開発はできそう、deployはあんまり使えなそう -

    勝手にIAMロールできたり - 消すときどうする?? - CI/CDに組み込みにくい - とか - deployはCDKで - cargo-lambda-cdk - carg-lambdaをラッピングしたCDKコンストラクト(L2) import { RustFunction } from 'cargo-lambda-cdk'; const myFunction = new RustFunction(this, 'MyFunction', { manifestPath: './lambda/my-function', runtime: 'provided.al2023', }); cdk deploy時に勝手にbuildして deployしてくれる
  7. 例えば 13 - 社内でちょっとしたAPI Server実装したいとか - 1時間もあればできそう(できた) Lambda Web Adapter+

    Axumでモノリシックな API Serverとか API Gateway ↓ すべてのリクエスト Lambda (Axum) ├── /health ├── /users └── /products
  8. - Lambda Web Adapterなんぞや? - Lambda Web Adapter気になるって人向け 参考 14

    https://speakerdeck.com/junkishigaki/impressions-trying-lambda-web-adapter
  9. パフォーマンスみてみる 15 ### フィボナッチ数列(再帰実装) fib(0) = 0 fib(1) = 1

    fib(n) = fib(n-1) + fib(n-2) 数列の例: 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55... - RustとNode.jsでLambda関数を実装 - 同じ処理でパフォーマンスを比較 - 処理速度・コールドスタート・ウォームスタートを測定
  10. こんな感じの 16 Rust: rust fn fibonacci(n: u32) -> u64 {

    match n { 0 => 0, 1 => 1, _ => fibonacci(n - 1) + fibonacci(n - 2), } } Node.js: typescript function fibonacci(n: number): number { if (n === 0) return 0; if (n === 1) return 1; return fibonacci(n - 1) + fibonacci(n - 2); }
  11. 結果 17 > ## 処理時間の測定結果(5回) | 回数 | Rust (ms)

    | Node.js (ms) | 速度比 | |------|-----------|--------------|--------| | 1回目 | 542 | 1823 | 3.4倍 | | 2回目 | 579 | 1807 | 3.1倍 | | 3回目 | 574 | 1806 | 3.1倍 | | 4回目 | 526 | 1798 | 3.4倍 | | 5回目 | 578 | 1814 | 3.1倍 | | 平均 | 560 | 1810 | 3.2倍 | ## コールドスタート測定結果 | 言語 | 全体応答時間 | 処理時間 | 初期化オーバーヘッド | |------|-------------|----------|---------------------| | Rust | 1.05秒 | 0.57秒 | +0.48秒 | | Node.js | 2.73秒 | 2.10秒 | +0.63秒 | | 差 | 1.68秒 | 1.53秒 | 0.15秒 | ※ フィボナッチ数列 n=35(再帰実装、約2900万回の関数呼び出し)
  12. まとめ 18 - cargo-lambdaの開発者体験よき - 触っていて体験がいいというのは大事 - ツール類の充実はその技術が盛り上がっていく上で大事 - CDK統合もサクッとできるのよき

    - サクッとBuildしてDeployできたりするのはCDKのよさ(コンストラクトあり がたや〜) - Lambda Web Adapter + AxumとかでモノリシックAPI Serverとかはすぐ作れそう (作れた) - サクッとできるのは入門編としてうれしい - Rustやっぱりいいすね...RustのLambdaもいいすね!!