搜尋
首頁開發工具Git如何將前端gitlab專案自動化部署到k8s上

本文主要介紹如何將前端專案自動化部署到基於Kubernetes的容器環境。這裡我們使用GitLab CI/CD來完成這個過程,其中,GitLab作為用於程式碼管理、版本控制和協作的平台,Kubernetes作為容器編排和部署的工具,能夠讓前端開發過程更有效率和便利。

  1. GitLab配置

首先在GitLab上建立一個項目,並將其與Git倉庫關聯。隨後,在專案設定中開啟CI/CD功能,選擇需要使用的Runner。這裡我們將安裝GitLab Runner,並將其註冊到GitLab的Runner清單中。

  1. GitLab Runner安裝與設定

安裝GitLab Runner的過程相對簡單,只需要根據不同系統和平台的安裝指南進行相應操作即可。

在安裝完成後,我們需要對GitLab Runner進行設定。假設你已經有一個Kubernetes的集群,我們需要將GitLab Runner配置為在該集群上運行。具體的配置流程如下:

① 首先,我們需要為Runner配置一個Kubernetes的Service Account,該Service Account需要被授權存取叢集中的Kubernetes API。

② 隨後,我們需要將這個Runner設定為使用該Service Account來存取API。為此,我們需要在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 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數量(這裡為1),並宣告了容器映像的名稱和連接埠號碼。完成這個部署檔案之後,我們可以使用Kubernetes命令列工具(kubectl)來建立該Deployment物件:

kubectl apply -f deployment.yml

到此為止,我們的前端應用就已經應該可以成功運行在Kubernetes上了。

結論

本文介紹如何將前端專案自動化部署到基於Kubernetes的容器環境。重點介紹了GitLab CI/CD、Kubernetes和Docker的使用,並透過一個完整的DEMO來示範了部署流程。希望這篇文章對前端開發工程師有幫助。

以上是如何將前端gitlab專案自動化部署到k8s上的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
git vs. github:探索他們的角色git vs. github:探索他們的角色Apr 16, 2025 am 12:06 AM

Git和GitHub是不同的工具:Git是一個分佈式版本控制系統,用於管理代碼版本和協作開發;GitHub是一個基於Git的在線平台,提供代碼託管和協作工具。 Git的主要功能包括版本管理、分支管理和協作開發,而GitHub則提供代碼託管、協作工具和社交網絡功能。

GitHub:開源和軟件開發的樞紐GitHub:開源和軟件開發的樞紐Apr 15, 2025 am 12:10 AM

GitHub是一個基於Git的版本控制系統託管平台,提供版本控制、協作開發和社區交流功能。使用GitHub可以提高開發效率和代碼質量。

git and github:有什麼關係?git and github:有什麼關係?Apr 14, 2025 am 12:10 AM

Git和GitHub是不同的工具:Git是用於版本控制的軟件,GitHub是基於Git的在線平台。 1.Git允許你跟踪文件變化和協同開發。 2.GitHub提供代碼託管和協作工具,增強團隊開發效率。

GitHub:開發人員和項目的平台GitHub:開發人員和項目的平台Apr 13, 2025 am 12:01 AM

GitHub的核心功能包括版本控制、分支管理、代碼審查、問題跟踪和項目管理。 1.版本控制與分支管理基於Git,允許追踪代碼變更和實驗性開發。 2.代碼審查通過PullRequest實現,提升代碼質量和團隊協作。 3.問題跟踪與項目管理通過Issues和項目管理板進行,提高項目透明度和可追踪性。

行動中的github:示例和用例行動中的github:示例和用例Apr 12, 2025 am 12:16 AM

GitHub是提升軟件開發效率和質量的強大工具。 1)版本控制:通過Git管理代碼變更。 2)PullRequests:進行代碼審查,提高代碼質量。 3)Issues:跟踪bug和項目進度。 4)GitHubActions:自動化構建、測試和部署流程。

git vs. github:版本控制和代碼託管git vs. github:版本控制和代碼託管Apr 11, 2025 am 11:33 AM

Git是版本控制系統,GitHub是基於Git的代碼託管平台。 Git用於管理代碼版本,支持本地操作;GitHub提供在線協作工具,如Issue跟踪和PullRequest。

什麼是簡單的話?什麼是簡單的話?Apr 09, 2025 am 12:12 AM

Git是一個開源的分佈式版本控制系統,幫助開發者跟踪文件變化、協同工作和管理代碼版本。它的核心功能包括:1)記錄代碼修改,2)回退到之前版本,3)協同開發,4)創建和管理分支進行並行開發。

git和github相同嗎?git和github相同嗎?Apr 08, 2025 am 12:13 AM

Git和GitHub不是同一回事。 Git是版本控制系統,GitHub是基於Git的代碼託管平台。 Git用於管理代碼版本,GitHub提供在線協作環境。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具