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
HDC24: A Life without VMs: High-Scale Kubernete...
Search
Martin Helmich
August 30, 2024
Technology
73
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
HDC24: A Life without VMs: High-Scale Kubernetes on Bare Metal
Martin Helmich
August 30, 2024
More Decks by Martin Helmich
See All by Martin Helmich
NEOSCon26: AI is eating your CMS
martinhelmich
0
24
CloudFest 2026: From Firefighting to Sleeping At Night
martinhelmich
0
22
WebCamp Venlo 26: AI is eating your CMS
martinhelmich
0
22
T3CON25: AI is eating your servers... and your CMS
martinhelmich
0
35
T3CB25: MCP – The Duct Tape of the AI era?
martinhelmich
0
72
T3CL25: Cloud-Native TYPO3
martinhelmich
0
62
T3DD25: How to annoy your Hosting Provider
martinhelmich
0
140
NEOSCon25: How to annoy your Hosting Provider
martinhelmich
0
34
T3CON24: Crafting Tomorrow's Tech Talent
martinhelmich
0
110
Other Decks in Technology
See All in Technology
WebGIS AI Agentの紹介
_shimizu
0
510
レガシーな広告配信システムでのAI駆動開発/運用の挑戦
i16fujimoto
0
110
IaC コードを資産へ:AWS CDK 社内ライブラリと横断展開 / aws-summit-japan-2026
gotok365
10
1.5k
Bucharest Tech Week 2026 - Reinventing testing practices in the AI era
edeandrea
PRO
1
170
20260619 私の日常業務での生成 AI 活用
masaruogura
1
240
Agile and AI Redmine Japan 2026
hiranabe
4
450
自分が詳しくない領域でAIを使う #プロヒス2026
konifar
20
7.2k
作る力から、見極める力へ — AI時代に広がるエンジニアの価値と役割
rince
0
300
從開發到部署全都交給 AI:實作 AI 驅動的自動化流程
appleboy
0
120
SONiCのNETCONFサーバ機能を試してみた
sonic
0
100
OTel × Datadog で 「AI活用」を計測し、改善に繋げる
shihochan
2
580
人材育成分科会.pdf
_awache
4
310
Featured
See All Featured
Context Engineering - Making Every Token Count
addyosmani
9
980
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
16k
4 Signs Your Business is Dying
shpigford
187
22k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.8k
Mobile First: as difficult as doing things right
swwweet
225
10k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
55k
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
Building Adaptive Systems
keathley
44
3.1k
Reflections from 52 weeks, 52 projects
jeffersonlam
356
21k
Embracing the Ebb and Flow
colly
88
5.1k
Imperfection Machines: The Place of Print at Facebook
scottboms
270
14k
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
440
Transcript
VIKTOR ABRAMS @mittwald MARTIN HELMICH @mittwald A LIFE WITHOUT VMs
HIGH - SCALE KUBERNETES ON BARE METAL HELLMANN DEVELOPER & MAKER CONFERENCE August 30th, 2024
https://web.archive.org/web/20040829084706/http://www.espelkamper-nachrichten.de/ MY FIRST ( PAID ) WEBSITE
HOSTING BACK THEN
HOSTING BACK THEN
APACHE PHP MYSQL HOSTING BACK THEN
APACHE PHP MYSQL ... AND NOW OPENSEARCH KEYCLOAK MOBILE APP
...OR NODE.JS DOCKER PWA NGINX 💥 ...OR P CDN HOSTING BACK THEN BOOP VARNISH
None
MITTWALD CLOUD PLATFORM ARCHITECTURAL GOALS FLEXIBILITY RESOURCE EFFICIENCY ( INTERNAL
) EASE OF USE *) apart from obvious ones, like security, reliability and performance *
MITTWALD CLOUD PLATFORM ARCHITECTURAL GOALS FLEXIBILITY STANDARDS CONFORMANCE KUBERNETES/COE CONTAINERIZED
CUSTOMIZABLE OCI IMAGES QUALITY GOAL SOLUTION STRATEGY RESOURCE EFFICIENCY ELASTICITY OPTIMIZED SCHEDULING ( INTERNAL ) EASE OF USE DECLARATIVE APIS KUBERNETES OPERATORS
NODE BASIC KUBERNETES PRINCIPLES NODE NODE CLUSTER YEET USER POD
POD POD POD ( SLIGHTLY SIMPLIFIED ) POD
martin @ local $ mw app install typo3 -q --version=12.4.17
--install-mode composer [...] martin @ local $ kubectl get pods --all-namespaces \ --field-selector spec.nodeName=shoot--chp-prod--gestringen-pm-sps-3669c938-z1-797d7-gtfmz NAMESPACE NAME READY STATUS RESTARTS AGE kube-system node-local-dns-69btw 1/1 Running 0 36d kube-system node-problem-detector-2bq2z 1/1 Running 0 36d kube-system openstack-manila-csi-nodeplugin-sk8sm 2/2 Running 0 36d monitoring kube-prometheus-stack-prometheus-node-exporter-dnq9l 1/1 Running 0 36d monitoring loki-stack-promtail-mntw2 1/1 Running 0 36d pg-s-piryq0 mysql-default-80-low-latency-knlw2-0 1/1 Running 0 12s pg-s-piryq0 p-elfmx0-64db467d4b-qzmdv 2/2 Running 0 2d20h pg-s-piryq0 p-elfmx0-l2qzd-b79b7fdf6-qxjl4 2/2 Running 0 12s pg-s-piryq0 p-elfmx0-logrotation-28698480-47mvh 0/1 Completed 0 23h
DEPLOYMENT REPLICASET POD STATEFULSET DAEMONSET SERVICE INGRESS INGRESS CLASS PERSISTENT
VOLUME PERSISTENT VOLUMECLAIM STORAGE CLASS JOB CRON JOB CERTIFICATE SECRET CONFIG MAP NODE
None
ABSTRACTION
DEPLOYMENT REPLICASET POD STATEFULSET DAEMONSET SERVICE INGRESS INGRESS PERSISTENT VOLUME
PERSISTENT VOLUMECLAIM STORAGE CLASS JOB CRON JOB CERTIFICATE SECRET CONFIG MAP NODE KUBERNTES CORE CONCEPTS PROJECT CUSTOMER PROJECT GROUP APP DATABASE DOMAIN HOSTING DOMAIN MODEL
apiVersion: apphosting.mittwald.cloud/v1 kind: App metadata: name: a-XXXXX namespace: s-YYYYY spec:
app: typo3 version: 12.4.17 project: name: p-ZZZZZ requirements: - name: php version: ^8.3 - name: composer version: ^2 installPath: /my-typo3-site
CUSTOM RESOURCE CONTROLLER KUBERNETES API USER create / update watch
notify reconcile desired state control loop
None
PRODUCT SPECIFIC K8S OPERATORS K8S CORE COMPONENTS
MACRO ARCHITECTURE PRODUCT SPECIFIC MICROSERVICES PRODUCT SPECIFIC K8S OPERATORS K8S
CORE COMPONENTS IaaS CLOUD DATA CENTER
ORGANIZATIONAL STRUCTURE PRODUCT SPECIFIC MICROSERVICES PRODUCT SPECIFIC K8S OPERATORS K8S
CORE COMPONENTS IaaS CLOUD DATA CENTER PRODUCT DEV TEAMS CLOUD PLATFORM TEAM IaaS + NETWORK TEAM DATA CENTER OPERATIONS
UNDER THE HOOD
WHAT IS YOUR PRODUCT? AND WHAT DO YOU NEED TO
RUN IT?
m³ ( Pronunciation: "m-cubed") NATIVE KUBERNETES WEBHOSTING
m³ ( Pronunciation: "m-cubed") VISIBILITY RESOURCE MANAGEMENT BARE METAL PROVISIONING
VIRTUAL CLUSTERS ROUTE REFLECTION MAIN GOALS
/etc /mnt /srv httpd php-fpm sshd VISIBILITY NAMESPACES /home python
/mnt /var httpd /mnt /etc /srv httpd php-fpm MySQL 1. Processes 2. File system 3. Network
RESOURCE MANAGEMENT CONTROL GROUPS cpu1 cpu2 cpu3 httpd node php-fpm
1. Memory 2. Compute 3. I/O
BARE METAL PROVISIONING control- plane worker worker worker Rack 1
control - plane worker worker worker Rack 2 control - plane worker worker Rack 3 netbox Adapter dhcp bootp cloud- init CORE BGP EFI RAID EFI RAID LVM root Volume 1..n BGP worker cloud- image
VIRTUAL CLUSTERS systemd cri-o kubelet ... systemd cri-o kubelet ...
systemd cri-o kubelet ... systemd cri-o kubelet ... Control-Plane Worker 1 Worker 2 Worker N kluster.m3.services Cluster Workergroup Cluster-Operator
ROUTE REFLECTION vnode 1 vnode 2 vnode 3 vnode 5
vnode 4 SWITCH 1 SWITCH 2 frr frr NODE 1 NODE 2
MAIN GOALS _ IP DUAL STACK _ PERFORMANCE FIRST _
MANAGEABLE UNITS (no micromanagement) _ COMPLETE INVENTORY OVERVIEW (datacenter infrastructure management; DCIM ) _ COMPLEXITY REDUCTION i.e.: less abstraction (compute, network, ...)
https://github.com/mittwald https://github.com/martin-helmich https://www.mittwald.de https://www.linkedin.com/company/mittwald https://www.linkedin.com/in/martinhelmich