Slide 1

Slide 1 text

§ Was SIE ERWARTET § Pragmatische Sicht auf Cloud-Native § Was? Warum? Wie? Wo? § Methodiken, Praktiken & Patterns § Verteilte Anwendungen mit Dapr § Automatisierung auf allen Ebenen § End-to-End Beispielanwendung § .NET-Code (und ein bisschen Go) § Lokal und in der Cloud § Terminal & CLIs § Was SIE NICHT ERWARTET § Einführung in Docker, Kubernetes oder Azure § Deep Dives in Docker, Kubernetes oder Azure § Windows 🙈 § Klicki-Bunti in Visual Studio 😇 § Businessaspekte, wie Business Domain Modeling oder SaaS § Cloud-Native Security Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Kein Hands-On für Teilnehmer 1

Slide 2

Slide 2 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Kenny Pflug https://thinktecture.com/kenny-pflug Software Architect @feO2x Thorsten Hans https://thinktecture.com/thorsten-hans Consultant @thorstenhans

Slide 3

Slide 3 text

Consultant @ Thinktecture AG #Cloud-Native #Kubernetes #Azure #WebAssembly Thorsten Hans Moderne End-to-End-Architekturen in der Praxis Cloud-Native-Workshop [email protected] thinktecture.com thorsten-hans.com @ThorstenHans

Slide 4

Slide 4 text

§ Distributed Systems with ASP.NET Core § .NET internals § Cloud-native [email protected] @feO2x https://www.thinktecture.com Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Kenny Pflug Consultant @ Thinktecture AG 4

Slide 5

Slide 5 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis The agenda for today 5 Intro / Story Block I: 9:00 – 10:30 Architecture / Technology / Code Block II: 11:00 – 12:30 Architecture / Technology / Code Block III: 13:30 – 15:00 Automation / Code / Recap Closing Q ‘n’ A Block IV: 15:30 – 17:00

Slide 6

Slide 6 text

BLOCK I Introduction Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 6

Slide 7

Slide 7 text

D E M O Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 7

Slide 8

Slide 8 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis End-to-End Demo Application 8

Slide 9

Slide 9 text

Myth Busting & Definitions Aka “WTF?” Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 9

Slide 10

Slide 10 text

Cloud-Native What is it NOT Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 10 Myth Busting & Definitions

Slide 11

Slide 11 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 11 Myth Busting & Definitions

Slide 12

Slide 12 text

Cloud-Native What is it Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 12 Myth Busting & Definitions

Slide 13

Slide 13 text

”… is highly distributed, must operate in a constantly changing environment, and is itself constantly changing.” Cornelia Davis, Author of Cloud Native Patterns: Designing change-tolerant software Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Cloud-Native Software 13 Myth Busting & Definitions

Slide 14

Slide 14 text

Myth Busting & Definitions Cloud-Native Software Yes, it is all about Linux. Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 14

Slide 15

Slide 15 text

Disadvantages of Windows Containers • Bigger in size • longer push/pull times • Require more storage (affects Kubernetes & PaaS) • Higher resource consumption • Windows Containers & Hosts need more CPU & memory • Direct impact on infrastructure budged • Host & container OS must have same version (strict policy) • https://kubernetes.io/docs/concepts/windows/intro/#windows-os-version-support • Meaning you may end up with way more infrastructure Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Cloud-Native Software 15 Myth Busting & Definitions

Slide 16

Slide 16 text

Myth Busting & Definitions Cloud-Native Candidate Applications Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 16

Slide 17

Slide 17 text

§ Strategic enterprise systems that need to constantly evolve business capabilities/features § Application that requires a high release velocity - with high confidence § System where individual features must release without a full redeployment of the entire system § Application developed by teams with expertise in different technology stacks § Application with components that must scale independently § ℹ Smaller, less impactful LOB applications might fare well with a simple monolithic architecture hosted in a Cloud PaaS environment Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Candidates for Cloud-Native 17 Myth Busting & Definitions

Slide 18

Slide 18 text

Cloud-Native & Microservices Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 18 Myth Busting & Definitions

Slide 19

Slide 19 text

Cloud-Native Attributes What & why Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 19

Slide 20

Slide 20 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 20 Availability Scalability Resiliency Configurability Observability Cloud-Native Applications Cloud-Native Attributes

Slide 21

Slide 21 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 21 Availability Scalability Resiliency Configurability Observability Cloud-Native Applications Cloud-Native Attributes

Slide 22

Slide 22 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 22 Availability Scalability Resiliency Configurability Observability Cloud-Native Applications Cloud-Native Attributes

Slide 23

Slide 23 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 23 Availability Scalability Resiliency Configurability Observability Cloud-Native Applications Cloud-Native Attributes

Slide 24

Slide 24 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 24 Availability Scalability Resiliency Configurability Observability Cloud-Native Applications Cloud-Native Attributes

Slide 25

Slide 25 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 25 Availability Scalability Resiliency Configurability Observability Cloud-Native Applications Cloud-Native Attributes

Slide 26

Slide 26 text

Cloud-Native Landscape Complex affairs Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 26

Slide 27

Slide 27 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Our Brainstorming… 27 … there is a lot of infrastructure- related stuff ! Cloud-Native Landscape

Slide 28

Slide 28 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 28 https://landscape.cncf.io/ Cloud-Native Landscape

Slide 29

Slide 29 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 29 https://twitter.com/GeertBaeke/status/1577704842541285379 Cloud-Native Landscape

Slide 30

Slide 30 text

Cloud-Native & Cloud What’s in a name? Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 30

Slide 31

Slide 31 text

"Cloud is about where we're computing. Cloud-Native is about how.” Cornelia Davis, Author of Cloud Native Patterns: Designing change-tolerant software Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 31 Cloud-Native & Cloud

Slide 32

Slide 32 text

From Build vs. Buy to Run vs. Rent Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 32 Cloud-Native & Cloud

Slide 33

Slide 33 text

Cloud Agnosticism Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 33 Cloud-agnostic Cloud vendor-coupled More complex Complex Cloud-Native & Cloud

Slide 34

Slide 34 text

Cloud Agnostism Going fully cloud-agnostic leads to re-implementing stuff that’s already there Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 34 Cloud-Native & Cloud

Slide 35

Slide 35 text

Hosting Options Running Cloud-Native applications Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 35

Slide 36

Slide 36 text

§ We can choose and mix from the continuum Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Cloud Compute Continuum PaaS IaaS On-Premises Serverless 36 Managed Kubernetes Hosting options

Slide 37

Slide 37 text

§ Cloud-Native is not “just using” Kubernetes § Kubernetes is a powerful platform (orchestrator) to build and run cloud-native applications § Leverage Kubernetes patterns and capabilities to address certain cloud-native “ilities” § Kubernetes is a driver to become cloud-agnostic Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Cloud-Native & Kubernetes 37 Hosting options

Slide 38

Slide 38 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Hosting Options - Comparison 38 Hosting options 0 = worst / 3 = best

Slide 39

Slide 39 text

BLOCK II Applying proven techniques to .NET applications Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 39

Slide 40

Slide 40 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 40 D E M Patterns

Slide 41

Slide 41 text

Configurability by Example with IConfiguration Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis .NET by Example https://docs.microsoft.com/en-us/aspnet/core/fundamentals/configuration/ 42 Techniques & Practices

Slide 42

Slide 42 text

Observability by Example Individual Health Checks Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis https://docs.microsoft.com/en-us/aspnet/core/host-and-deploy/health-checks 43 Techniques & Practices

Slide 43

Slide 43 text

Configuration by Example Integrate with the network environment Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis https://docs.microsoft.com/en-us/aspnet/core/host-and-deploy/proxy-load-balancer 44 Techniques & Practices

Slide 44

Slide 44 text

Redefined Responsibilities E.g.: Application devs do not configure HTTPS in the application Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 45 Techniques & Practices

Slide 45

Slide 45 text

Observability by Example Logging simplified Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis https://docs.microsoft.com/en-us/aspnet/core/fundamentals/logging/ 46 Techniques & Practices

Slide 46

Slide 46 text

Observability by Example Distributed Tracing with OpenTelemetry Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis https://opentelemetry.io/docs/instrumentation/net/getting-started/ 47 Techniques & Practices

Slide 47

Slide 47 text

Observability by Example Metrics with OpenTelemetry Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 48 Techniques & Practices

Slide 48

Slide 48 text

Containerization Create & use Docker Images Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 49 Techniques & Practices

Slide 49

Slide 49 text

BLOCK III Cloud-Native Patterns & Implementations Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 50

Slide 50

Slide 50 text

§ Execution independence / Hosting-agnostic § Different programming / tech stacks § Running anywhere § Resiliency § Location transparency § Error handling, retries § Decoupling § Robustness § Async business processes § Observability § Seeing everything end-to-end § Tracing, logging, metrics 💡 Nice to have help here § Proven patterns § Support by libraries, SDK, runtime Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Cloud-Native applications - Some tedious parts 51 Patterns & Implementations

Slide 51

Slide 51 text

§ Portable, event-driven runtime for building distributed applications § Open-source, community-driven, vendor-neutral § Prevents developers reinventing the wheel, esp. complex wheels § Making developers lives easier with consistent approach § Productivity tool, when having different § Generations of software types (greenfield and brownfield) § Languages & frameworks § Team formations ➡ Dapr as a common lingua franca Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Dapr: Distributed Application Runtime - for Cloud-Native 52 Patterns & Implementations

Slide 52

Slide 52 text

Cloud-Native-Workshop Dapr Building Blocks Moderne End-to-End-Architekturen in der Praxis 53 Patterns & Implementations

Slide 53

Slide 53 text

Cloud-Native-Workshop Dapr Sidecar: Separating Concerns Moderne End-to-End-Architekturen in der Praxis daprd 54 Patterns & Implementations

Slide 54

Slide 54 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 55 Components: Abstracting Access to “Things” Patterns & Implementations

Slide 55

Slide 55 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 56 https://github.com/dapr/components-contrib/tree/master/pubsub Patterns & Implementations

Slide 56

Slide 56 text

Cloud-Native-Workshop Service Invocation: Interception Moderne End-to-End-Architekturen in der Praxis 57 Patterns & Implementations

Slide 57

Slide 57 text

Cloud-Native-Workshop On-Premises oder in der Cloud – mit Dapr 58 Publish & Subscribe: Decoupling Patterns & Implementations

Slide 58

Slide 58 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Input / Output Bindings & Triggers 59 Patterns & Implementations

Slide 59

Slide 59 text

BLOCK IV Automation in Cloud-Native Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 60

Slide 60

Slide 60 text

Automation in Cloud-Native The key to success! Automate EVERYTHING Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 61 Automation

Slide 61

Slide 61 text

“Everything that can be automated, should be automated.” Kevin Hoffman & Dan Nemeth, Author of Cloud Native Patterns: Designing change-tolerant software Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 62 Automation

Slide 62

Slide 62 text

“Anything you do more than once per day is a candidate for automation.” Kevin Hoffman & Dan Nemeth, Author of Cloud Native Patterns: Designing change-tolerant software Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 63 Automation

Slide 63

Slide 63 text

Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Automation Layers Inner-Loop Infrastructure CI & CD Automation 64

Slide 64

Slide 64 text

Inner-Loop Automate everything you need to do while developing locally Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 65 Automation

Slide 65

Slide 65 text

Infrastructure Automate your cloud-infrastructure by applying Infrastructure-as-Code Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 66 Automation

Slide 66

Slide 66 text

Continuous Integration Build, Test, and Package every application component independently and automatically Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 67 Automation

Slide 67

Slide 67 text

Deployment Deploy every component independently and automatically Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 68 Automation

Slide 68

Slide 68 text

Deployment Embrace either Continuous Deployment or GitOps Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 69 Automation

Slide 69

Slide 69 text

Recap Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis 71

Slide 70

Slide 70 text

§ Was Sie gesehen haben § Pragmatische Sicht auf Cloud-Native § Was? Warum? Wo? Wie? § Methodiken, Praktiken & Patterns § Verteilte Anwendungen mit Dapr § Automatisierung auf allen Ebenen § End-to-End Beispielanwendung § .NET-Code (und ein bisschen Go) § Lokal und in der Cloud § Terminal & CLIs § Was Sie nicht gesehen haben § Einführung in Docker, Kubernetes oder Azure § Deep Dives in Docker, Kubernetes oder Azure § Windows 🙈 § Klick-Bunti in Visual Studio 😇 § Businessaspekte, wie Business Domain Modeling oder SaaS § Cloud-Native Security Cloud-Native-Workshop Moderne End-to-End-Architekturen in der Praxis Summary 72

Slide 71

Slide 71 text

https://www.thinktecture.com/ueber-uns/karriere/ Dankeschön! Kenny Pflug https://thinktecture.com/kenny-pflug Demos aus der Session: https://github.com/thinktecture-labs/ cloud-native-sample https://www.thinktecture.com/wissen/ Thorsten Hans https://thinktecture.com/thorsten-hans 73