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
Graphite 1.0-ish
Search
Jason Dixon
November 30, 2016
Programming
0
340
Graphite 1.0-ish
Jason Dixon
November 30, 2016
Tweet
Share
More Decks by Jason Dixon
See All by Jason Dixon
Monitorama PDX 2015 - Closing Plenary
obfuscurity
1
440
Stupid Graphite Tips
obfuscurity
37
4.8k
The State of Open-Source Monitoring
obfuscurity
146
49k
Trending with Purpose
obfuscurity
11
1.3k
Other Decks in Programming
See All in Programming
HTML/CSS超絶浅い説明
yuki0329
0
190
毎日13時間もかかるバッチ処理をたった3日で60%短縮するためにやったこと
sho_ssk_
1
550
混沌とした例外処理とエラー監視に秩序をもたらす
morihirok
13
2.3k
Scaling your build logic
antalmonori
1
100
生成AIでGitHubソースコード取得して仕様書を作成
shukob
0
630
アクターシステムに頼らずEvent Sourcingする方法について
j5ik2o
6
700
月刊 競技プログラミングをお仕事に役立てるには
terryu16
1
1.2k
ATDDで素早く安定した デリバリを実現しよう!
tonnsama
1
1.9k
「とりあえず動く」コードはよい、「読みやすい」コードはもっとよい / Code that 'just works' is good, but code that is 'readable' is even better.
mkmk884
6
1.4k
EC2からECSへ 念願のコンテナ移行と巨大レガシーPHPアプリケーションの再構築
sumiyae
3
590
どうして手を動かすよりもチーム内のコードレビューを優先するべきなのか
okashoi
3
870
Rubyでつくるパケットキャプチャツール
ydah
0
170
Featured
See All Featured
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
226
22k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
33
2k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
7
570
Visualization
eitanlees
146
15k
What’s in a name? Adding method to the madness
productmarketing
PRO
22
3.2k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
98
18k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
45
2.3k
Designing on Purpose - Digital PM Summit 2013
jponch
116
7.1k
Learning to Love Humans: Emotional Interface Design
aarron
274
40k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
232
17k
Large-scale JavaScript Application Architecture
addyosmani
510
110k
Imperfection Machines: The Place of Print at Facebook
scottboms
267
13k
Transcript
The Launch of Graphite 1.0-ish aka the cage match between
0.9.x and 0.10.0
what is graphite?
None
None
None
None
how did we get here?
None
http://www.aosabook.org/en/ graphite.html
None
the changing tsdb landscape
the not-so-secret secret about tsdb’s
the future now of graphite
not 0.9.x
but I love 0.9.x
ok, so what now?
live demo
highlights
pluggable storage finders • standard (whisper, rrd) • ceres •
Cyanite (external, Cassandra-based) • KairosDB (external) • OpenTSDB (external) • < your custom finder here >
pluggable carbon protocols
zomg so much test coverage special thanks to @brutasse @cbowman0
improved brace expansion and globstar support
None
improved unicode, timezone, and special char support throughout
updated requirements • Python 2.7 • Django 1.9 (graphite-web) •
Twisted 13.2+ (carbon)
new (optional) components • Carbonate (rebalancing suite) • Ceres (experimental
tsdb)
zomg new functions
None
aggregateLine
avg min max
applyByNode
i tried i really did but you should just go
read the applyByNode function docs because omg i can’t even
averageOutsidePercentile
None
delay
None
fallbackSeries
fallbackSeries(foo.requests, constantLine(0))
grep
None
groupByNodes
groupByNodes(app.server*.*.reqs.*, "sumSeries",1,4)
integralByInterval
None
interpolate
sorta behaves like lineMode=connected except it also supports a limit
arg for how many null values to interpolate over
invert
None
None
isNonNull
None
linearRegression
None
linearRegressionAnalysis
None
mapSeries reduceSeries
map and reduce, nbd (again, rtd)
multiplySeriesWithWildcards
just like the other *SeriesWithWildcards functions but more fun, because
multiplication
offsetToZero
basically treats the lowest value in a series as the
floor and subtracts that from all values in the series
None
zomg are we done yet
pow
power(foo.bar, 10) factor
removeBetweenPercentile
only render series that have a value outside the Nth
percentile of all values within an interval
None
removeEmptySeries
None
sortByTotal
sort series by the sum of their total values
squareRoot
None
timeSlice
used to limit values to a specific set of intervals
within the larger time range, e.g. when you’re interested in a contiguous span across disparate metrics
None
verticalLine
verticalLine("-1h")
weightedAverage
None
zomg new display formats
pdf
None
width=2000&height=800 format=pdf
None
dygraph
rickshaw
no surprises, work as intended, useful for quick prototyping with
their respective frameworks
zomg new graph options
hideNullFromLegend
hideXAxis
noNullPoints (format=json)
pieLabels valueLabels valueLabelsColor valueLabelsMin
None
anything else because we still have some time left on
the clock I think?
live demo
new logo
None
zomg new settings
INTRACLUSTER_HTTPS
MAX_TAG_LENGTH
DATE_FORMAT
WHISPER_FADVISE_RANDOM
MAX_RECEIVER_CONNECTIONS
ok I think that’s all but if we have time
left I guess I can answer questions or rant about Trump or whatever
thank you