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
Lambdaって課金されるの?〜非同期処理でちょっとやらかした話 /jawsug_bgnr_c...
Search
Kenichiro Wada
April 16, 2021
Technology
0
48
Lambdaって課金されるの?〜非同期処理でちょっとやらかした話 /jawsug_bgnr_chiba_lt
JAWS-UG 初心者支部&千葉支部 #26 - 新人さん歓迎!ハンズオン<(オンライン) -
Kenichiro Wada
April 16, 2021
Tweet
Share
More Decks by Kenichiro Wada
See All by Kenichiro Wada
My First Impression Of Kiro / 20250801-kumoben-lt
kwada
0
94
(全日本人)待望のS3トリガーのLambda無限ループ対応について / chibaraki-1
kwada
0
170
AWS Lambdaに出会って人生が変わった1人の10年間 /awslambda10th
kwada
0
110
GPSデバイスを使った簡易位置案内システムの構築をしてみた話。/jawsfesta2024
kwada
0
930
とある航空会社の飛行機の乗り方をお教えします。/20240913-lt
kwada
3
350
Building a Simple Navigation Guide Service Using GPS Devices/jaws-pankration2024
kwada
0
140
IaCジェネレーターを使って、昔に作ったLambda関数をCDK管理下においてみた / jaws-ug-josys-30
kwada
0
150
SORACOM UG Explorer 2023ハンズオンの裏側サービスを紹介 / soracom-ug-online-17
kwada
0
360
(2023.08.17 Update)Detecting and stopping recursive loops in AWS Lambda functionsでAWS Lambdaの無限ループを防ぐ! / jaws-ug-shizuoka
kwada
0
260
Other Decks in Technology
See All in Technology
Strands Agents × インタリーブ思考 で変わるAIエージェント設計 / Strands Agents x Interleaved Thinking AI Agents
takanorig
6
2.4k
ルネサンス開発者を育てる 1on1支援AIエージェント
yusukeshimizu
0
120
Building Serverless AI Memory with Mastra × AWS
vvatanabe
1
800
Oracle Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
2
510
Claude Skillsの テスト業務での活用事例
moritamasami
1
120
AWS Lambda durable functions を使って AWS Lambda の15分の壁を超えてみよう
matsuzawatakeshi
0
110
戰略轉變:從建構 AI 代理人到發展可擴展的技能生態系統
appleboy
0
170
202512_AIoT.pdf
iotcomjpadmin
0
160
Introduce marp-ai-slide-generator
itarutomy
0
150
Kiro を用いたペアプロのススメ
taikis
4
2.1k
松尾研LLM講座2025 応用編Day3「軽量化」 講義資料
aratako
14
4.7k
M&Aで拡大し続けるGENDAのデータ活用を促すためのDatabricks権限管理 / AEON TECH HUB #22
genda
0
300
Featured
See All Featured
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.6k
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
0
2.2k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
21k
Exploring anti-patterns in Rails
aemeredith
2
210
AI Search: Implications for SEO and How to Move Forward - #ShenzhenSEOConference
aleyda
1
1k
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
39
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
170
How To Stay Up To Date on Web Technology
chriscoyier
791
250k
Hiding What from Whom? A Critical Review of the History of Programming languages for Music
tomoyanonymous
0
320
Technical Leadership for Architectural Decision Making
baasie
0
190
Test your architecture with Archunit
thirion
1
2.1k
Transcript
+"846(ॳ৺ऀࢧ෦ˍઍ༿ࢧ෦ ৽ਓ͞ΜܴʂϋϯζΦϯ-5 ΦϯϥΠϯ -BNCEBͬͯ՝ۚ͞ΕΔͷʁʙඇಉظॲཧͰ ͪΐͬͱΒ͔ͨ͠
ࣗݾհ ・和⽥ 健⼀郎 ・アイレット株式会社所属 ・ JAWS-UG 千葉⽀部運営 ・普段は、社内ツールの開発に従事 ・趣味で開発する(IoTっぽいこと)時はLambdaメイン ・好きなAWSサービスはAWS
Lambda Twitter : @Keni_W Qiita: https://qiita.com/keni_w
Lambdaって課⾦されるの?
-BNCEBͬͯ՝ۚ͞ΕΔͷʁ 趣味(ハンズオンとかちょっとした開発)で 利⽤している限りは、まずないです。 例)2020/03の利⽤料⾦
-BNCEBͬͯ՝ۚ͞ΕΔͷʁ ただし、 「Provisioned Concurrency」という機能を 有効にすると、その利⽤料は無料利⽤枠対象外 になります。 例)検証していた際(12⽉)の利⽤料⾦
ただし、⾮同期処理で、 やらかした場合は、 その限りではありません! -BNCEBͬͯ՝ۚ͞ΕΔͷʁ
ちょっとやらかした⼀例を、 実例を含めてお話しします。 ミスによるものなので、 基本的にはLambda、 サーバーレス怖くないですよ。 -BNCEBͬͯ՝ۚ͞ΕΔͷʁ
構成(想定) ඇಉظॲཧͰΒ͔ͨ͠ AWS Lambda Amazon CloudFront Amazon Simple Storage Service
バケットA AWS Lambda Amazon Simple Storage Service バケットB User ①ユーザーはCFn経由で、 ファイルをS3バケットA に アップロード ②S3トリガーでLambda が起動。Lambda関数内 で、バケットBにファイ ルをコピーし、元のファ イルを削除 ③バケットBでもS3トリ ガーでLambdaが起動し、 後続処理を実⾏
察しの良い⽅は、この時点で何を どう間違えたか気づくかと思いますが。。。 ඇಉظॲཧͰΒ͔ͨ͠
構成(実際) ඇಉظॲཧͰΒ͔ͨ͠ AWS Lambda Amazon CloudFront バケットB User ①ユーザーはCFn経由で、 ファイルをS3バケットA
に アップロード ②S3トリガーでLambdaが起動。 Lambda関数内で、バケットBバケットA にファイルをコピーし、元のファイルを削除 ・ ・ ・ ③S3トリガーでLambdaが起動。 Lambda関数内で、バケットBバケットA にファイルをコピーし、元のファイルを削除 ④S3トリガーでLambdaが起動。 Lambda関数内で、バケットBバケットA にファイルをコピーし、元のファイルを削除 ⑤S3トリガーでLambdaが起動。 Lambda関数内で、バケットBバケットA にファイルをコピーし、元のファイルを削除
ඇಉظॲཧͰΒ͔ͨ͠
⽬に⾶び込んできたのは、 Lambdaの実⾏数(Invocations)が 凄まじい勢いで跳ね上り、 Throttlesの値が出現する Cloudwatchのメトリクス。 そして、Slackに通知される監視システムからの アラートメッセージ。。。 ඇಉظॲཧͰΒ͔ͨ͠
ඇಉظॲཧͰΒ͔ͨ͠
いや、挫折してる暇はないんです。 ⽌めないと。。。 ඇಉظॲཧͰΒ͔ͨ͠
Lambda関数消しました ※もっといい⽌め⽅があるので後述します。 ඇಉظॲཧͰΒ͔ͨ͠
S3バケットの指定は、Lambdaの環境変数に定義して あったので、それを変えればいいんじゃ・・・? ඇಉظॲཧͰΒ͔ͨ͠
ඇಉظॲཧͰΒ͔ͨ͠
Lambdaに限らずですが、 まあ、まずは落ち着きましょう。 ඇಉظॲཧͰΒ͔ͨ͠
救いだったのは。。。 新規開発のもので、実装終わって、 さあーってLambdaデプロイして、 テストするかー。の時点だったこと (メトリクスも⾒てたので、すぐに気づけた) そういう存在だったので容赦なく捨てられたこと。 ඇಉظॲཧͰΒ͔ͨ͠
暴⾛Lambdaの⽌め⽅ですが、 コンソール上部にある「スロットリング」ボタンを押す と⽌められるそうです。 ඇಉظॲཧͰΒ͔ͨ͠
どう対策するべきか。 ※ダメなケースもあるので最適解ではないです。 ・同時実⾏数の予約を1にする。 ・Invocationsの異常値、もしくは Throttlesが発⽣時に、Clouwatch Alerm もしくはサードパーティーの監視システム で通知をあげる。 ඇಉظॲཧͰΒ͔ͨ͠
ちょっと聞いた話なんですが、 こんなケースもあるそうです。 ඇಉظॲཧͰΒ͔ͨ͠
構成(⼀部想像) ඇಉظॲཧͰΒ͔ͨ͠ AWS Lambda Amazon Simple Storage Service Bucket with
objects AWS Lambda Amazon Simple Storage Service Bucket with objects User ①ユーザーは S3バケットAに アップロード ②S3トリガーでLambda が起動。Lambda関数内 で、ファイル内のデータ を使って処理後、バケッ トBにファイルをコピー ③S3トリガーでLambda が起動。Lambda関数内 で、ファイル内のデータ を使って処理後、バケッ トCにファイルをコピー Amazon Simple Storage Service Bucket with objects AWS Lambda ④S3トリガーでLambda が起動。Lambda関数内 で、ファイル内のデータ を使って処理後、バケッ トAにファイルをコピー ⑤②と同様
1Lambdaの実⾏が淡々と繰り返される。。。 スロットリングにもならないので、エラーも起こらない。 ඇಉظॲཧͰΒ͔ͨ͠
どう対策するべきか。 聞いた時ちょっと悩みましたね。でも、以下かな? ※これまたダメなケースもあるので最適解ではないです。 ・関数のInvocationsのsum(合計)が異常値検知 して、アラートを⾶ばす。 ・BillingAlertを設定し、課⾦発⽣/想定外時 に、アラートを⾶ばす。 ඇಉظॲཧͰΒ͔ͨ͠
いずれにしろ、確かなことは、 ⼈はミスする⽣物なので、 オンプレ・EC2上で動作するアプリでも、 サーバーレスのアプリでも監視は重要ってことです。 ·ͱΊ
とはいえ、いきなり監視(しかも個⼈の場合は特に)は 難しいので、テスト実⾏して、ログ・メトリクスを⾒ま しょう! ·ͱΊ
素敵なサーバーレス開発ライフを! ·ͱΊ