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
Routing Your Microservices Architecture to Ease...
Search
DevOps Gathering
March 10, 2020
Programming
290
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Routing Your Microservices Architecture to Ease DevOps Enterprise Transformation by Manuel Zapf
DevOps Gathering
March 10, 2020
More Decks by DevOps Gathering
See All by DevOps Gathering
Hacking Terraform by Constantin Weisser
devopsgatheringio
1
270
The Road to Reliability: Infrastructure Testing explained by Constantin Weisser
devopsgatheringio
1
310
Take MicroProfile to the Clouds with Quarkus by Dirk Weil
devopsgatheringio
0
220
Tracing - a Journey to Tactical Insights by Florian Kückelkorn
devopsgatheringio
0
280
Testable Kubernetes Operators? by Marcel Müller
devopsgatheringio
0
310
How Containerized Pipelines Can Boost Your CI/CD by Nico Meisenzahl
devopsgatheringio
0
200
The First Decade of DevOps is Over by Konstanin Diener
devopsgatheringio
1
180
From Zero to Hero - Onboarding with GitOps by Mario Kleinsasser
devopsgatheringio
0
170
Building a Graph User-Interface for Malware-Analysis by Stefan Hausotte
devopsgatheringio
0
280
Other Decks in Programming
See All in Programming
さぁV100、メモリをお食べ・・・
nilpe
0
140
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
330
代数的データ型って何が嬉しいの? #frontend_phpcon_do
kajitack
8
3.6k
「なぜそう決めたのか」を残し続ける仕組み ― Notion AI カスタムエージェント × Slack連携による設計判断の自動記録 - NIKKEI Tech Talk #47
niftycorp
PRO
0
150
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
12k
Oxlintのカスタムルールの現況
syumai
6
1.1k
AI時代の仕事技芸論 — ソフトウェア開発で「遊ぶように働く」職人的熟達のすすめ
kuranuki
2
670
TSKaigi Night Talks 2026_TypeScriptでサプライチェーンの整合性を型に閉じ込める
geekplus_tech
0
340
エンジニアと一緒にテストコードの設計と実装を改善した話
mototakatsu
0
160
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
240
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
21
6.6k
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
420
Featured
See All Featured
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
YesSQL, Process and Tooling at Scale
rocio
174
15k
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.9k
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
1
540
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
590
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
200
How to optimise 3,500 product descriptions for ecommerce in one day using ChatGPT
katarinadahlin
PRO
1
3.6k
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
190
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
230
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
250
Google's AI Overviews - The New Search
badams
0
1k
Leading Effective Engineering Teams in the AI Era
addyosmani
9
2k
Transcript
Routing Your Microservices Architecture To Ease DevOps Enterprise Transformation Devops
Gathering 2020 1
Whoami Manuel Zapf Head of Product Open Source @ Maintainer
on Containous Trae k @mZapfDE SantoDE 2
Containous We Believe in Open Source We Deliver Trae k,
Trae k Enterprise Edition, Maesh Commercial Support 30 people distributed, 90% tech https://containo.us 3 . 1
3 . 2
The Premise Of Microservices… 3 . 3
… And What Happens 3 . 4
Where’s My Service? 3 . 5
Tools Of The Trade 3 . 6
Source: Twitter[] 3 . 7
What If I Told You? That You Don’t Have to
Write This Con guration File… ? 3 . 8
Here Comes Traefik! 4 . 1
Traefik Project 4 . 2
Traefik 2.0 Quick Overview Revamped Documentation Clari ed Concepts Expressive
Routing Rule Syntax Middlewares TCP Support Canary / Mirroring And so Much More… Learn more on the blog post 4 . 3
Traefik (V2.0) Core Concepts 5 . 1
Traefik Is An Edge Router 5 . 2
Dynamically Discovers Services 5 . 3
Architecture (V2.0) At A Glance 5 . 4
Entrypoints 5 . 5
Routers 5 . 6
Middlewares 5 . 7
Services 5 . 8
Architecture (Again) At A Glance 5 . 9
Static & Dynamic Configuration 5 . 10
Traefik And Let’s Encrypt 6 . 1
HTTPS & Let’s Encrypt 6 . 2
Traefik With ⎈ ⎈ Diagram from https://medium.com/@geraldcroes 7 . 1
Ingress Example With ⎈ ⎈ apiVersion: networking.k8s.io/v1beta1 kind: Ingress metadata:
name: corporate-webapp annotations: kubernetes.io/ingress.class: 'traefik' spec: rules: - host: localhost http: paths: - backend: serviceName: corporate-webapp servicePort: 80 7 . 2
⎈ ⎈ CRD - Custom Resources Definition # File "webapp.yaml"
apiVersion: traefik.containo.us/v1alpha1 kind: IngressRoute metadata: name: simpleingressroute spec: entryPoints: - web routes: - match: Host(`localhost`) && PathPrefix(`/whoami`) kind: Rule services: - name: webapp port: 80 $ kubectl apply -f webapp.yaml $ kubectl get ingressroute 7 . 3
⎈ ⎈ & TCP (With CRD) apiVersion: traefik.containo.us/v1alpha1 kind: IngressRouteTCP
metadata: name: ingressroutetcpmongo.crd spec: entryPoints: - mongotcp routes: - match: HostSNI(`mongo-prod`) services: - name: mongo-prod port: 27017 7 . 4
East / West Traefik 8 . 1
Say Hello To Maesh 8 . 2
What Is Maesh? Maesh is a lightweight, easy to con
gure, and non-invasive service mesh that allows visibility and management of the traf c ows inside any Kubernetes cluster. 8 . 3
Maesh Architecture 8 . 4
More On Maesh Built on top of Trae k, SMI
(Service Mesh Interface speci cation) compliant, Opt-in by default. Maesh Website 8 . 5
Show Me The Code! Install Maesh (Helm Chart): Deploy Applications:
Deploy SMI Objects to allow traf c in the mesh: helm repo add maesh https://containous.github.io/maesh/charts helm repo update helm install --name=maesh --namespace=maesh maesh/maesh --values=./maesh/values.yaml kubectl apply -f apps/0-namespace.yaml kubectl apply -f apps/1-svc-accounts.yaml kubectl apply -f apps/2-apps-client.yaml kubectl apply -f apps/3-apps-servers.yaml kubectl apply -f apps/4-ingressroutes.yaml kubectl apply -f apps/5-smi-http-route-groups.yaml kubectl apply -f apps/6-smi-traffic-targets.yaml 8 . 6
A Closer Look To SMI Objects apiVersion: specs.smi-spec.io/v1alpha1 kind: HTTPRouteGroup
metadata: name: app-routes namespace: apps matches: - name: all pathRegex: "/" methods: ["*"] --- apiVersion: access.smi-spec.io/v1alpha1 kind: TrafficTarget metadata: name: client-apps namespace: apps destination: kind: ServiceAccount name: apps-server namespace: apps specs: - kind: HTTPRouteGroup name: app-routes matches: - all sources: - kind: ServiceAccount name: apps-client namespace: apps 8 . 7
That’s All Folks! 9 . 1
We Have Stickers! 9 . 2
We Are Hiring! docker run -it containous/jobs 9 . 3
Thank You! @mZapfDE SantoDE Slides (HTML): https://containous.github.io/slides/devops-gathering-2020 Slides
(PDF): https://containous.github.io/slides/devops-gathering-2020/slides.pdf Source on : https://github.com/containous/slides/tree/devops-gathering-2020 10