SlideShare a Scribd company logo
A Tale of Three Tools:
Kubernetes, Jsonnet, and Bazel
Miles Yucht
SF Kubernetes Meetup
July 26, 2017 1
Who am I?
Miles
• CS @ Princeton
• SWE on Growth team @ Databricks
since 2015
• "Lead Developer" of kubecfg
2
Agenda
• Kubernetes @ Databricks
• Why Jsonnet
• Combining Bazel and Kubernetes
• Q & A
3
Kubernetes
4
Kubernetes at Databricks
● Multiple Kubernetes clusters, hundreds of deployments
● 6+ terabytes of memory, hundreds of cores
● Many customizations for security
● Everything new goes onto Kubernetes
● All managed by a 7-person team
5
Kubernetes at Databricks
We're hiring! Come talk to
Priya or me after the talks!
6
Combinatorial Configurations
6 clusters, 3 environments, 4 modes of deployment
● Lots of parameters
● Extremely verbose
○ >75k lines of checked-in YAML templates
● YAML is not modular
● Hard to manage, manipulate, and correctly refactor templates
7
Kubernetes development lifecycle
● Simple to test & develop in Kubernetes
● Keep dev, test, staging, prod environments similar
● Critical for testing kubernetes/cloud features
○ E.g. replication, PROXY protocol
8
Many-step Deployment
9
Build Docker Image
Tag Docker Image
Push Docker ImageEdit Template
Apply Template
kubecfg!
● Python wrapper around kubectl
○ Still have all your favorite kubectl commands
● Preprocesses inputs and passes the result to kubectl
● Augments kubectl
○ Easy to add new commands to kubecfg
● Automates several common workflows
○ Simpler for developers
○ Fewer chances to make mistakes
10
Jsonnet
11
Jsonnet
● DSL for defining JSON data
● Break up monolithic configurations into composable parts
● >75k lines of YAML → ~20k lines of Jsonnet
● To learn about how we use Jsonnet:
○ https://databricks.com/blog/2017/06/26/declarative-infrastructure-js
onnet-templating-language.html
12
Jsonnet → JSON
When running kubecfg apply -f webapp.jsonnet:
● jsonnet webapp.jsonnet > /tmp/aaa.json
● kubectl apply -f /tmp/aaa.json
13
Original kubecfg architecture
14
Jsonnet Template Kubernetes spec Kubectl
Integrating build and deploy
Kubernetes template
⇕
Tagged image
15
Integrating build and deploy
Kubernetes template
⇕
How to produce the artifact that it depends on
16
Integrating build and deploy
1. What do you need to do to prepare the artifact?
→ Ask your build tool.
2. How do you refer to the artifact?
→ Use a tagged docker image.
17
Bazel
18
Bazel
● Open-source, language-agnostic build tool
● Very customizable/configurable
● Ported our build from SBT to Bazel mid-2016
● To learn about how we use Bazel:
○ Blog post coming soon!
19
Kubectl Templates
{
image: "registry.databricks.com/webapp:latest",
...
}
20
Kubectl Templates
{
image: "registry.databricks.com/webapp:latest",
...
}
Kubernetes template
⇕
Tagged image
21
Kubecfg Templates
{
target: "//docker/webapp",
...
}
22
Kubecfg Templates
{
target: "//docker/webapp",
...
}
Kubernetes template
⇕
Bazel target
23
Integrating build and deploy
Build:
● bazel build //docker/webapp:webapp
Tag & Push (new):
● bazel run //docker/webapp:webapp_push -t <tag>
Deploy (new):
● $(cat //docker/webapp:webapp_repository):<tag>
24
Tagging images
For clean checkouts:
● <GIT_SHA>-<COMMIT_TIMESTAMP>
For dirty checkouts:
● <GIT_SHA>-<COMMIT_TIMESTAMP>-DIRTY-<DIFF_SHA>
25
Current kubecfg architecture
26
Jsonnet Template
“Kubernetes spec”
with Bazel targets
Kubectl
Kubernetes spec
with images
Build docker
image
Tag and
push image
git ref-log
Conclusion
● kubecfg makes deployment a two-step operation
1. git checkout my-branch
2. kubecfg apply -f the-template.jsonnet
● Speeds up development cycle
● Helps with tracking down errors
27
Future of kubecfg
● We plan on open sourcing this library
● Development in Bazel makes this easier
○ https://github.com/bazelbuild/rules_docker
28
Thank you
We're hiring! Talk to me or Priya if you're
interested in joining our team.
29

More Related Content

Similar to A Tale of Three Tools: Kubernetes, Jsonnet, and Bazel (20)

PPTX
Kubernetes
Lhouceine OUHAMZA
 
PPTX
Kubernetes Introduction
Eric Gustafson
 
PDF
Kubernetes meetup - 2018-05-23
Ruben Ernst
 
PDF
Getting serious \w private kubernetes clusters &amp; cloud native storage
David Steiman
 
PPTX
Kuberenetes - From Zero to Hero
Ori Stoliar
 
PDF
Kubernetes + Python = ❤ - Cloud Native Prague
Henning Jacobs
 
PDF
Metal-k8s presentation by Julien Girardin @ Paris Kubernetes Meetup
Laure Vergeron
 
PDF
David Steiman - Getting serious with private kubernetes clusters & cloud nati...
Codemotion
 
PPTX
David Steiman - Getting serious with private kubernetes clusters & cloud nati...
Codemotion
 
PDF
5 - Hands-on Kubernetes Workshop:
Kangaroot
 
PPTX
Kubernetes: від знайомства до використання у CI/CD
Stfalcon Meetups
 
PPTX
Leveraging Helm to manage Deployments on Kubernetes
Manoj Bhagwat
 
PPTX
Kubernates : An Small introduction for Beginners by Rajiv Vishwkarma
Rajiv Vishwkarma
 
PDF
DevOpsDays Houston 2019 - Dan Kirkpatrick - My Kubernetes Tool Chain: Open-So...
DevOpsDays Houston
 
PDF
Kubernetes at Telekom Austria Group
Oliver Moser
 
PPTX
Kubernetes 101
Stanislav Pogrebnyak
 
PDF
2016 10-26 docker meetup - kubernetes on open stack
Amrita Prasad
 
PPTX
K8s from Zero to ~Hero~ Seasoned Beginner
Kristof Jozsa
 
PDF
[WSO2Con USA 2018] Deploying Applications in K8S and Docker
WSO2
 
PDF
$ kubectl hacking @DevOpsCon Berlin 2019
Tobias Schneck
 
Kubernetes
Lhouceine OUHAMZA
 
Kubernetes Introduction
Eric Gustafson
 
Kubernetes meetup - 2018-05-23
Ruben Ernst
 
Getting serious \w private kubernetes clusters &amp; cloud native storage
David Steiman
 
Kuberenetes - From Zero to Hero
Ori Stoliar
 
Kubernetes + Python = ❤ - Cloud Native Prague
Henning Jacobs
 
Metal-k8s presentation by Julien Girardin @ Paris Kubernetes Meetup
Laure Vergeron
 
David Steiman - Getting serious with private kubernetes clusters & cloud nati...
Codemotion
 
David Steiman - Getting serious with private kubernetes clusters & cloud nati...
Codemotion
 
5 - Hands-on Kubernetes Workshop:
Kangaroot
 
Kubernetes: від знайомства до використання у CI/CD
Stfalcon Meetups
 
Leveraging Helm to manage Deployments on Kubernetes
Manoj Bhagwat
 
Kubernates : An Small introduction for Beginners by Rajiv Vishwkarma
Rajiv Vishwkarma
 
DevOpsDays Houston 2019 - Dan Kirkpatrick - My Kubernetes Tool Chain: Open-So...
DevOpsDays Houston
 
Kubernetes at Telekom Austria Group
Oliver Moser
 
Kubernetes 101
Stanislav Pogrebnyak
 
2016 10-26 docker meetup - kubernetes on open stack
Amrita Prasad
 
K8s from Zero to ~Hero~ Seasoned Beginner
Kristof Jozsa
 
[WSO2Con USA 2018] Deploying Applications in K8S and Docker
WSO2
 
$ kubectl hacking @DevOpsCon Berlin 2019
Tobias Schneck
 

More from Databricks (20)

PPTX
DW Migration Webinar-March 2022.pptx
Databricks
 
PPTX
Data Lakehouse Symposium | Day 1 | Part 1
Databricks
 
PPT
Data Lakehouse Symposium | Day 1 | Part 2
Databricks
 
PPTX
Data Lakehouse Symposium | Day 2
Databricks
 
PPTX
Data Lakehouse Symposium | Day 4
Databricks
 
PDF
5 Critical Steps to Clean Your Data Swamp When Migrating Off of Hadoop
Databricks
 
PDF
Democratizing Data Quality Through a Centralized Platform
Databricks
 
PDF
Learn to Use Databricks for Data Science
Databricks
 
PDF
Why APM Is Not the Same As ML Monitoring
Databricks
 
PDF
The Function, the Context, and the Data—Enabling ML Ops at Stitch Fix
Databricks
 
PDF
Stage Level Scheduling Improving Big Data and AI Integration
Databricks
 
PDF
Simplify Data Conversion from Spark to TensorFlow and PyTorch
Databricks
 
PDF
Scaling your Data Pipelines with Apache Spark on Kubernetes
Databricks
 
PDF
Scaling and Unifying SciKit Learn and Apache Spark Pipelines
Databricks
 
PDF
Sawtooth Windows for Feature Aggregations
Databricks
 
PDF
Redis + Apache Spark = Swiss Army Knife Meets Kitchen Sink
Databricks
 
PDF
Re-imagine Data Monitoring with whylogs and Spark
Databricks
 
PDF
Raven: End-to-end Optimization of ML Prediction Queries
Databricks
 
PDF
Processing Large Datasets for ADAS Applications using Apache Spark
Databricks
 
PDF
Massive Data Processing in Adobe Using Delta Lake
Databricks
 
DW Migration Webinar-March 2022.pptx
Databricks
 
Data Lakehouse Symposium | Day 1 | Part 1
Databricks
 
Data Lakehouse Symposium | Day 1 | Part 2
Databricks
 
Data Lakehouse Symposium | Day 2
Databricks
 
Data Lakehouse Symposium | Day 4
Databricks
 
5 Critical Steps to Clean Your Data Swamp When Migrating Off of Hadoop
Databricks
 
Democratizing Data Quality Through a Centralized Platform
Databricks
 
Learn to Use Databricks for Data Science
Databricks
 
Why APM Is Not the Same As ML Monitoring
Databricks
 
The Function, the Context, and the Data—Enabling ML Ops at Stitch Fix
Databricks
 
Stage Level Scheduling Improving Big Data and AI Integration
Databricks
 
Simplify Data Conversion from Spark to TensorFlow and PyTorch
Databricks
 
Scaling your Data Pipelines with Apache Spark on Kubernetes
Databricks
 
Scaling and Unifying SciKit Learn and Apache Spark Pipelines
Databricks
 
Sawtooth Windows for Feature Aggregations
Databricks
 
Redis + Apache Spark = Swiss Army Knife Meets Kitchen Sink
Databricks
 
Re-imagine Data Monitoring with whylogs and Spark
Databricks
 
Raven: End-to-end Optimization of ML Prediction Queries
Databricks
 
Processing Large Datasets for ADAS Applications using Apache Spark
Databricks
 
Massive Data Processing in Adobe Using Delta Lake
Databricks
 
Ad

Recently uploaded (20)

PPTX
Agentic Automation: Build & Deploy Your First UiPath Agent
klpathrudu
 
PDF
SciPy 2025 - Packaging a Scientific Python Project
Henry Schreiner
 
PDF
IObit Driver Booster Pro 12.4.0.585 Crack Free Download
henryc1122g
 
PPTX
Prompt Like a Pro. Leveraging Salesforce Data to Power AI Workflows.pptx
Dele Amefo
 
PDF
Simplify React app login with asgardeo-sdk
vaibhav289687
 
PPTX
BB FlashBack Pro 5.61.0.4843 With Crack Free Download
cracked shares
 
PPTX
From spreadsheets and delays to real-time control
SatishKumar2651
 
PPTX
Build a Custom Agent for Agentic Testing.pptx
klpathrudu
 
PPTX
Transforming Insights: How Generative AI is Revolutionizing Data Analytics
LetsAI Solutions
 
PDF
UITP Summit Meep Pitch may 2025 MaaS Rebooted
campoamor1
 
PDF
Dipole Tech Innovations – Global IT Solutions for Business Growth
dipoletechi3
 
PPTX
Comprehensive Risk Assessment Module for Smarter Risk Management
EHA Soft Solutions
 
PDF
ERP Consulting Services and Solutions by Contetra Pvt Ltd
jayjani123
 
PDF
Latest Capcut Pro 5.9.0 Crack Version For PC {Fully 2025
utfefguu
 
PDF
Everything you need to know about pricing & licensing Microsoft 365 Copilot f...
Q-Advise
 
PPTX
iaas vs paas vs saas :choosing your cloud strategy
CloudlayaTechnology
 
PDF
Generic or Specific? Making sensible software design decisions
Bert Jan Schrijver
 
PDF
AOMEI Partition Assistant Crack 10.8.2 + WinPE Free Downlaod New Version 2025
bashirkhan333g
 
PDF
Best Web development company in india 2025
Greenusys
 
PDF
Ready Layer One: Intro to the Model Context Protocol
mmckenna1
 
Agentic Automation: Build & Deploy Your First UiPath Agent
klpathrudu
 
SciPy 2025 - Packaging a Scientific Python Project
Henry Schreiner
 
IObit Driver Booster Pro 12.4.0.585 Crack Free Download
henryc1122g
 
Prompt Like a Pro. Leveraging Salesforce Data to Power AI Workflows.pptx
Dele Amefo
 
Simplify React app login with asgardeo-sdk
vaibhav289687
 
BB FlashBack Pro 5.61.0.4843 With Crack Free Download
cracked shares
 
From spreadsheets and delays to real-time control
SatishKumar2651
 
Build a Custom Agent for Agentic Testing.pptx
klpathrudu
 
Transforming Insights: How Generative AI is Revolutionizing Data Analytics
LetsAI Solutions
 
UITP Summit Meep Pitch may 2025 MaaS Rebooted
campoamor1
 
Dipole Tech Innovations – Global IT Solutions for Business Growth
dipoletechi3
 
Comprehensive Risk Assessment Module for Smarter Risk Management
EHA Soft Solutions
 
ERP Consulting Services and Solutions by Contetra Pvt Ltd
jayjani123
 
Latest Capcut Pro 5.9.0 Crack Version For PC {Fully 2025
utfefguu
 
Everything you need to know about pricing & licensing Microsoft 365 Copilot f...
Q-Advise
 
iaas vs paas vs saas :choosing your cloud strategy
CloudlayaTechnology
 
Generic or Specific? Making sensible software design decisions
Bert Jan Schrijver
 
AOMEI Partition Assistant Crack 10.8.2 + WinPE Free Downlaod New Version 2025
bashirkhan333g
 
Best Web development company in india 2025
Greenusys
 
Ready Layer One: Intro to the Model Context Protocol
mmckenna1
 
Ad

A Tale of Three Tools: Kubernetes, Jsonnet, and Bazel