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
COSCUP - Dynamic Jenkins Agent on Kubernetes
Search
Rico Chen
August 01, 2020
0
60
COSCUP - Dynamic Jenkins Agent on Kubernetes
Jenkins CICD more Cloud Native way.
Rico Chen
August 01, 2020
Tweet
Share
More Decks by Rico Chen
See All by Rico Chen
How to monitor Cosmos validator by Prometheus
ricotoothless
0
620
how-to-choose-cicd-tools.pdf
ricotoothless
0
120
SRE Book Club - Linux - ch45 - Where's socket buffer
ricotoothless
0
150
SRE Book Club - Linux - ch38 - tcpdump & Wireshark
ricotoothless
0
56
Taiwan CDK Meetup - Rookie operator's CDK journey
ricotoothless
0
230
DevOps Taiwan 2020 Workshop - Jenkins CICD
ricotoothless
0
91
SRE Book Club - Kubernetes - ch32-35 - Network
ricotoothless
0
55
SRE Book Club - Kubernetes - ch22 - Job & CronJob
ricotoothless
0
40
Featured
See All Featured
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
26
3.2k
Designing Experiences People Love
moore
142
24k
Context Engineering - Making Every Token Count
addyosmani
9
410
Unsuck your backbone
ammeep
671
58k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
Scaling GitHub
holman
464
140k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
140
34k
Facilitating Awesome Meetings
lara
57
6.6k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
37
2.6k
The Power of CSS Pseudo Elements
geoffreycrofte
80
6.1k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
253
22k
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
1
45
Transcript
Dynamic Jenkins Agent on Kubernetes 政治要正確,正名 Jenkins Agent
Apology I shouldn't use a word like "slave" on the
COSCUP agenda description. All lives matters. Don’t KILLALL -9 me.
Who am I • I work for Bincentive • Volunteer
with DevOps Taiwan • Frozen lover
Agenda • What is Cloud Native • Why do we
keep using Jenkins? • Introduce plugins • Case study • Live demo • Reference
What is Cloud Native
Cloud Native definition • Cloud Native technologies build and run
scalable applications in modern, dynamic environments • Loosely coupled systems that are resilient, manageable, and observable
Why do we keep using Jenkins?
Jenkins advantage • Open source with rich community support •
More than 1000 plugins • Jenkins just like Transformers. Plugin can make Jenkins more Cloud Native way
巨巨巨巨巨巨巨巨巨巨巨巨巨巨巨 巨巨巨巨巨巨巨巨巨巨巨巨巨巨巨 巨巨巨巨巨巨巨巨巨巨巨巨巨巨巨 巨巨巨巨巨巨巨巨巨巨巨巨巨巨巨 巨巨巨巨巨巨巨巨巨巨巨巨巨巨巨 巨巨巨巨巨巨巨巨巨巨巨巨巨巨巨 巨巨巨巨巨巨巨巨巨巨巨巨巨巨 好巨的肩膀,不站嗎?
Introduce plugins
AWS ECS is base on Auto Scaling Group. 2018 was
lacking storage management. What can I do??? Main
Kubernetes plugin • Run dynamic agents in a Kubernetes •
The agent is essentially a pod • Can config PV, resources limit, namespaces … and more
How to config agent pod? • Start with UI •
Jenkins configuration as code plugin • Declarative or Scripted pipeline (use source control)
default namespace jenkins namespace EKS cluster Jenkins-agent service Jenkins main
service Kubernetes service 1 3 2
Jenkins agent pod docker dind jenkins-agent golang aws-cli nodeSelector tolerations
serviceAccount envVars
Case study
Issues • Too many microservices project • Prefer less plugins
to reduce Jenkins main’s complex • Compiler job could impact develop environment. We need isolate Jenkins agent pod. • Compiler resources usage
Pod Template docker dind jenkins- agent golang aws-cli docker dind
jenkins- agent node.js aws-cli Pod Template nodeSelector tolerations serviceAccount envVars nodeSelector tolerations serviceAccount envVars
Pod Template Pod Template golang docker dind jenkins- agent aws-cli
node.js nodeSelector tolerations serviceAccount envVars Jenkins shared library
agent pod jenkins main app pod app pod app pod
Normal worker nodes group jenkins agent worker nodes group
agent pod agent pod Can I build now? No. plz
queue.
Live demo
Isolate Jenkins aget pod • nodeSelector • taints • tolerations
Resources limit • only demo cpu request & limit
Reference
• Jenkins Kubernetes plugin • Jenkins Helm Charts • Jenkins
and Kubernetes - Secret Agents in the Clouds • Dynamic Jenkins Agent from Kubernetes • Docker image for inbound Jenkins agents • CNTUG #28 - Kubernetes Resource and Eviction Management and more (speak slide) • cAdvisor - Analyzes containers resources usage
• Jenkins Configuration as Code plugin • Jenkins Configuration as
Code Job DSL example • Jenins Job DSL GitHub • Jenkins Job DSL API Document • Jenkins Job DSL playground
• CNCF Cloud Native Definition v1.0 • Access-cluster-services • FluxCD,
ArgoCD or Jenkins X GitOps • “docker stop” and “docker kill”?
Thanks you Q & A