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
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
657
61k
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
Gamification - CAS2011
davidbonilla
81
5.5k
Building Flexible Design Systems
yeseniaperezcruz
329
39k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
667
120k
We Have a Design System, Now What?
morganepeng
53
7.8k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
30
2.7k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
127
53k
How to train your dragon (web standard)
notwaldorf
96
6.3k
Music & Morning Musume
bryan
46
6.8k
Optimizing for Happiness
mojombo
379
70k
How To Stay Up To Date on Web Technology
chriscoyier
791
250k
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