In addition to Weibo, there is also WeChat
Please pay attention
WeChat public account
Shulou
2025-01-14 Update From: SLTechnology News&Howtos shulou NAV: SLTechnology News&Howtos > Servers >
Share
Shulou(Shulou.com)05/31 Report--
This article will explain in detail how to analyze the principle of GitOps. The content of the article is of high quality, so the editor will share it for you as a reference. I hope you will have a certain understanding of the relevant knowledge after reading this article.
Maybe you've heard of GitOps before, but you don't know anything about it. In this article, I will briefly introduce it, which is actually a term in application development and management, whose core idea is to store the application's declarative infrastructure and applications in Git's version control library. We'll talk about what GitOps is, how it will affect your organization, and how to stay in sync with Kubernetes.
What is GitOps?
GitOps is a continuous delivery model that uses Git development tools to operate and manage cloud native applications. When deploying an application to Kubernetes, Git should be the only source of fact. When developers change applications, Git automatically push them to Kubernetes for deployment. Moreover, if the running state within the Kubernetes changes but is inconsistent with the state within the Git, they will revert to the known state from within the Git.
GitOps and CI/CD: what is the connection between them?
GitOps and CI/CD are very important partners. CI/CD allows developers to iterate, develop, and deploy applications continuously. Iterations are usually done through a Git configuration repository (although there will be other configuration repositories as well). During the deployment / delivery phase, the built container-based application is "push" to Kubernetes for deployment. GitOps enhances the CI/CD model through Kubernetes's use of "pull" to bring the operation and maintenance level into deployment / delivery.
But what happens if someone changes something running in the Kubernetes cluster? We will use Git as the primary source of facts for declarative deployment tools and other tools to alert us when differences occur. In addition, Kubernetes can be fixed to a known / declared running state by using tools that can identify the difference between the running state and the declared state.
Note: continuous integration and continuous development are complementary but independent processes. Ideally, GitOps would split the batch size into a single process, processing only one unit at a time. However, because the CI and CD processes occur in different groups, the processes may be different between organizations.
GitOps and application lifecycle
Let's look at the role of GitOps from the perspective of the application life cycle. In a typical lifecycle, an application goes through several states, including:
Code
Construction
Create a mirror
test
Publish
With GitOps, these states will be expanded to:
Deployment
Monitor changes in the Git repository
Log changes and events
Alert when changes occur and integrate with existing monitoring / alarm systems
Update
Under the GitOps operating model, when an application is released, Kubernetes needs to ensure that it works as expected. At the same time, Kubernetes manages the operation and maintenance of the application by ensuring its stability and availability. If a developer changes the application through Git, Kubernetes will accept the declaration and apply it as needed.
What did GitOps bring?
GitOps provides an operational model for applications, which ensures that Git provides a framework to unify the operation, operation, and continuous development of applications.
As part of the CI/CD pipeline, GitOps provides glue between where the application is built / delivered and where it is run.
In the Kubernetes platform, Git provides the only factual source for application development and operation and maintenance.
Application delivery and platform management are declarative, while versioning can be done through Git
Git can control rollbacks, upgrades, and changes
Developers do not need to know how to operate an operation and maintenance platform (such as Kubernetes), nor do they need to understand the complex deployment delivery process, they just need to release new features using familiar tools. Greatly improve the developer experience.
Git controls and repairs differences or "drift"
GitOps uses audit, monitoring, and rollback capabilities to increase the reliability and stability of application releases
Finally, although there is still a lot of work to be done in the GitOps mode, there is a significant synergy between GitOps, DevOps and the existing CI/CD mode. GitOps provides a model for delivering applications to the Kubernetes platform, which ensures that Git is the only source of fact and takes full advantage of the capabilities on the Kubernetes platform. It is worth noting, however, that GitOps is not a substitute for tools. On the contrary, GitOps uses declarative processes and tools to strengthen processes, improve their maturity, and help teams deliver applications.
GitOps practice: FluxCD Demo
FluxCD (or Flux) is a great tool that integrates Git and Kubernetes. Flux is essentially a Kubernetes Operator, which means that you, as an administrator, can install it into Kubernetes to manage the integration between Git and native Kubernetes.
In Kubernetes, Operator is an extension of the Kubernetes native platform and is a pattern for customizing resources that are mainly used to manage applications and their components. This means that with the help of Kubernetes's internal Operator, the required state (such as running status) will be constantly checked and adjusted to match the content of the Git repository declaration. Flux can be integrated into your existing CI/CD toolset for other workflows, permission approvals, and audits. In Kubernetes, Flux will monitor whether the Git repository you declare through configuration has changed, and if there are local changes on Kubernetes Pod that should not have occurred, Flux will update Kubernetes to the desired running state. Keep in mind that Git is the source of facts. Flux Operator detects this and changes the running configuration back to the declared state.
The following demo, I will show you how to install and implement Flux.
Preparation in advance
You will need:
A Docker Hub image repository where you can upload Flaskapp docker images.
A Git Repo and connect it, and then you can replace it with your settings as needed throughout the presentation. "
< >"anything in"
Concrete steps
Install Kubernetes
Install and configure the native installer for fluxctl,Flux deployment
Configure Flux to connect to Git Repo
Upgrade deployment manifest in Git Repo
Upgrade container image and synchronize
Configure drift (drift) and synchronize
You can use the following configuration for testing or demonstration. It includes the Docker file of the Flask application and the Kubernetes deployment/ configuration file. You will need them in the demo, and you can also upload them to your designated Git repository.
Docker File
FROM python:3 RUN pip install flask RUN mkdir-p / corp/app WORKDIR / corp/app COPY main.py. ENV FLASK_APP=/corp/app/main.py ENV APP_NAME=MyApp.DevOps ENV APP_VERSION=v1.0.0 CMD ["flask", "run", "--host=127.0.0.1"]
Main.py Python script file
Import osfrom flask import Flaskapp = Flask (_ _ name__) @ app.route ('/') def index (): appname = os.environ ['APP_NAME'] appversion = os.environ [' APP_VERSION'] response = "% s -% s% s\ n"% ('Hello World', appname, appversion) return response
Kubernetes Deployment file
ApiVersion: v1 kind: Namespace metadata: name: my-demo-apiVersion: apps/v1 kind: Deployment metadata: name: fluxdemo namespace: my-demo annotations: flux.weave.works/tag.flask: glob:develop-v* flux.weave.works/automated: 'true' labels: role: fluxdemo env: demo app: flux spec: replicas: 1 selector: matchLabels: role: fluxdemo template: metadata: labels : role: fluxdemo spec: containers:-name: nginx image: nginx:1.16-perl imagePullPolicy: IfNotPresent ports:-name: http containerPort: 80 volumeMounts:-name: nginx-proxy-config mountPath: / etc/nginx/conf.d/default.conf subPath: nginx.conf -name: flask image: docker.io//flaskapp:develop-v1.8.0 imagePullPolicy: IfNotPresent ports:-name: http containerPort: 5000 env:-name: APP_NAME value: myfluxdemo.K8s.GitOps-name: APP_VERSION value: v1.0.5 volumes:-name: nginx-proxy -config configMap: name: nginx-conf-apiVersion: v1kind: ConfigMap metadata: name: nginx-conf namespace: my-demodata: nginx.conf: |-# CODE1.0: # add the nginx.conf configuration-this will be referenced within the deployment.yaml server {listen 80 Server_name localhost; location / {proxy_pass http://localhost:5000/; proxy_set_header Host "localhost";}} install Flux
Install Fluxctl
Https://docs.fluxcd.io/en/1.18.0/references/fluxctl.html
Install Fluxcd
Https://docs.fluxcd.io/en/1.18.0/tutorials/get-started.html
Configure Flux for Repo
Create a namespace
Kubectl create ns export FLUX_FORWARD_NAMESPACE= fluxctl list-workloads
Install Fluxcd to establish a connection to your Git Repo
Export GHUSER= "" export REPO= "gitops-demo" export NS= "flux" fluxctl install\-git-user=$ {GHUSER}\-git-email=$ {GHUSER} @ users.noreply.github.com\-git-url=git@github.com:Image download failed. {REPO}\-namespace=$ {NS} | kubectl apply-f-create a SSH key to add to the Github repository
Enter the following command in your terminal to get the key you need for the next step:
Fluxctl identity
Open Github, navigate to the repository added when installing Fluxcd, go to Settings-deployment key, click * * add deployment key * *, specify title for it, select * * allow write access * *, paste the public key, and then click * * add key * *.
Upgrade Deployment Manifest in Git Repo
Open your Git Repo, which should contain the deployment.yaml file, slide down to the section shown below, and then change the APP_VERSION number
Env:-name: APP_NAME value: myfluxdemo.K8s.GitOps-name: APP_VERSION value: v1.0.5
Save and Commit changes to your Repo.
Flux will upgrade your deployment in 5 minutes.
To test from localhost, use the "Port-forward" command in Kubernetes:
Kubectl get pods-n copy the pod name kubectl port-forward 8080 80-n
Open another terminal:
Curl-s-I http://localhost:8080 upgrade container image and synchronize
Now let's modify the Docker image and upload it to our Docker Hub image repository. To do this, we will modify the main.py file in the flaskapp directory.
Upgrade the main.py file. Change Hello World to something else
Response = "% s -% s.% s\ n"% ('Flux World', appname, appversion)
Create a new Docker file and upload it to Docker (and another incremental version number).
Wait 5 minutes and Flux will automatically deploy the new image.
Configure drift and synchronize
Now, let's test what happens if you manually change the running configuration.
Kubectl scale deployment/fluxdemo-- replicas=4-n
Now, let's take a few minutes to look at pod and see what happens. We will see other pod in a short time (within 5 minutes), and we will also see many pod terminations. As a result, Flux has restored the configuration to the declared deployment state currently retained in Git.
Kubectl get po-n-- watch
Rerun the same command, and you will see that there is only one pod currently running.
Don't forget to clean up and remove deployment and Git connections (if you want to remove it). Otherwise, you need to start adding more repositories and continue to build.
On how to carry out the principle analysis of GitOps is shared here, I hope the above content can be of some help to you, can learn more knowledge. If you think the article is good, you can share it for more people to see.
Welcome to subscribe "Shulou Technology Information " to get latest news, interesting things and hot topics in the IT industry, and controls the hottest and latest Internet news, technology news and IT industry trends.
Views: 0
*The comments in the above article only represent the author's personal views and do not represent the views and positions of this website. If you have more insights, please feel free to contribute and share.
Continue with the installation of the previous hadoop.First, install zookooper1. Decompress zookoope
"Every 5-10 years, there's a rare product, a really special, very unusual product that's the most un
© 2024 shulou.com SLNews company. All rights reserved.