DevOps
Implement by Kubernetes
https://slides.com/rockwyc992/devops
Agenda
-
What's DevOps?
-
What's Kubernetes?
-
How to use them together?
Why do I use DevOps?
常見的開發情況
-
我的電腦可以跑,為什麼你的不行?
-
不知道剛剛改了什麼,程式就壞掉了
-
需.求.變.更 => 大.災.難
常見的維運情況
-
為什麼你的電腦可以跑,我的卻不行?
-
不知道怎麼安裝,或是安全性問題一大堆
-
這是上個月安裝的,我已經忘記怎麼安裝了
常見的各種情況
-
不敢重開機、不敢升級
-
缺乏測試,Bug 滿天飛
What's DevOps?
-
Developer
-
Operator
Developer + Operator = DevOps
who write & debug program
who build & install program
https://commons.wikimedia.org/wiki/File:Devops.svg
data:image/s3,"s3://crabby-images/1a97a/1a97a02cafcaaa02290334cd335d6d00274f1763" alt=""
https://www.zaizi.com/devops
Great
Poor
Dev
Ops
https://commons.wikimedia.org/wiki/File:Agile-vs-iterative-flow.jpg
data:image/s3,"s3://crabby-images/7629c/7629c5e8385ef1334929fad7ad98d8e2dfb6f022" alt=""
How to improve our workflow?
-
Git Flow
-
Gitlab CI
-
[WIP] Unit Test
-
Prometheus / fluentd
Monitor
Code
Build, Release, Deploy
Test
The Mythical Man-Month
http://www.books.com.tw/products/0010254508
No Silver Bullet
data:image/s3,"s3://crabby-images/a53cf/a53cf94710a9344836696d341deb75f2c8e38922" alt=""
(人月神话)
A story about baking cake
http://www.infoq.com/cn/articles/delivering-software-water-scrum-fall
Water Scrum Fall
Seems like Sliver Bullet
-
OOP
-
MVC
-
Agile
-
Docker
Why Git Flow?
branching model for git
data:image/s3,"s3://crabby-images/792ff/792ff49f09c61dabf88c45cfd46ebbbcb397e57b" alt=""
data:image/s3,"s3://crabby-images/472ec/472ec7806fbe27ed1fa49ed4ea7030e87e3aa92b" alt=""
data:image/s3,"s3://crabby-images/c1f6c/c1f6c3168e12998a96c540bc0c1f35d3d05e71be" alt=""
data:image/s3,"s3://crabby-images/37f34/37f3425f69d75a4fab19eb79bdd78fa2be2d1c7c" alt=""
data:image/s3,"s3://crabby-images/7ff0a/7ff0a8783a67f8ec46315583386304724587614c" alt=""
data:image/s3,"s3://crabby-images/7ff0a/7ff0a8783a67f8ec46315583386304724587614c" alt=""
semver
(Semantic Versioning)
4 . 14 . 1
compatible
new feature
non-compatible
hot-fix
Who use git flow?
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
-
TDD / BDD
-
Mock / Stub
-
Refactoring
-
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/a01fd/a01fd4a86748b2e227d52c5acdd36455ddc1a0cf" 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
- More compatibility
- RestAPI
- OpenSouce (Apache 2.0)
VM
- Easy to use
- Easy to debug
- Easy to design
- More secure
- Keep all change
Kubernetes Architecture
Kubernetes Architecture
data:image/s3,"s3://crabby-images/9c1b6/9c1b62d95376eb471dd91b79e02a619c95d74414" alt=""
data:image/s3,"s3://crabby-images/73862/73862f08b6d0733d1cf8cc3a7dec042ecfddc7ba" alt=""
How to deploy
All pods in Kubernetes
data:image/s3,"s3://crabby-images/5f3fb/5f3fbdd56cbc45cd00c7897842ad3de2ce9f0ddc" alt=""
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/
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/a770a/a770a93fc47352d9265b1185a762dfd2efed927c" alt=""
Gitlab CI/CD Pipeline
https://about.gitlab.com/2016/08/26/ci-deployment-and-environments/
What have we done?
Gitlab CI/CD Pipeline
todo: .gitlab-ci.yaml
data:image/s3,"s3://crabby-images/ff9ab/ff9abd5b25116f4d63f5479e1f0d4cfbe3e9d2b5" alt=""
Gitlab CI/CD Pipeline
todo: .gitlab-ci.yaml
data:image/s3,"s3://crabby-images/e0f78/e0f78871f39a16e62d8b79bae6e48f6eb98e0625" alt=""
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=""
todo: environment
Gitlab CI/CD Pipeline
data:image/s3,"s3://crabby-images/b646c/b646cb30551fdc3dc35b9155aca47b4e5e5ddc2b" alt=""
data:image/s3,"s3://crabby-images/90405/90405aaff4ed8d18ebe87a750499cd26197b5bbc" alt=""
Example
Summy
- Change the habit with coding & pushing code.
- Just copy the file at Kubernetes-CI into your code.
All magic things will be done by Gitlab CI & Kubernetes.
- TDD / BDD for your code. It would do more job now,
but it will let you do less job at the future.
Have we done all things?
I have done the job to "use" Kubernetes.
But, I will do the job to "customize" Kubernetes.
or "contribute"
Q&A
Thanks
for your attention!
DevOps
By rockwyc992
DevOps
- 853