class: center, middle # Practices --- # Inhalt 1. Einleitung 2. Continuous Integration 3. Continuous Delivery 4. Continuous Deployment 5. Plattformen & Tools für CI/CD 6. Deployment strategies 7. DevOps 8. DevSecOps 9. SRE --- # Einleitung - Prozess von der Idee bis zum Betrieb --- # Continuous Integration - Was ist Continuous Integration - Vorteile - Build monitoring - Kleinere Code-Merges --- # Continuous Integration Workflow .image[data:image/s3,"s3://crabby-images/01bae/01bae19d0e36ea1510c29286638311490782b5cf" alt="sketch"] --- # Continuous Integration - Build Monitor .image[data:image/s3,"s3://crabby-images/b5c5c/b5c5c546d7fde1c2a968c2c667330eb8434f91cc" alt="buildmonitor"] --- # Continuous Delivery - Erweitert Continuous Integration - Release zu jeder Zeit ermöglichen - Schnellere Entwicklungszyklen .image[data:image/s3,"s3://crabby-images/f201a/f201a3e8cbc21b0c2a0a474a23a812ee23f2e0fd" alt="sketch"] --- # Continuous Deployment - Erweitert Continuous Delivery - Führt ein automatisiertes Deployment durch - Containerization stellt das Verhalten des Builds sicher - Vorteilhaft bei Microservices in einer automatisch gemanagten Umgebung - Hohe Einstiegshürde --- # Continuous Deployment - Zyklus .image[data:image/s3,"s3://crabby-images/60a35/60a35b8e78e29d40f40bdbd3b2a35bc59537e774" alt="ContinuousDeployment"] --- # Plattformen & Tools für CI/CD - Für jeden ist etwas dabei - Jenkins - GitHub Actions - CircleCI - LiveDemo zu GitHub Actions & CircleCI --- # Jenkins - Automatisierungs Server - Hoch flexibel - Konfiguration - Server - Repository - Viele Plugins --- # Jenkins UI .image[data:image/s3,"s3://crabby-images/b8d27/b8d2775bb621685c4c51f6d196cfcee4f9deceea" alt="sketch"] --- # Jenkins - Pipeline #1 ```groovy #!/usr/bin/env groovy pipeline { agent any tools { maven 'Maven-3.6.0' } stages { stage('Clone') { steps{ checkout scm } } stage('Build') { steps { sh 'mvn -B -DskipTests clean package' } } ``` --- # Jenkins - Pipeline #2 ```groovy stage('Test') { steps { sh 'mvn test' } post { always { junit 'target/surefire-reports/*.xml' } } } stage('Deliver') { when { branch 'master' } steps { sh 'mvn deploy' } } } } ``` --- # GitHub Actions - In GitHub intigriert - Im kleinen Umfang kostenlos - GitHub Package Storage enthalten --- # GitHub Actions - Pipeline #1 ```yaml name: Docker Image CI on: push: branches: [ master ] release: types: [published] jobs: build: runs-on: ubuntu-latest ``` --- # GitHub Actions - Pipeline #2 ```yaml steps: - uses: actions/checkout@v1 - name: Login to DockerHub Registry run: echo ${{ secrets.DOCKERHUB_PASSWORD }} | docker login -u ${{ secrets.DOCKERHUB_USERNAME }} --password-stdin - name: Build the tagged Docker image run: docker build . --file Dockerfile --tag dasbene/continuousx:$GITHUB_SHA - name: Push the tagged Docker image run: docker push dasbene/continuousx:$GITHUB_SHA - name: Build the latest Docker image run: docker build . --file Dockerfile --tag dasbene/continuousx:latest - name: Push the latest Docker image run: docker push dasbene/continuousx:latest ``` --- # CircleCI - Einfach zu bedienen - Gute GitHub Integration .image[data:image/s3,"s3://crabby-images/d5c37/d5c37b31d75677b0b50948af160b6a81c7e92d19" alt="sketch"] --- # CircleCI - Pipeline ```yaml version: 2.1 orbs: node: circleci/node@1.1.6 jobs: build-and-test: executor: name: node/default steps: - checkout - node/with-cache: steps: - run: npm install - run: npm test workflows: build-and-test: jobs: - build-and-test ``` --- # Sonstige Plattformen - [TravisCI](https://travis-ci.org/) - AWS Code Build & CodePipeline - Google Cloud Build - Azure Pipelines - GitLab - Docker Hub --- class: center, middle # Live Demo --- # Deployment strategies - Wie wird der release Build zum laufen gebracht? - *Continuous Delivery Patterns* - Strategien - Recreate - Blue / Green - Shadow - Canary - Ramped / Rolling - A/B testing --- # Recreate .image[data:image/s3,"s3://crabby-images/89463/89463e51c86ace7bef6d6a1182b51860ea40caa4" alt="Recreate"] --- # Blue / Green .image[data:image/s3,"s3://crabby-images/cd38b/cd38b0f33bc0cb9b25f1d0855dd0ac99013fec57" alt="Recreate"] --- # Canary .image[data:image/s3,"s3://crabby-images/82539/825399d4c5540f0d7b61aac5d763a8f6e880c78a" alt="Recreate"] --- # Ramped / Rolling .image[data:image/s3,"s3://crabby-images/c4c3f/c4c3f4832fa3ffcd3c4359cecccf33ff03cf6825" alt="Recreate"] --- # Shadow .image[data:image/s3,"s3://crabby-images/c9c14/c9c143aae6f239a490dcea2880bd42dd11958140" alt="Recreate"] --- # A/B testing .image[data:image/s3,"s3://crabby-images/70093/70093a428f6fed6c0cb50d23f2d382d8bbdb3dc9" alt="Recreate"] --- # Weitere deployment strategies - Feature Flags - Dark Launching --- # DevOps ### Wesentlche Kenngrößen von Development: - neue Features - behobende Fehler ### Wesentlche Kenngrößen von IT-Operations: - Verfügbarkeit - Stabilität ### Widerspruch? --- # DevOps als Kultur - Tauziehen zwischen Dev und Ops auflösen - Pipeline von der Idee bis zum Auswerten der Operations Erfahrungen - Multidisziplinäre Teams - Workflow .image[data:image/s3,"s3://crabby-images/9dd21/9dd21c2634755d71b33f6f5aef537b98cbe6eed1" alt="DevOpsPipeline"] --- # DevOps - Zyklus .image[data:image/s3,"s3://crabby-images/dedba/dedbafd0c87c7d194b73d0bbca3b4ae075ba887a" alt="DevOpsPipeline"] --- # DevOps - Ziele - Schnellere Auslieferung von neuen Funktionen - Schnellere Auslieferung von Änderungen - Höhere Qualität der Auslieferungen - Schnellere Reaktionszeit Fehler zu beheben --- # DevOps - Unterstützende Technologien - Continuous Deployment - Containerisierung - Microservices - Cloud native computing --- # DevSecOps - Variante von *DevOps* - Fokus auf Sicherheit - Transparenz des Workflow --- # DevSecOps - Anforderungen Zusätzliche Workflow Anforderungen: - Test-driven development - Pair Programming - Linting - Vulnerability scanning - Cloud nativ deployment --- # DevSecOps - Vorteile - Sicherere Software - Audit der Software - Compliance - Gesundheitswesen - Finanzwesen - Öffentliche Aufträge --- # SRE (Site Reliability Engineering) - Von Google entwickelt - seit 2003 - Teams 50/50 - Software Development - System Administration
> SRE is "what happens when a software engineer is tasked with what used to be called operations." > > --
Ben Treynor
--- # SRE - Unterschiede zu DevOps - *Implementierung von DevOps* --- # SRE - Säulen - *Reduce organizational silos* - *Accept failure as normal* - *Implement gradual changes* - *Leverage tooling and automation* - *Measure everything* --- class: center, middle # Fragen? --- # Quellen - CI/CD - https://new.siemens.com/global/de/produkte/automatisierung/industrie-software/automatisierungs-software/tia-portal/highlights/continuous-integration.html - https://www.atlassian.com/continuous-delivery/continuous-integration/how-to-get-to-continuous-integration - https://www.atlassian.com/continuous-delivery/continuous-deployment - https://dzone.com/articles/what-is-continuous-delivery-the-benefits-and-best - Jenkins - https://plugins.jenkins.io/build-monitor-plugin/ - https://www.jenkins.io/doc/tutorials/build-a-java-app-with-maven/ - CircleCI - https://jaxenter.de/der-softwarelieferheld-45524 --- # Quellen - Deployment strategies - https://thenewstack.io/deployment-strategies/ - https://dev.to/mostlyjason/intro-to-deployment-strategies-blue-green-canary-and-more-3a3 - https://docs.cloudfoundry.org/devguide/deploy-apps/blue-green.html - https://rollout.io/blog/rolling-deployment/ - https://medium.com/@Cycligent/pros-and-cons-of-5-popular-continuous-delivery-patterns-e2998af002ff - https://de.wikipedia.org/wiki/Datei:Un-flag-square.png - https://de.wikipedia.org/wiki/Flagge_Deutschlands#/media/Datei:Flag_of_Germany.svg - Dev[Sec]Ops - https://www.plm.automation.siemens.com/media/global/de/polarion-devops_tcm53-26359.png - https://www.youtube.com/watch?v=J73MELGF6u0 - https://www.youtube.com/watch?v=UbtB4sMaaNM - SRE - https://landing.google.com/sre/ - https://www.youtube.com/watch?v=uTEL8Ff1Zvk - https://landing.google.com/sre/interview/ben-treynor-sloss/