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
Autoscaling in Kubernetes
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Atsushi Tanaka
September 09, 2018
Programming
1.3k
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Autoscaling in Kubernetes
Atsushi Tanaka
September 09, 2018
More Decks by Atsushi Tanaka
See All by Atsushi Tanaka
OpenCensusと歩んだ7年間
bgpat
0
650
SREだけど社内営業組織の業務改善をしてみた
bgpat
0
830
ウォンテッドリーにおける Platform Engineering
bgpat
0
760
Wantedly での Datadog 活用事例
bgpat
2
6.2k
KubernetesでDatadogを飼うならオートディスカバリーを使わないと損
bgpat
2
1.1k
マイクロサービス基盤にフルマネージドサービスではなくKubernetesを選択する理由
bgpat
12
4.5k
400万ユーザーに価値を届けるエンジニアを を支えるインフラ基盤
bgpat
3
540
Ruby製社内ツールのGo移行
bgpat
2
850
導入から5年が経って見えた Datadog APM 運用の課題
bgpat
4
1.4k
Other Decks in Programming
See All in Programming
DynamoDBには集計系のクエリがないけどなんとかしたい
musan
1
130
Spec-Driven Development with AI-Agents: From High-Level Requirements to Working Software
antonarhipov
2
470
Spec Driven Development | AI Summit Lisbon
danielsogl
PRO
0
170
Java × distroless で 軽量なコンテナイメージを / Java on Distroless
contour_gara
0
510
LLM本来の能力を解き放つサンドボックス技術とAI民主化への適用
yukukotani
3
3.2k
Language Server 使ってる? 〜VSCode と Zed の場合〜 / Are you using a Language Server? ~For VS Code and Zed~
handlename
0
770
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
17
6.2k
Webフレームワークの ベンチマークについて
yusukebe
0
140
Skillsは効率化、Agentsは"自分の拡張"——Builder時代のエージェント編成(CC Night 2026)
wemra
1
110
Technical Debt: Understanding it Rightly, Engaging it Rightly #LaravelLiveJP
shogogg
0
200
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
12k
AIチームを指揮するOSS「TAKT」活用術 / How to Use “TAKT,” an OSS Tool for Orchestrating AI Teams
nrslib
6
840
Featured
See All Featured
The Art of Programming - Codeland 2020
erikaheidi
57
14k
AI Search: Implications for SEO and How to Move Forward - #ShenzhenSEOConference
aleyda
1
1.3k
Site-Speed That Sticks
csswizardry
13
1.2k
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
200
svc-hook: hooking system calls on ARM64 by binary rewriting
retrage
2
290
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
1
280
Visual Storytelling: How to be a Superhuman Communicator
reverentgeek
2
550
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
400
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.5k
Mobile First: as difficult as doing things right
swwweet
225
10k
Transcript
©2018 Wantedly, Inc. Autoscaling in Kubernetes KubernetesͱΦʔτεέʔϧ ,VCFSOFUFT LT ษڧձ!ຊϚΠΫϩιϑτגࣜձࣾ
9.Sep.2018 - Atsushi Tanaka - @bgpat
©2018 Wantedly, Inc. • Atsushi Tanaka ాதಞࢤ • Infrastructure
Engineer at Wantedly, Inc. • Interested in k8s, Docker and Golang About @bgpat
©2018 Wantedly, Inc. Φʔτεέʔϧͷ
©2018 Wantedly, Inc. https://ja.wikipedia.org/wiki/εέʔϥϏϦςΟ "εέʔϧ"
©2018 Wantedly, Inc. https://ja.wikipedia.org/wiki/εέʔϥϏϦςΟ "εέʔϧ"
©2018 Wantedly, Inc. ෛՙʹ߹ΘͤͯࣗಈͰαʔόʔΛ֦ு͢Δ
©2018 Wantedly, Inc. w )PSJ[POUBM1PE"VUPTDBMFS w $MVTUFS"VUPTDBMFS w 7FSUJDBM1PE"VUPTDBMFS w
"EEPO3FTJ[FS KubernetesͰ͑ΔΦʔτεέʔϧ
©2018 Wantedly, Inc. w )PSJ[POUBM1PE"VUPTDBMFS w $MVTUFS"VUPTDBMFS w 7FSUJDBM1PE"VUPTDBMFS w
"EEPO3FTJ[FS KubernetesͰ͑ΔΦʔτεέʔϧ ਫฏεέʔϧ ਨεέʔϧ
©2018 Wantedly, Inc. εϖοΫ Scale Out Scale In Scale
Down Scale Up
©2018 Wantedly, Inc. w )PSJ[POUBM1PE"VUPTDBMFS w $MVTUFS"VUPTDBMFS w 7FSUJDBM1PE"VUPTDBMFS w
"EEPO3FTJ[FS KubernetesͰ͑ΔΦʔτεέʔϧ /PEF 1PE
©2018 Wantedly, Inc. w )PSJ[POUBM1PE"VUPTDBMFS )1" w $MVTUFS"VUPTDBMFS w
7FSUJDBM1PE"VUPTDBMFS w "EEPO3FTJ[FS KubernetesͰ͑ΔΦʔτεέʔϧ
©2018 Wantedly, Inc. w ϝτϦΫε͕ઃఆΛ͍͑ͯͳ͍͔ࢹ w 1PEͷΛ૿͢ݮΒ͢ EFQMPZNFOUͷSFQMJDBTͷΛมߋ ࣮ࡍʹεέʔϧΛߦ͏ͷεέδϡʔϥʔ Horizontal
Pod Autoscaler
©2018 Wantedly, Inc. /PEF /PEF /PEF Kubernetesͷεέʔϧ 1PE 4FSWJDF 1PE
1PE 1PE 1PE %FQMPZNFOU 3FQMJDB4FU Service Pod ʹରͯ͠ ϦΫΤετΛϩʔυόϥϯε͢Δ Deployment Pod ͷΛ Ұఆʹอͭ
©2018 Wantedly, Inc. εέʔϧ͢Δج४ w $16༻ͷΈ BVUPTDBMJOHW w Ϧιʔεʹඥ͘ϝτϦΫε
BVUPTDBMJOHW w Ϧιʔεʹඥ͔ͳ͍ϝτϦΫε LTW Horizontal Pod Autoscaler
©2018 Wantedly, Inc. HPA autoscaling/v1
©2018 Wantedly, Inc. HPA autoscaling/v1
©2018 Wantedly, Inc. HPA autoscaling/v1
©2018 Wantedly, Inc. HPA autoscaling/v1
©2018 Wantedly, Inc. autoscaling/v2 ෳͷϝτϦΫεΛઃఆՄೳ ͲΕ͔ͻͱͭͰᮢΛ͑Δͱεέʔϧ͢Δ • Resource: CPUɾϝϞϦ ͷ༻
• Object: Kubernetes ͕ཧ͢ΔϦιʔεͷϝτϦΫε • Pods: Pod ʹؔ͢ΔϝτϦΫε • External: Kubernetes ͷϦιʔεʹؔ࿈͠ͳ͍ϝτϦΫε Horizontal Pod Autoscaler
©2018 Wantedly, Inc. HPA autoscaling/v2
©2018 Wantedly, Inc. HPA autoscaling/v2
©2018 Wantedly, Inc. HPA autoscaling/v2
©2018 Wantedly, Inc. HPA autoscaling/v2
©2018 Wantedly, Inc. HPA autoscaling/v2
©2018 Wantedly, Inc. HPA autoscaling/v2
©2018 Wantedly, Inc. API ΛͬͯϝτϦΫεΛऔಘ͢Δ • Resource Metrics API •
Custom Metrics API • External Metrics API Horizontal Pod Autoscaler
©2018 Wantedly, Inc. • Metrics Server or Heapster • Pod
Λ Node ʹஔ͢Δͱ͖ʹΘΕΔ • औΕΔϝτϦΫε CPU ͱ ϝϞϦ ͷΈ Resource Metrics API
©2018 Wantedly, Inc. • CPU, ϝϞϦ༻ྔҎ֎ͷϝτϦΫε͕औΕΔ • API αʔόʔΛ༻ҙͯ͠Ϋϥελʹొ͠ͳ͍ͱ͍͚ͳ͍ •
Prometheus • Azure • Stackdriver Custom & External Metrics API
©2018 Wantedly, Inc. w )PSJ[POUBM1PE"VUPTDBMFS )1" w $MVTUFS"VUPTDBMFS w
7FSUJDBM1PE"VUPTDBMFS w "EEPO3FTJ[FS KubernetesͰ͑ΔΦʔτεέʔϧ
©2018 Wantedly, Inc. Pod Λεέδϡʔϧ͢ΔͨΊͷϊʔυ͕Γͳ͘ͳΔͱ ΫϥελΛߏ͢ΔϊʔυͷΛ૿͢ ରԠ͍ͯ͠Δ CloudProvider • AWS
• Azure • GCP Cluster Autoscaler
©2018 Wantedly, Inc. w )PSJ[POUBM1PE"VUPTDBMFS )1" w $MVTUFS"VUPTDBMFS w
7FSUJDBM1PE"VUPTDBMFS w "EEPO3FTJ[FS KubernetesͰ͑ΔΦʔτεέʔϧ
©2018 Wantedly, Inc. • Pod ͷਨεέʔϧ • resource.limit ͱ resource.request
Λมߋ • Node ͷεέδϡʔϦϯά࣌ʹӨڹ • ᮢࣗಈઃఆ • HPAͱͷซ༻Մೳ Vertical Pod Autoscaler
©2018 Wantedly, Inc. w )PSJ[POUBM1PE"VUPTDBMFS )1" w $MVTUFS"VUPTDBMFS w
7FSUJDBM1PE"VUPTDBMFS w "EEPO3FTJ[FS KubernetesͰ͑ΔΦʔτεέʔϧ
©2018 Wantedly, Inc. • Pod ͷதʹϦιʔεΛࢹ͢ΔίϯςφΛཱͯͯ (sidecar) ༻ྔʹ߹Θͤͯཁٻ͢ΔϦιʔεΛ૿ݮͤ͞Δ • ૿ݮ͢Δྔϊʔυͷʹґଘ
• ΫϥελΛߏ͢Δίϯϙʔωϯτʹ༻͍ΒΕ͍ͯΔ • cluster-autoscaler • metrics-server Addon Resizer
©2018 Wantedly, Inc. ͔͜͜Βࣄྫհ
©2018 Wantedly, Inc. • kops Ͱ AWS ্ʹߏங • ϊʔυ:
40 • αʔϏε: 70ݸ • ΞϓϦέʔγϣϯͷ࣮ • Ruby on Rails • Goݴޠ • Python (ػցֶश) • C++, Rust (ը૾ॲཧ) WantedlyͷKubernetesΫϥελ
©2018 Wantedly, Inc. • HPA + Custom Metrics • Prometheus
• k8s-prometheus-adapter • Prometheus Operator • nginx-exporter • Cluster Autoscaler WantedlyͰ͍ͬͯΔΦʔτεέʔϧ
©2018 Wantedly, Inc. 1SPNFUIFVT 1SPNFUIFVT 1PE 1PE HPA + Custom
Metrics ͷߏ .BTUFS/PEF $VTUPN.FUSJDT "1*4FSWFS ,VCFSOFUFT "1*4FSWFS 1PE "QQMJDBUJPO /HJOY OHJOY FYQPSUFS proxy )1" metrics proxy stub_status 1SPNFUIFVT 1SPNFUIFVT 0QFSBUPS manage metrics %FQMPZNFOU scale 3FQMJDB4FU manage manage metrics
©2018 Wantedly, Inc. 1SPNFUIFVT 1SPNFUIFVT 1PE 1PE HPA + Custom
Metrics ͷߏ .BTUFS/PEF $VTUPN.FUSJDT "1*4FSWFS ,VCFSOFUFT "1*4FSWFS 1PE "QQMJDBUJPO /HJOY OHJOY FYQPSUFS proxy )1" metrics proxy stub_status 1SPNFUIFVT 1SPNFUIFVT 0QFSBUPS manage metrics %FQMPZNFOU scale 3FQMJDB4FU metrics manage manage
©2018 Wantedly, Inc. Prometheus Operator https://coreos.com/operators/prometheus/docs/latest/user-guides/getting-started.html
©2018 Wantedly, Inc. Prometheus Operator apiVersion: monitoring.coreos.com/v1 kind: ServiceMonitor metadata:
name: service-monitor namespace: custom-metrics labels: service-monitor: prometheus spec: selector: matchLabels: custom-metrics: prometheus namespaceSelector: any: true endpoints: - port: http - port: https custom-metrics: prometheus ͷϥϕϧ͕͍͍ͯΔαʔϏε Λࢹ
©2018 Wantedly, Inc. 1SPNFUIFVT 1SPNFUIFVT 1PE 1PE HPA + Custom
Metrics ͷߏ .BTUFS/PEF $VTUPN.FUSJDT "1*4FSWFS ,VCFSOFUFT "1*4FSWFS 1PE "QQMJDBUJPO /HJOY OHJOY FYQPSUFS proxy )1" metrics proxy stub_status 1SPNFUIFVT 1SPNFUIFVT 0QFSBUPS manage metrics %FQMPZNFOU scale 3FQMJDB4FU metrics manage manage
©2018 Wantedly, Inc. Nginxͷstub_status location /basic_status { stub_status; } Active
connections: 291 server accepts handled requests 16630948 16630948 31070465 Reading: 6 Writing: 179 Waiting: 106 ͪίωΫγϣϯΛ͏
©2018 Wantedly, Inc. Active connections: 291 server accepts handled requests
16630948 16630948 31070465 Reading: 6 Writing: 179 Waiting: 106 nginx-exporter # HELP nginx_connections_current Number of connections currently processed by nginx # TYPE nginx_connections_current gauge nginx_connections_current{state="active"} 2 nginx_connections_current{state="reading"} 0 nginx_connections_current{state="waiting"} 1 nginx_connections_current{state="writing"} 1
©2018 Wantedly, Inc. 1SPNFUIFVT 1SPNFUIFVT 1PE 1PE HPA + Custom
Metrics ͷߏ .BTUFS/PEF $VTUPN.FUSJDT "1*4FSWFS ,VCFSOFUFT "1*4FSWFS 1PE "QQMJDBUJPO /HJOY OHJOY FYQPSUFS proxy )1" metrics proxy stub_status 1SPNFUIFVT 1SPNFUIFVT 0QFSBUPS manage metrics %FQMPZNFOU scale 3FQMJDB4FU metrics manage manage
©2018 Wantedly, Inc. 1SPNFUIFVT 1SPNFUIFVT 1PE 1PE HPA + Custom
Metrics ͷߏ .BTUFS/PEF $VTUPN.FUSJDT "1*4FSWFS ,VCFSOFUFT "1*4FSWFS 1PE "QQMJDBUJPO /HJOY OHJOY FYQPSUFS proxy )1" metrics proxy stub_status 1SPNFUIFVT 1SPNFUIFVT 0QFSBUPS manage metrics %FQMPZNFOU scale 3FQMJDB4FU create create metrics
©2018 Wantedly, Inc. 1SPNFUIFVT 1SPNFUIFVT 1PE 1PE HPA + Custom
Metrics ͷߏ .BTUFS/PEF $VTUPN.FUSJDT "1*4FSWFS ,VCFSOFUFT "1*4FSWFS 1PE "QQMJDBUJPO /HJOY OHJOY FYQPSUFS proxy )1" metrics proxy stub_status 1SPNFUIFVT 1SPNFUIFVT 0QFSBUPS manage metrics %FQMPZNFOU scale 3FQMJDB4FU metrics manage manage
©2018 Wantedly, Inc. HPA apiVersion: autoscaling/v2beta1 kind: HorizontalPodAutoscaler metadata: name:
wantedly spec: maxReplicas: 50 minReplicas: 20 scaleTargetRef: apiVersion: apps/v1 kind: Deployment name: wantedly metrics: - type: Resource resource: name: cpu targetAverageUtilization: 50 - type: Pods pods: metricName: nginx_connections_current{state="writing"} targetAverageValue: 2.5 CPU ͱ Nginx ͷ ͪίωΫγϣϯͰεέʔϧ
©2018 Wantedly, Inc. ΦʔτεέʔϧͱϦΫΤετ
©2018 Wantedly, Inc. ΦʔτεέʔϧͱϦΫΤετ
©2018 Wantedly, Inc. • αʔόʔͷίετ͕͑ΒΕͨ • EC2 30 → Pod
20 (EC2 7) • εύΠΫʹڧ͘ͳͬͨ(ؾ͕͢Δ) • Ξϥʔτ͕ݮͬͨ • ᮢܾΊ͕େม • ௨ৗ࣌ʹΪϦΪϦεέʔϧ͠ͳ͍Λ୳͢ KubernetesͷΦʔτεέʔϧΛಋೖͯ͠
©2018 Wantedly, Inc. • KubernetesͰ͑ΔΦʔτεέʔϧͷ • εέʔϧͷΈ • ઃఆͷํ •
࣮ࡍʹͬͯΈͨ • ߏྫ • Ͳ͏ͳ͔ͬͨ ·ͱΊ
©2018 Wantedly, Inc. • Custom Metrics Λಋೖ͢Δ • CPU͚ͩͷͱ͖ΑΓޮΑ͘Φʔτεέʔϧ͕͑Δ •
ΞϓϦέʔγϣϯͷىಈΛૣ͘͢Δ • ͘͢εέʔϧͯ͠ىಈ͕͍ͱεύΠΫʹউͯͳ͍ • API Server ͷΦϓγϣϯΛมߋ͢Δ • --horizontal-pod-autoscaler-sync-period • ϞχλϦϯάͰ͖ΔΈ • Wantedly Ͱ DataDog Λ͍ͬͯΔ KubernetesͷΦʔτεέʔϧಋೖͷTips