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
610
how-to-choose-cicd-tools.pdf
ricotoothless
0
110
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
54
SRE Book Club - Kubernetes - ch22 - Job & CronJob
ricotoothless
0
39
Featured
See All Featured
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
Typedesign – Prime Four
hannesfritz
42
2.8k
Designing Experiences People Love
moore
142
24k
Documentation Writing (for coders)
carmenintech
76
5.1k
Agile that works and the tools we love
rasmusluckow
331
21k
Code Reviewing Like a Champion
maltzj
526
40k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
1.7k
The Cost Of JavaScript in 2023
addyosmani
55
9.1k
Large-scale JavaScript Application Architecture
addyosmani
514
110k
Done Done
chrislema
186
16k
YesSQL, Process and Tooling at Scale
rocio
174
15k
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
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