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
58
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
560
how-to-choose-cicd-tools.pdf
ricotoothless
0
110
SRE Book Club - Linux - ch45 - Where's socket buffer
ricotoothless
0
130
SRE Book Club - Linux - ch38 - tcpdump & Wireshark
ricotoothless
0
54
Taiwan CDK Meetup - Rookie operator's CDK journey
ricotoothless
0
180
DevOps Taiwan 2020 Workshop - Jenkins CICD
ricotoothless
0
82
SRE Book Club - Kubernetes - ch32-35 - Network
ricotoothless
0
52
SRE Book Club - Kubernetes - ch22 - Job & CronJob
ricotoothless
0
36
Featured
See All Featured
Reflections from 52 weeks, 52 projects
jeffersonlam
346
20k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
29
2.3k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
28
2.1k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
38
1.9k
Build your cross-platform service in a week with App Engine
jlugia
229
18k
[RailsConf 2023] Rails as a piece of cake
palkan
53
5k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
111
49k
Producing Creativity
orderedlist
PRO
341
39k
Testing 201, or: Great Expectations
jmmastey
40
7.1k
The Power of CSS Pseudo Elements
geoffreycrofte
73
5.4k
Designing on Purpose - Digital PM Summit 2013
jponch
116
7k
Java REST API Framework Comparison - PWX 2021
mraible
PRO
28
8.3k
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