개발 도구 자식 프런트엔드 gitlab 프로젝트를 k8s에 자동으로 배포하는 방법

프런트엔드 gitlab 프로젝트를 k8s에 자동으로 배포하는 방법

Mar 29, 2023 pm 12:44 PM

이 글에서는 주로 프런트엔드 프로젝트를 Kubernetes 기반 컨테이너 환경에 자동으로 배포하는 방법을 소개합니다. 여기서는 GitLab CI/CD를 사용하여 이 프로세스를 완료합니다. GitLab은 코드 관리, 버전 제어 및 협업을 위한 플랫폼 역할을 하며, Kubernetes는 프런트엔드 개발 프로세스를 보다 효율적이고 효율적으로 만들 수 있는 컨테이너 조정 및 배포용 도구 역할을 합니다. 편리한.

  1. GitLab 구성

먼저 GitLab에서 프로젝트를 생성하고 Git 저장소와 연결하세요. 그런 다음 프로젝트 설정에서 CI/CD 기능을 켜고 사용하려는 러너를 선택하세요. 여기서는 GitLab Runner를 설치하고 GitLab의 Runner 목록에 등록하겠습니다.

  1. GitLab Runner 설치 및 구성

GitLab Runner 설치 과정은 비교적 간단합니다. 다양한 시스템과 플랫폼의 설치 가이드를 따르기만 하면 됩니다.

설치가 완료되면 GitLab Runner를 구성해야 합니다. 이미 Kubernetes 클러스터가 있다고 가정하면 클러스터에서 실행되도록 GitLab Runner를 구성해야 합니다. 구체적인 구성 과정은 다음과 같습니다.

① 먼저 Runner용 Kubernetes 서비스 계정을 구성해야 합니다. 서비스 계정은 클러스터의 Kubernetes API에 액세스할 수 있는 권한이 있어야 합니다.

② 그런 다음 서비스 계정을 사용하여 API에 액세스하도록 이 Runner를 구성해야 합니다. 이를 위해서는 Runner의 구성 파일(config.toml)에 다음 필드를 설정해야 합니다.

[[runners.kubernetes.volumes.host_path]]
      name = "docker"
      mount_path = "/var/run/docker.sock"
      host_path = "/var/run/docker.sock"
    [[runners.kubernetes.volumes.config_map]]
      name = "kube-config"
      mount_path = "/etc/kubernetes"
    [[runners.kubernetes.volumes.empty_dir]]
      name = "tls"
      mount_path = "/etc/gitlab-runner/certs"
    [[runners.kubernetes.volumes.secret]]
      name = "runner-secret"
      mount_path = "/etc/gitlab-runner"
로그인 후 복사

그 중 kube-config는 Runner와 관련된 config 맵의 이름이고, runner-secret은 Runner와 관련된 비밀 이름입니다. kube-config为与Runner相关的config map的名称,runner-secret为与Runner相关的secret的名称。

③ 最后,我们需要更新并重启GitLab Runner,使其能够使用在Kubernetes中运行的容器。运行以下命令可以自动重启GitLab Runner:

sudo gitlab-runner restart
로그인 후 복사
  1. 实现自动化部署

获得了一个配置好的Runner之后,我们就可以开始实现自动化部署了。这里我们使用一个名为.gitlab-ci.yml的文件来定义我们的CI/CD流程。

首先,我们需要定义一个Dockerfile,以便在Kubernetes中运行容器时使用。该Dockerfile将在构建Docker镜像时使用,如下所示:

FROM nginx:1.15.8-alpine

COPY dist /usr/share/nginx/html

COPY nginx/default.conf /etc/nginx/conf.d/
로그인 후 복사

该镜像将以nginx:1.15.8-alpine为基础镜像,复制我们的前端文件到Nginx的默认目录,并替换默认的Nginx配置文件以便于我们的应用能够正常运行。

随后,在.gitlab-ci.yml文件中定义我们的CI/CD流程。具体地,我们将在该文件中声明该项目的构建过程,然后将该构建后的Docker镜像推送到容器镜像库,并最终在Kubernetes中运行这个镜像。流程如下:

stages:
  - build
  - release

build:
  stage: build
  script:
    - docker build -t registry.cn-hangzhou.aliyuncs.com/$CI_PROJECT_NAMESPACE/$CI_PROJECT_NAME:$CI_COMMIT_TAG .
    - docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD registry.cn-hangzhou.aliyuncs.com
    - docker push registry.cn-hangzhou.aliyuncs.com/$CI_PROJECT_NAMESPACE/$CI_PROJECT_NAME:$CI_COMMIT_TAG
  only:
    - /^v\d+\.\d+(\.\d+)?(-\S*)?$/

release:
  stage: release
  script:
    - kubectl apply -f k8s/
  only:
    - /^v\d+\.\d+(\.\d+)?(-\S*)?$/
로그인 후 복사

在这个文件中,我们首先声明了我们的流程拥有buildrelease两个阶段,并在build阶段中完成构建、推送到容器镜像库的过程,在release阶段中完成Kubernetes部署的过程。注意,这里我们只为tag为版本号的Git提交启用CI/CD流程。

  1. 应用部署

最后,在我们的Kubernetes中部署上我们的应用。我们将使用一个名为deployment.yml的文件来完成部署。该文件声明了一个Deployment对象,用于在Kubernetes中运行前端应用。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: frontend-deployment
spec:
  replicas: 1 # 运行一个副本
  selector:
    matchLabels:
      app: frontend
  template:
    metadata:
      labels:
        app: frontend
    spec:
      containers:
        - name: frontend
          image: registry.cn-hangzhou.aliyuncs.com/wbbry/frontend:latest # 镜像名称
          imagePullPolicy: Always
          ports:
            - containerPort: 80 # 前端端口
로그인 후 복사

该文件指定了该Deployment对象的replicas

3 마지막으로 Kubernetes에서 실행되는 컨테이너를 사용할 수 있도록 GitLab Runner를 업데이트하고 다시 시작해야 합니다. 다음 명령을 실행하여 GitLab Runner를 자동으로 다시 시작하세요.

kubectl apply -f deployment.yml
로그인 후 복사
    자동 배포

    구성된 Runner를 얻은 후 자동 배포 구현을 시작할 수 있습니다. 여기서는 .gitlab-ci.yml이라는 파일을 사용하여 CI/CD 프로세스를 정의합니다.

    🎜먼저 Kubernetes에서 컨테이너를 실행할 때 사용할 Dockerfile을 정의해야 합니다. 이 Dockerfile은 아래와 같이 Docker 이미지를 빌드할 때 사용됩니다. 🎜rrreee🎜이미지는 nginx:1.15.8-alpine을 기반으로 합니다. 프런트엔드 파일을 기본 디렉터리에 복사합니다. Nginx. 그리고 애플리케이션이 정상적으로 실행될 수 있도록 기본 Nginx 구성 파일을 교체합니다. 🎜🎜그런 다음 .gitlab-ci.yml 파일에서 CI/CD 프로세스를 정의하세요. 구체적으로 이 파일에서 프로젝트의 빌드 프로세스를 선언한 다음 빌드된 Docker 이미지를 컨테이너 이미지 라이브러리에 푸시하고 마지막으로 Kubernetes에서 이 이미지를 실행합니다. 프로세스는 다음과 같습니다. 🎜rrreee🎜이 파일에서는 먼저 프로세스에 빌드릴리스의 두 단계가 있고 빌드에 있음을 선언합니다. > 컨테이너 이미지 라이브러리를 빌드하고 푸시하는 과정은 단계에서 완료되고, Kubernetes 배포 프로세스는 release 단계에서 완료됩니다. 여기서는 태그가 버전 번호인 Git 커밋에 대해서만 CI/CD 프로세스를 활성화합니다. 🎜
      🎜애플리케이션 배포🎜🎜🎜마지막으로 Kubernetes에 애플리케이션을 배포합니다. deployment.yml이라는 파일을 사용하여 배포를 완료합니다. 이 파일은 Kubernetes에서 프런트엔드 애플리케이션을 실행하기 위한 배포 개체를 선언합니다. 🎜rrreee🎜이 파일은 배포 개체의 복제본 수(여기서는 1)를 지정하고 컨테이너 이미지의 이름과 포트 번호를 선언합니다. 이 배포 파일을 완료한 후 Kubernetes 명령줄 도구(kubectl)를 사용하여 배포 개체를 생성할 수 있습니다. 🎜rrreee🎜이 시점에서 프런트 엔드 애플리케이션이 Kubernetes에서 성공적으로 실행될 수 있어야 합니다. 🎜🎜결론🎜🎜이 문서에서는 Kubernetes 기반 컨테이너 환경에 프런트 엔드 프로젝트 배포를 자동화하는 방법을 소개합니다. GitLab CI/CD, Kubernetes 및 Docker의 사용에 중점을 두고 전체 DEMO를 통해 배포 프로세스를 보여줍니다. 이 글이 프론트엔드 개발 엔지니어들에게 도움이 되기를 바랍니다. 🎜

위 내용은 프런트엔드 gitlab 프로젝트를 k8s에 자동으로 배포하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

git은 github와 동일합니까? git은 github와 동일합니까? Apr 08, 2025 am 12:13 AM

Git과 Github도 같은 것이 아닙니다. GIT는 버전 제어 시스템이며 GitHub는 GIT 기반 코드 호스팅 플랫폼입니다. GIT는 코드 버전을 관리하는 데 사용되며 Github은 온라인 협업 환경을 제공합니다.

Github는 배우기가 어렵습니까? Github는 배우기가 어렵습니까? Apr 02, 2025 pm 02:45 PM

Github는 배우기가 어렵지 않습니다. 1) 기본 지식 마스터 : GitHub는 코드 변경 및 협업 개발을 추적하는 데 도움이되는 GIT 기반 버전 제어 시스템입니다. 2) 핵심 기능 이해 : 버전 제어는 각 제출, 로컬 작업 지원 및 원격 동기화를 기록합니다. 3) 사용 방법 : 저장소 작성부터 커밋 푸시, 분기 사용 및 요청을 당기는 것까지. 4) 일반적인 문제 해결 : 합병 충돌 및 파일 추가 잊어 버린 것과 같은. 5) 최적화 실습 : 의미있는 제출 메시지를 사용하고, 분기를 정리하고, 프로젝트 보드를 사용하여 작업을 관리합니다. 실습과 커뮤니티 커뮤니케이션을 통해 Github의 학습 곡선은 가파르지 않습니다.

Git vs. Github : 버전 제어 및 코드 호스팅 Git vs. Github : 버전 제어 및 코드 호스팅 Apr 11, 2025 am 11:33 AM

GIT는 버전 제어 시스템이며 GitHub는 GIT 기반 코드 호스팅 플랫폼입니다. GIT는 코드 버전을 관리하는 데 사용되며 로컬 작업을 지원합니다. GitHub는 문제 추적 및 풀 레크와 같은 온라인 협업 도구를 제공합니다.

Microsoft는 git 또는 github를 소유합니까? Microsoft는 git 또는 github를 소유합니까? Apr 05, 2025 am 12:20 AM

Microsoft는 Git을 소유하지 않지만 Github를 소유하고 있습니다. 1. Git은 2005 년 Linus Torvaz가 만든 분산 버전 제어 시스템입니다. 2. Github는 GIT를 기반으로 한 온라인 코드 호스팅 플랫폼입니다. 2008 년에 설립되어 2018 년 Microsoft에서 인수했습니다.

이력서에 git 또는 github를 넣어야합니까? 이력서에 git 또는 github를 넣어야합니까? Apr 04, 2025 am 12:04 AM

이력서에서는 위치 요구 사항과 개인 경험에 따라 GIT 또는 GitHub를 작성하도록 선택해야합니다. 1. 위치에 GIT 기술이 필요한 경우 git을 강조 표시하십시오. 2. 직위가 커뮤니티 참여를 가치있게 평가하면 Github를 보여주십시오. 3. 사용 경험과 프로젝트 사례를 자세히 설명하고 완전한 문장으로 끝내십시오.

간단한 말로 git은 무엇입니까? 간단한 말로 git은 무엇입니까? Apr 09, 2025 am 12:12 AM

GIT는 개발자가 파일 변경을 추적하고 협력하며 코드 버전을 관리하는 데 도움이되는 오픈 소스 분산 버전 제어 시스템입니다. 핵심 기능에는 1) 레코드 코드 수정, 2) 이전 버전으로의 폴백, 3) 협업 개발 및 4) 병렬 개발을위한 분기 생성 및 관리가 포함됩니다.

git 또는 github로 시작해야합니까? git 또는 github로 시작해야합니까? Apr 06, 2025 am 12:09 AM

GIT에서 시작하는 것은 버전 제어 원칙에 대한 깊은 이해에 더 적합하며 GitHub에서 시작하는 것은 협업 및 코드 호스팅에 중점을 두는 데 더 적합합니다. 1. git은 코드 버전 기록을 관리하는 데 도움이되는 분산 버전 제어 시스템입니다. 2. GitHub는 GIT를 기반으로 한 온라인 플랫폼으로 코드 호스팅 및 협업 기능을 제공합니다.

HTML에 github를 사용하는 방법은 무엇입니까? HTML에 github를 사용하는 방법은 무엇입니까? Apr 07, 2025 am 12:13 AM

HTML 프로젝트를 관리하기 위해 GitHub를 사용하는 이유는 버전 제어, 협업 개발 및 작품 발표를위한 플랫폼을 제공하기 때문입니다. 특정 단계에는 다음이 포함됩니다. 1. Git 저장소 작성 및 초기화, 2. HTML 파일 추가 및 제출, 3. GitHub에 푸시, 4. GitHubPages를 사용하여 웹 페이지를 배포, 5. GitHubactions를 사용하여 빌드 및 배포를 자동화하십시오. 또한 GitHub은 HTML 프로젝트를 최적화하고 협업하는 데 도움이되는 코드 검토, 문제 및 풀 레크 기능 기능을 지원합니다.

See all articles