DevOps
Implement by Kubernetes
Agenda
-
What's DevOps?
-
What's Kubernetes?
-
How to use them together?
What's DevOps?
-
Developer
-
Operator
Developer + Operator = DevOps
who write & debug program
who build & install program
Why do I use DevOps?
常見的開發情況
-
我的電腦可以跑,為什麼你的不行?
-
不知道剛剛改了什麼,程式就壞掉了
-
需.求.變.更 => 大.災.難
常見的維運情況
-
為什麼你的電腦可以跑,我的卻不行?
-
不知道怎麼安裝,或是安全性問題一大堆
-
這是上個月安裝的,我已經忘記怎麼安裝了
常見的各種情況
-
不敢重開機、不敢升級
-
缺乏測試,Bug 滿天飛
Gitlab CI
data:image/s3,"s3://crabby-images/4bb41/4bb41d07fb1e6379c85dad901773b51b39f310cc" alt=""
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
What's CI/CD?
-
Continuous Integration
-
Continuous Delivery
https://commons.wikimedia.org/wiki/File:Agile-vs-iterative-flow.jpg
data:image/s3,"s3://crabby-images/7629c/7629c5e8385ef1334929fad7ad98d8e2dfb6f022" alt=""
http://www.globalnerdy.com/2007/11/28/dilbert-on-extreme-and-agile-programming/
data:image/s3,"s3://crabby-images/841d7/841d74fbea86efa14cb6203c6dfb13209025a799" alt=""
Unit Test
-
Find problems early
-
TDD / BDD
-
Test Coverage
-
Test for failure
Other Method
-
e2e testing
-
A / B Test
-
Canary release
-
Blue / Green Release
-
Nightly Build
Final Target
-
Auto Test
-
Auto Deploy
-
Faster Coding, Less Bug
-
CaaS (Code as a Service)
-
Rolling Update / Rollback
-
High Avilible / Auto Healing
Before we go ahead
What's Kubernetes?
What's Kubernetes
Kubernetes is an open source system for managing Docker across multiple hosts.
A Project of CNCF
data:image/s3,"s3://crabby-images/a43d3/a43d302501858f9067f682108c17738220cbbd8f" alt=""
What's Kubernetes
Kubernetes is an open source system for managing Docker across multiple hosts.
-
Docker
-
Micro-service / Stateless
-
Multi-host
-
Self-healing
-
Rolling Update
-
Open Source (Apache 2.0)
Rolling Update
https://www.slideshare.net/DanielSmith272/whats-new-in-kubernetes
data:image/s3,"s3://crabby-images/a1fc4/a1fc49e2b7e097c4e4968696a4b396f0a1630bec" alt=""
data:image/s3,"s3://crabby-images/163f2/163f284260f69b54ad4906bdf0567da1c7c2a017" alt=""
data:image/s3,"s3://crabby-images/aa5dc/aa5dcb1712349ff1c9e821b58ead6bce9f021e45" alt=""
data:image/s3,"s3://crabby-images/08da4/08da4e1c9ff4f0365bf5eb0e7966ec3f6119a17a" alt=""
data:image/s3,"s3://crabby-images/14a6c/14a6c1d496c6c89728060dd15ef1e7c5b32816a5" alt=""
data:image/s3,"s3://crabby-images/6219d/6219dad474dde1f702a537260ea3a46099c76403" alt=""
data:image/s3,"s3://crabby-images/8ecb5/8ecb5a422fc823ea6c05434e98c41764f1d58085" alt=""
data:image/s3,"s3://crabby-images/492ce/492cefcf5464dd82ceed87ce295c63d6bc8457f2" alt=""
data:image/s3,"s3://crabby-images/665d9/665d9247983a88b9cfadf996c79f68f442c12afb" alt=""
So, what's Docker?
data:image/s3,"s3://crabby-images/8612c/8612cf1db90cc8e71237285d5127a4c1b176ac09" alt=""
data:image/s3,"s3://crabby-images/04b42/04b4264b5bf9639d01241549d768acdc724df2bd" alt=""
So, what's Docker?
data:image/s3,"s3://crabby-images/ab406/ab406cbc9f027a4cb94e7ee535ed32e06806ca93" alt=""
So, what's Docker?
data:image/s3,"s3://crabby-images/09358/0935885db2ee9a8cb42324aa66cf0a2b1d47f278" alt=""
So, what's Docker?
data:image/s3,"s3://crabby-images/97941/97941a22837c21bb4ae285364bbf2472caf53950" alt=""
Docker
- Execute Faster
- Launch Faster
- Less Disk & Less Memory
- Scale up quickly
- OpenSouce (Apache 2.0)
VM
- Easy to use
- Easy to debug
- Easy to design
- More secure
- Keep all change
Gitlab CI
data:image/s3,"s3://crabby-images/4bb41/4bb41d07fb1e6379c85dad901773b51b39f310cc" alt=""
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/0d95a/0d95aed77527f8278a7705be18fbdd9c1f43a6d3" alt=""
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/17269/17269203a67c44dce8a67a9f62097addeba1b07c" alt=""
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/5a3ee/5a3ee12fc787eb861749585a1e2d4fd1bbf5b1df" alt=""
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/c97d0/c97d03edc343ea4dfb68a211c33ec6ba17316268" alt=""
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/ff9f3/ff9f369afa98ad9f9cab6c682376ca20170a2323" alt=""
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/54b64/54b643c141bad020c547bd1880d6e66b55cc9cfc" alt=""
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
todo: runner、running dashboard
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/2436c/2436cb7b647ffb01bce06fd21fe6ef110235d277" alt=""
todo: pipeline
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/f6cd6/f6cd663e9e02d3e4354b87117cfdeafb81c1e563" alt=""
Have we done all things?
I have done the job to "use" Kubernetes.
But, we will do the job to "customize" Kubernetes.
or "contribute"
Q&A
Thanks
for your attention!
DevOps
By rockwyc992
DevOps
- 786