"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > GitOps: 소프트웨어 제공 및 인프라 관리의 판도를 바꾸는 도구

GitOps: 소프트웨어 제공 및 인프라 관리의 판도를 바꾸는 도구

2024-08-15에 게시됨
검색:210

소프트웨어 배포를 관리하기 위해 여러 도구와 프로세스를 저글링하는 데 지치셨나요? DevOps 세계를 휩쓸고 있는 판도를 바꾸는 접근 방식인 GitOps를 만나보세요. GitOps가 무엇인지, 왜 이것이 여러분이 찾고 있던 솔루션인지, 그리고 실제 회사들이 GitOps를 사용하여 운영을 어떻게 변화시키고 있는지 알아보겠습니다.

GitOps에 대한 소문은 무엇입니까?

코드부터 인프라까지 전체 시스템이 Git 저장소에 깔끔하게 패키징되어 있는 세상을 상상해 보세요. 깔끔한 것 같죠? 간단히 말해서 GitOps입니다. 2017년에 탄생한 Weaveworks의 아이디어는 조직이 소프트웨어를 관리하고 제공하는 방법을 재정의하고 있습니다.

GitOps: The Game-Changer in Software Delivery and Infrastructure Management

GitOps 101: 기본 사항

그렇다면 GitOps는 어떻게 작동하나요? 분석해 보겠습니다.

  1. 코드 및 구성 준비: 모든 것은 코드와 구성 파일로 시작됩니다. 이는 전체 시스템의 청사진과 같습니다.
  2. Git 푸시: 변경사항이 있나요? Git으로 푸시하면 됩니다. 모든 것을 위한 원스톱 상점입니다.
  3. 지속적 통합의 마법: 변경 사항을 커밋하면 GitHub Actions와 같은 CI 도구가 작동됩니다. 그들은 앱을 구축하고, 테스트를 실행하고, 심지어 보안 문제도 검색합니다.
  4. 컨테이너 이미지: 모든 확인을 통과하시겠습니까? 엄청난! 코드는 깔끔한 컨테이너 이미지로 압축됩니다.
  5. 이미지 레지스트리: 이러한 이미지는 중앙 레지스트리에서 작업 준비가 완료된 집을 찾습니다.
  6. 지속적 배포: ArgoCD 또는 Flux와 같은 도구는 Git 저장소를 감시하여 시스템이 항상 Git에 있는 것과 일치하는지 확인합니다.

GitOps를 좋아하게 될 이유

  1. 생산성 향상: 수동 작업이 줄어들어 멋진 일에 더 많은 시간을 할애할 수 있습니다.
  2. 완벽한 안정성: 이런 순간이 있나요? 걱정 마세요. 롤백하는 것은 매우 쉽습니다.
  3. Fort Knox 보안: 보안 검사가 프로세스에 바로 적용됩니다.
  4. Crystal Clear 감사 추적: 누가 언제 무엇을 했습니까? Git에는 모든 것이 있습니다.
  5. 신속한 복구: 재해가 발생했습니까? 그 어느 때보다 빠르게 되돌아옵니다.

실제 GitOps

개발, 테스트, 프로덕션 중 무엇이든 GitOps가 도와드립니다. 환경이 완벽하게 조화를 이루도록 보장하여 문제를 조기에 포착합니다. 하지만 우리의 말만 믿지 말고 실제 성공 사례를 살펴보겠습니다.

  1. Weaveworks: GitOps 개척자

이 용어를 만든 회사보다 누구부터 시작하는 것이 더 좋을까요? Weaveworks는 GitOps를 사용하여 자체 인프라를 관리합니다.

  • 이 회사는 오픈 소스 GitOps 도구인 Flux를 사용하여 다양한 클라우드 제공업체에서 수십 개의 클러스터를 관리합니다.
  • 마이크로서비스와 데이터베이스를 포함한 전체 플랫폼은 Git 리포지토리에 정의되어 있습니다.
  • 결과: 배포 시간이 몇 시간에서 몇 분으로 단축되고 시스템 안정성이 향상되었습니다.

예:

   # Sample Flux HelmRelease for a microservice
   apiVersion: helm.fluxcd.io/v1
   kind: HelmRelease
   metadata:
     name: my-app
     namespace: default
   spec:
     releaseName: my-app
     chart:
       repository: https://charts.mycompany.com
       name: my-app
       version: 1.2.3
     values:
       replicaCount: 3
       image:
         repository: myregistry.azurecr.io/my-app
         tag: v1.0.0

Git의 이 YAML 파일은 Helm을 사용하여 "my-app" 애플리케이션을 자동으로 배포하고 업데이트합니다.

  1. Ticketmaster: GitOps를 통한 확장

전 세계적으로 수백만 장의 이벤트 티켓을 처리하는 Ticketmaster는 대규모 Kubernetes 인프라를 관리하기 위해 GitOps를 채택했습니다.

  • ArgoCD를 사용하여 200개 이상의 Kubernetes 클러스터를 관리합니다.
  • 모든 애플리케이션 구성 및 인프라 정의는 Git에 저장됩니다.
  • 이점: 배포 일관성이 향상되고 사고 복구 시간이 단축됩니다.

ArgoCD 애플리케이션 매니페스트의 예:

   apiVersion: argoproj.io/v1alpha1
   kind: Application
   metadata:
     name: ticketing-service
     namespace: argocd
   spec:
     project: default
     source:
       repoURL: https://github.com/ticketmaster/ticketing-service.git
       targetRevision: HEAD
       path: k8s
     destination:
       server: https://kubernetes.default.svc
       namespace: production
     syncPolicy:
       automated:
         prune: true
         selfHeal: true
  1. Financial Times: 멀티 클라우드를 위한 GitOps

Financial Times는 GitOps를 사용하여 여러 클라우드 제공업체의 인프라를 관리합니다.

  • Flux를 사용하여 AWS, Google Cloud, 온프레미스의 클러스터를 관리합니다.
  • 모든 인프라 변경 사항은 Git 풀 요청을 거쳐 적절한 검토 및 감사 추적을 보장합니다.
  • 결과: 더 빠르고 안정적인 배포와 더 쉬운 멀티 클라우드 관리.

고급 GitOps: 호기심 많은 사람들을 위한

GitOps에 익숙해지면 다음을 탐색해 볼 수도 있습니다.

  • 풀 모델과 푸시 모델: 필요에 따라 취향을 선택하세요.
  • 드리프트 감지: 시스템을 항상 점검하세요.
  • 멀티 클러스터 관리: 전문가처럼 여러 Kubernetes 클러스터를 관리하세요.
  • 비밀 관리: 해당 API 키와 자격 증명을 비밀로 유지하세요.

길은 덜 평탄하다

현실적으로 생각해보자. GitOps는 햇빛과 무지개만 있는 것은 아닙니다. 다음과 같은 상황이 발생할 수 있습니다.

  • 문화적 저항: 변화는 어려울 수 있습니다. 특히 "우리는 항상 이렇게 해왔습니다"라는 군중에게는 더욱 그렇습니다.
  • 통합 문제: GitOps를 기존 설정과 병합하시겠습니까? 초기 통증에 대비하세요.
  • 확장 과제: 성장함에 따라 모든 것을 동기화하는 것이 까다로울 수 있습니다.
  • 보안 문제: Git에 모든 것을 저장하시겠습니까? Fort Knox 수준의 보안을 유지하는지 확인하세요.

실제 예: 웹 애플리케이션용 GitOps 구현

GitOps를 사용해 볼 준비가 되셨나요? 다음은 웹 애플리케이션에 구현하는 방법에 대한 간단한 예입니다.

  1. Git 저장소(예: GitHub)에 애플리케이션 코드를 저장하세요.
  2. Kubernetes 매니페스트를 위한 별도의 저장소를 만듭니다.
   k8s-manifests/
   ├── deployment.yaml
   ├── service.yaml
   └── ingress.yaml
  1. CI 파이프라인(예: GitHub Actions)을 설정하여 애플리케이션을 빌드하고, 테스트를 실행하고, Docker 이미지를 레지스트리에 푸시하세요.
  2. Kubernetes 클러스터에 Flux 또는 ArgoCD와 같은 GitOps 도구를 설치하세요.
  3. k8s-manifests 저장소를 감시하도록 GitOps 도구를 구성하세요.
  4. 애플리케이션을 업데이트하려는 경우:
    • 애플리케이션 코드를 변경하세요.
    • deployment.yaml에서 이미지 태그를 업데이트합니다.
    • 두 저장소 모두에 변경 사항을 커밋하고 푸시합니다.
  5. GitOps 도구는 자동으로 변경 사항을 감지하고 클러스터를 업데이트합니다.

이 워크플로는 Git 리포지토리가 항상 원하는 시스템 상태를 반영하고 실제 인프라가 동기화된 상태를 유지하도록 보장합니다.

마무리하기

GitOps는 단순한 기술 유행어가 아니라 게임 체인저입니다. Git을 단일 정보 소스로 만들면 더욱 원활하고 효율적인 DevOps 여정을 준비할 수 있습니다. 소수의 서비스를 관리하든 수백 개의 클러스터를 관리하든 GitOps는 운영을 간소화하고 안정성을 향상시키는 데 도움이 될 수 있습니다.

당신 차례입니다!

GitOps 물에 발가락을 담가보셨나요? 어떤 장애물에 직면했습니까? 어떻게 극복하셨나요? 댓글로 GitOps 전쟁 이야기를 공유하세요. 서로에게서 배우고 DevOps 생활을 더 쉽게 만들어 보세요!

릴리스 선언문 이 기사는 https://dev.to/vyan/gitops-the-game-changer-in-software-delivery-and-infrastructure-management-3ibd?1에 복제되어 있습니다. 침해가 있는 경우에는 Study_golang@163으로 문의하시기 바랍니다. .com에서 삭제하세요
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3