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
Instrumenting Application Stack in Dynamically Scaling Environment
Search
Mike Fiedler
November 15, 2013
Technology
0
47
Instrumenting Application Stack in Dynamically Scaling Environment
DMG212 AWS re:Invent 2013
Mike Fiedler
November 15, 2013
Tweet
Share
More Decks by Mike Fiedler
See All by Mike Fiedler
Fixing AWS with AWS
miketheman
1
120
HOW DO YOU KNOW iT'S WORKiNG
miketheman
0
87
Giving (and Taking) Back
miketheman
0
52
Where Do We Go From Here?
miketheman
0
100
What's In This Cookbook?
miketheman
0
47
Treating Your Infrastructure Like Garbage
miketheman
2
1.7k
MongoDB - Operations Best Practices
miketheman
1
110
MongoDB in the Cloud - Amazon Web Services
miketheman
3
97
Other Decks in Technology
See All in Technology
リテール金融(キャッシュレス・ネット銀行・ネット証券)の競争環境と経済圏
8maki
0
1.2k
AWSに詳しくない人でも始められるコスト最適化ガイド
yuhta28
1
250
Google Cloud の AI を支える裏側のインフラを垣間見る!
maroon1st
0
360
Gitlab本から学んだこと - そーだいなるプレイバック / gitlab-book
soudai
4
440
ServiceNow Knowledge Learning Rise up
manarobot
0
210
非同期推論システムによるコスト削減と信頼性向上
koki_nishihara
0
260
Além do else! Categorizando Pokemóns com Pattern Matching no JavaScript
wmsbill
0
640
20240418_Google ColabにLLMが搭載されたようなのでPython x データ分析の勉強方法を考えてみる
doradora09
0
140
今年のRubyKaigiはProfiler Year🤘
osyoyu
0
170
私が trocco を推す理由
__allllllllez__
1
250
VS CodeでAWSを操作しよう
smt7174
8
1.7k
MLOpsの「壁」を乗り越える、LINEヤフーの Data Quality as Code
lycorptech_jp
PRO
5
530
Featured
See All Featured
The Power of CSS Pseudo Elements
geoffreycrofte
60
5k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
21
1.6k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
34
8.9k
How STYLIGHT went responsive
nonsquared
92
4.8k
A better future with KSS
kneath
231
16k
The Cost Of JavaScript in 2023
addyosmani
16
3.9k
GraphQLとの向き合い方2022年版
quramy
32
12k
Building Better People: How to give real-time feedback that sticks.
wjessup
355
18k
Fantastic passwords and where to find them - at NoRuKo
philnash
37
2.5k
Infographics Made Easy
chrislema
238
18k
Navigating Team Friction
lara
178
13k
Six Lessons from altMBA
skipperchong
21
3k
Transcript
Instrumenting your Application Stack in a Dynamically Scaling Environment Mike
Fiedler, Datadog November 15, 2013
The Past • Server uptime • Intertwined applications • SPOFs
The Present • SOA • Scale or Fail • Data-driven
decisions
Modern application stack User LB Web Data
Failure is inevitable
Design to tolerate failure
Things that produce metrics business/service Services • applicatio n •
OS • instances API-based • S3, S*S • RDS, RedShift • etc Users • RUM
The Desire
CPU comparison (hypervisor)
CPU comparison (Agent)
My Stack • HAProxy • Apache HTTP • Bottle.py –
Custom python webapp • MongoDB • EC2 • Chef • Datadog • Users
Tracking Database operations
Moving up the stack…
Even higher…
Using metadata for more flavor
Replace an instance, keep the metrics
Enter…
Aggregating numbers
Comparing numbers
My App from bottle import route import pymongo import json
db = pymongo.Connection('mongodb://localhost').test @route('/insert/:name') def insert(name): doc = {'name': name} db.words.update(doc, {"$inc":{"count": 1}}, upsert=True) return json.dumps(doc, default=default)
Add 2 lines and you win! from bottle import route
import pymongo import json from statsd import statsd db = pymongo.Connection('mongodb://localhost').test @route('/insert/:name') @statsd.increment('fullstack.insert') def insert(name): doc = {'name': name} db.words.update(doc, {"$inc":{"count": 1}}, upsert=True) return json.dumps(doc, default=default)
Profit!
Correlation
Don’t be caught unaware
None
Questions Time!
We are sincerely eager to hear your feedback on this
presentation and on re:Invent. Please fill out an evaluation form when you have a chance.