This document provides an overview and summary of GitLab and DevOps workflows presented by Cheng Wei Chen at the STUDY4 TW .NET Conf 2019. The key points discussed include:
- An introduction to GitLab and its components and architecture.
- A comparison of different software development workflows and an explanation of the GitLab Workflow.
- A discussion of different Git branching strategies including GitLab Flow.
- An overview of GitLab Auto DevOps and how it can automate the DevOps pipeline.
- A reiteration of the main topics and a conclusion on how GitLab supports DevOps practices.
The document discusses GitLab CI/CD, an overview of the types of pipelines in GitLab including how they are defined and can group jobs. It also mentions manual actions, multi-project pipeline graphs, and security on protected branches. Additional topics covered include review apps and environments, application performance monitoring, next steps such as moving from dev to devops, how everyone can contribute to GitLab, and current job openings.
GitOps provides a way for organizations to adopt continuous delivery practices using cloud native technologies like Kubernetes and Docker. It advocates storing all infrastructure configurations and code in a Git repository to enable automated deployment and management of applications. Weaveworks adopted GitOps and was able to recover from a complete system failure in just 45 minutes by having their entire system defined as code. GitOps follows the principles of continuous delivery and observability by integrating deployment pipelines, monitoring, and security policies to drive faster, more reliable software releases.
This document discusses using GitOps and Helm to perform A/B testing with Istio on Kubernetes clusters. It introduces Weave Flux, an open source GitOps operator for Kubernetes that implements a control loop to continuously apply the desired application state from a Git repository. The Weave Flux Helm operator extends this to automate Helm chart releases defined as custom resources. An example is provided of setting up GitOps with Weave Flux and the Helm operator to perform A/B testing on an application by managing different versions through a Helm chart. Links are included to GitOps examples for Helm and Istio configurations.
CI:CD in Lightspeed with kubernetes and argo cdBilly Yuen
?
Enterprises have benefited greatly from the elastic scalability and multi-region availability by moving to AWS, but the fundamental deployment model remains the same.
At Intuit, we have adopted k8s as our new saas platform and re-invented our CI/CD pipeline to take full advantage of k8s. In this presentation, we will discuss our journey from Spinnaker to Argo CD.
1. Reduce CI/CD time from 60 minutes to 10 minutes.
2. Reduce production release (or rollback) from 10 minutes to 2 minutes.
3. Enable concurrent deployment using spinnaker and argo cd as HA/DR to safely adopt the new platform with no downtime.
4. Be compatible with the existing application monitoring toolset.
talked by CI/CD Conference 2021 by CloudNative Days https://event.cloudnativedays.jp/cicd2021
re-upload: https://speakerdeck.com/whywaita/cyberagent-oss-cicd-myshoes-cicd2021
Version control systems like Git allow teams to collaborate on code by automatically backing up work, tracking changes over time, and easily sharing code between collaborators. Git uses repositories to store source code and a branching model like GitFlow to coordinate work between team members on features, releases, and hotfixes in a stable, collaborative way. Key concepts in Git include repositories, working copies, commits, updates, pulls, and pushes used to integrate changes between local and remote repositories.
This document introduces Git Flow, a Git branching model that provides high-level repository operations. It outlines the main branches - master for production, develop for development, and supporting branches like feature, release, and hotfix. Git Flow is a collection of Git extensions that help initialize and manage branches through commands like git flow feature and git flow release. The model forms an easy to understand mental model for teams to share in their branching and releasing processes.
This document provides an overview of Git and how to use it. It discusses version control systems and how distributed version control systems like Git work. It explains how Git was created by Linus Torvalds for Linux kernel development and why it gained popularity due to its speed and efficiency. The document then covers Git basics like setup, commits, branches and workflows. It also introduces tools for using Git in Eclipse and GitLab for code hosting and collaboration.
GitOps è un nuovo metodo di CD che utilizza Git come unica fonte di verità per le applicazioni e per l'infrastruttura (declarative infrastructure/infrastructure as code), fornendo sia il controllo delle revisioni che il controllo delle modifiche. In questo talk vedremo come implementare workflow di CI/CD Gitops basati su Kubernetes, dalla teoria alla pratica passando in rassegna i principali strumenti oggi a disposizione come ArgoCD, Flux (aka Gitops engine) e JenkinsX
The document outlines an effective software release management strategy with multiple layers and branching models. It discusses establishing rigorous development, build, test, and deployment cycles with common environments. It also recommends moving to continuous integration and deployment with tools and processes to support rapid defect detection. Higher level branches have stricter quality criteria than lower ones, with mainline and release branches intended for stable, tested code. The strategy aims to speed delivery, increase quality, reduce costs, and support scalable, efficient development.
Gitlab ci e kubernetes, build test and deploy your projects like a prosparkfabrik
?
This document discusses using GitLab CI and Kubernetes together for continuous integration, delivery, and deployment. It provides an overview of Kubernetes and GitLab, describes how to set up a GitLab runner using the Kubernetes executor, and provides an example YAML configuration. It also covers continuous deployment workflows, running GitLab on Kubernetes, and some tips and tricks as well as techniques for troubleshooting Kubernetes and GitLab CI/CD pipelines.
General description of Release Management within an ITIL-based IT (Infra) Services organization. Find me at https://nl.linkedin.com/in/tijsvanvelthoven for more information
These are the slides for a talk/workshop delivered to the Cloud Native Wales user group (@CloudNativeWal) on 2019-01-10.
In these slides, we go over some principles of gitops and a hands on session to apply these to manage a microservice.
You can find out more about GitOps online https://www.weave.works/technologies/gitops/
This document provides an introduction to Gitlab CI and continuous integration/continuous delivery (CI/CD) workflows. It discusses DevOps practices and the benefits of Gitlab CI. It then covers how to set up Gitlab runners, write a basic Gitlab CI configuration file, define jobs, stages, variables and environments. The document demonstrates concepts like Docker integration, artifacts, auto and manual deployments, and stopping deployments. It concludes with a live demo of a Gitlab CI configuration.
The document provides an introduction to GitOps and Flux. It discusses what GitOps is, how it utilizes version control as a single source of truth for continuous delivery. It then summarizes what Flux is and its key components like the source, kustomize, helm and notification controllers. The document highlights benefits of Flux like reducing developer burden and being extensible. It also briefly mentions new Flux features like OCI support and related tools like the terraform controller, flamingo and Weave GitOps.
Introduction to Gitlab | Gitlab 101 | Training SessionAnwarul Islam
?
I actually described in this slide how to use Gitlab with git. I explained what is git, push, pull, clone, commit etc. so, you can use this slide to learn or tech someone.
Agile Release Management Best PracticesAnmol Oberoi
?
This document discusses best practices for agile release management for Salesforce admins. It recommends setting up a sandbox structure for different stages of development and testing. Key benefits of agile release management include more frequent releases with shorter response times to changes. Best practices include using version control, having rollback strategies, collaborating with others on reviews, and communicating schedules. It suggests adopting agile frameworks to release iteratively in time-boxed sprints. Overall, the document provides guidance on implementing agile processes and tools to streamline releases of Salesforce configurations and applications.
We are more than thrilled to announce the second meetup on 10 December 2022 where we discuss GitOps, ArgoCD and their fundamentals. Inviting SREs, DevOps engineers, developers & platform engineers from all around the world.
Agenda:-
1. GitOps Overview
2. Why and What is GitOps
3. Opensource GitOps tools
4. What is ArgoCD, Architecture
5. Let's Get our hands dirty on ArgoCD
6. Q&A
Acceptance criteria are used to confirm that a user story meets the intended purpose by describing clear outcomes that prove the story is acceptable to the product owner. A definition of done sets fixed criteria that all user stories must meet, such as refactored code, testing, and documentation. A sprint goal is a short description of what the team plans to achieve during a sprint, written by the team and product owner to communicate the sprint's purpose.
This document discusses setting up ArgoCD, an open source tool for continuous delivery for Kubernetes applications, including building and testing source code, deploying Docker images to a registry, and using ArgoCD to apply configuration definitions and deploy applications. It also provides links to additional Dev.to posts and GitHub projects about using Kustomize and secrets management with ArgoCD.
Kubernetes is an open-source system for managing containerized applications and services. It includes a master node that runs control plane components like the API server, scheduler, and controller manager. Worker nodes run the kubelet service and pods. Pods are the basic building blocks that can contain one or more containers. Labels are used to identify and select pods. Replication controllers ensure a specified number of pod replicas are running. Services define a logical set of pods and associated policy for access. They are exposed via cluster IP addresses or externally using load balancers.
This document provides an introduction to the version control system Git. It defines key Git concepts like the working tree, repository, commit, and HEAD. It explains that Git is a distributed version control system where the full history of a project is available once cloned. The document outlines Git's history, with it being created by Linus Torvalds to replace the commercial BitKeeper tool. It then lists and briefly describes important Git commands for local and collaboration repositories, including config, add, commit, log, diff, status, branch, checkout, merge, remote, clone, push, and pull. Lastly, it covers installing Git and generating SSH keys on Windows for accessing Git repositories.
This document introduces Git Flow, a Git branching model that provides high-level repository operations. It outlines the main branches - master for production, develop for development, and supporting branches like feature, release, and hotfix. Git Flow is a collection of Git extensions that help initialize and manage branches through commands like git flow feature and git flow release. The model forms an easy to understand mental model for teams to share in their branching and releasing processes.
This document provides an overview of Git and how to use it. It discusses version control systems and how distributed version control systems like Git work. It explains how Git was created by Linus Torvalds for Linux kernel development and why it gained popularity due to its speed and efficiency. The document then covers Git basics like setup, commits, branches and workflows. It also introduces tools for using Git in Eclipse and GitLab for code hosting and collaboration.
GitOps è un nuovo metodo di CD che utilizza Git come unica fonte di verità per le applicazioni e per l'infrastruttura (declarative infrastructure/infrastructure as code), fornendo sia il controllo delle revisioni che il controllo delle modifiche. In questo talk vedremo come implementare workflow di CI/CD Gitops basati su Kubernetes, dalla teoria alla pratica passando in rassegna i principali strumenti oggi a disposizione come ArgoCD, Flux (aka Gitops engine) e JenkinsX
The document outlines an effective software release management strategy with multiple layers and branching models. It discusses establishing rigorous development, build, test, and deployment cycles with common environments. It also recommends moving to continuous integration and deployment with tools and processes to support rapid defect detection. Higher level branches have stricter quality criteria than lower ones, with mainline and release branches intended for stable, tested code. The strategy aims to speed delivery, increase quality, reduce costs, and support scalable, efficient development.
Gitlab ci e kubernetes, build test and deploy your projects like a prosparkfabrik
?
This document discusses using GitLab CI and Kubernetes together for continuous integration, delivery, and deployment. It provides an overview of Kubernetes and GitLab, describes how to set up a GitLab runner using the Kubernetes executor, and provides an example YAML configuration. It also covers continuous deployment workflows, running GitLab on Kubernetes, and some tips and tricks as well as techniques for troubleshooting Kubernetes and GitLab CI/CD pipelines.
General description of Release Management within an ITIL-based IT (Infra) Services organization. Find me at https://nl.linkedin.com/in/tijsvanvelthoven for more information
These are the slides for a talk/workshop delivered to the Cloud Native Wales user group (@CloudNativeWal) on 2019-01-10.
In these slides, we go over some principles of gitops and a hands on session to apply these to manage a microservice.
You can find out more about GitOps online https://www.weave.works/technologies/gitops/
This document provides an introduction to Gitlab CI and continuous integration/continuous delivery (CI/CD) workflows. It discusses DevOps practices and the benefits of Gitlab CI. It then covers how to set up Gitlab runners, write a basic Gitlab CI configuration file, define jobs, stages, variables and environments. The document demonstrates concepts like Docker integration, artifacts, auto and manual deployments, and stopping deployments. It concludes with a live demo of a Gitlab CI configuration.
The document provides an introduction to GitOps and Flux. It discusses what GitOps is, how it utilizes version control as a single source of truth for continuous delivery. It then summarizes what Flux is and its key components like the source, kustomize, helm and notification controllers. The document highlights benefits of Flux like reducing developer burden and being extensible. It also briefly mentions new Flux features like OCI support and related tools like the terraform controller, flamingo and Weave GitOps.
Introduction to Gitlab | Gitlab 101 | Training SessionAnwarul Islam
?
I actually described in this slide how to use Gitlab with git. I explained what is git, push, pull, clone, commit etc. so, you can use this slide to learn or tech someone.
Agile Release Management Best PracticesAnmol Oberoi
?
This document discusses best practices for agile release management for Salesforce admins. It recommends setting up a sandbox structure for different stages of development and testing. Key benefits of agile release management include more frequent releases with shorter response times to changes. Best practices include using version control, having rollback strategies, collaborating with others on reviews, and communicating schedules. It suggests adopting agile frameworks to release iteratively in time-boxed sprints. Overall, the document provides guidance on implementing agile processes and tools to streamline releases of Salesforce configurations and applications.
We are more than thrilled to announce the second meetup on 10 December 2022 where we discuss GitOps, ArgoCD and their fundamentals. Inviting SREs, DevOps engineers, developers & platform engineers from all around the world.
Agenda:-
1. GitOps Overview
2. Why and What is GitOps
3. Opensource GitOps tools
4. What is ArgoCD, Architecture
5. Let's Get our hands dirty on ArgoCD
6. Q&A
Acceptance criteria are used to confirm that a user story meets the intended purpose by describing clear outcomes that prove the story is acceptable to the product owner. A definition of done sets fixed criteria that all user stories must meet, such as refactored code, testing, and documentation. A sprint goal is a short description of what the team plans to achieve during a sprint, written by the team and product owner to communicate the sprint's purpose.
This document discusses setting up ArgoCD, an open source tool for continuous delivery for Kubernetes applications, including building and testing source code, deploying Docker images to a registry, and using ArgoCD to apply configuration definitions and deploy applications. It also provides links to additional Dev.to posts and GitHub projects about using Kustomize and secrets management with ArgoCD.
Kubernetes is an open-source system for managing containerized applications and services. It includes a master node that runs control plane components like the API server, scheduler, and controller manager. Worker nodes run the kubelet service and pods. Pods are the basic building blocks that can contain one or more containers. Labels are used to identify and select pods. Replication controllers ensure a specified number of pod replicas are running. Services define a logical set of pods and associated policy for access. They are exposed via cluster IP addresses or externally using load balancers.
This document provides an introduction to the version control system Git. It defines key Git concepts like the working tree, repository, commit, and HEAD. It explains that Git is a distributed version control system where the full history of a project is available once cloned. The document outlines Git's history, with it being created by Linus Torvalds to replace the commercial BitKeeper tool. It then lists and briefly describes important Git commands for local and collaboration repositories, including config, add, commit, log, diff, status, branch, checkout, merge, remote, clone, push, and pull. Lastly, it covers installing Git and generating SSH keys on Windows for accessing Git repositories.
Testing in Production, Deploy on FridaysYi-Feng Tzeng
?
本議題是去年 ModernWeb'19 「Progressive Deployment & NoDeploy」的延伸。雖然已提倡 Testing in Production 多年,但至今願意或敢於實踐的團隊並不多,背後原因多是與文化及態度有些關係。
此次主要分享推廣過程中遇到的苦與甜,以及自己親力操刀幾項達成 Testing in Production, Deploy on Fridays 成就的產品。
The document talks about community, mutual trust, and mutual benefit. It discusses how everyone has the opportunity to be a hero to others. It references concepts like community, DevOps, and includes links to photos on Unsplash about networks and affinity. The overall message is about the importance of community and helping one another.
The document discusses Ignite Talks, which are short, fast-paced presentations given at DevOpsDays conferences. Ignite Talks are 5 minutes long with 20 slides that automatically advance every 15 seconds, forcing presenters to keep their message concise and fast-paced. The format aims to expose attendees to many new ideas in a short period of time through short bursts of dense information on a variety of topics.
1. The document discusses the concepts of DevOps, including definitions, principles, and practices.
2. DevOps aims to break down silos between development and operations teams through collaboration, automation, measurement, and sharing of information.
3. Key aspects of DevOps include shifting to a learning culture, increasing automation through practices like continuous integration and delivery, monitoring metrics to provide transparency and feedback, and ensuring collaboration between teams.