Heim Entwicklungswerkzeuge Idiot So stellen Sie Front-End-Gitlab-Projekte automatisch für k8s bereit

So stellen Sie Front-End-Gitlab-Projekte automatisch für k8s bereit

Mar 29, 2023 pm 12:44 PM

In diesem Artikel wird hauptsächlich die automatische Bereitstellung von Front-End-Projekten in einer Kubernetes-basierten Containerumgebung vorgestellt. Hier verwenden wir GitLab CI/CD, um diesen Prozess abzuschließen. GitLab dient als Plattform für Codeverwaltung, Versionskontrolle und Zusammenarbeit, und Kubernetes dient als Tool für die Container-Orchestrierung und -Bereitstellung, was den Front-End-Entwicklungsprozess effizienter und effizienter gestalten kann komfortabel.

  1. GitLab-Konfiguration

Erstellen Sie zunächst ein Projekt auf GitLab und verknüpfen Sie es mit dem Git-Repository. Aktivieren Sie dann die CI/CD-Funktion in den Projekteinstellungen und wählen Sie den Runner aus, den Sie verwenden möchten. Hier installieren wir GitLab Runner und registrieren es in der Runner-Liste von GitLab.

  1. GitLab Runner Installation und Konfiguration

Der Prozess der Installation von GitLab Runner ist relativ einfach. Sie müssen lediglich den Installationsanleitungen verschiedener Systeme und Plattformen folgen.

Nachdem die Installation abgeschlossen ist, müssen wir GitLab Runner konfigurieren. Vorausgesetzt, Sie verfügen bereits über einen Kubernetes-Cluster, müssen wir GitLab Runner für die Ausführung auf dem Cluster konfigurieren. Der spezifische Konfigurationsprozess ist wie folgt:

① Zuerst müssen wir ein Kubernetes-Dienstkonto für den Runner konfigurieren. Das Dienstkonto muss für den Zugriff auf die Kubernetes-API im Cluster autorisiert sein.

② Anschließend müssen wir diesen Runner so konfigurieren, dass er das Dienstkonto für den Zugriff auf die API verwendet. Dazu müssen wir die folgenden Felder in der Konfigurationsdatei des Runners (config.toml) festlegen:

[[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"
Nach dem Login kopieren

Darunter ist kube-config der Name der Konfigurationszuordnung, die sich auf den Runner bezieht. runner-secret ist der Name des Geheimnisses, das sich auf Runner bezieht. kube-config为与Runner相关的config map的名称,runner-secret为与Runner相关的secret的名称。

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

sudo gitlab-runner restart
Nach dem Login kopieren
  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/
Nach dem Login kopieren

该镜像将以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*)?$/
Nach dem Login kopieren

在这个文件中,我们首先声明了我们的流程拥有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 # 前端端口
Nach dem Login kopieren

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

③ Abschließend müssen wir GitLab Runner aktualisieren und neu starten, damit es Container verwenden kann, die in Kubernetes ausgeführt werden. Führen Sie den folgenden Befehl aus, um GitLab Runner automatisch neu zu starten:

kubectl apply -f deployment.yml
Nach dem Login kopieren
    Automatisierte Bereitstellung

    Nachdem wir einen konfigurierten Runner erhalten haben, können wir mit der Implementierung der automatisierten Bereitstellung beginnen. Hier verwenden wir eine Datei namens .gitlab-ci.yml, um unseren CI/CD-Prozess zu definieren.

    🎜Zuerst müssen wir eine Docker-Datei definieren, die beim Ausführen von Containern in Kubernetes verwendet werden soll. Diese Docker-Datei wird beim Erstellen des Docker-Images verwendet, wie unten gezeigt: 🎜rrreee🎜Das Image basiert auf nginx:1.15.8-alpine. Kopieren Sie unsere Front-End-Dateien in das Standardverzeichnis von Nginx. Und ersetzen Sie die Standard-Nginx-Konfigurationsdatei, damit unsere Anwendung normal ausgeführt werden kann. 🎜🎜Dann definieren Sie unseren CI/CD-Prozess in der Datei .gitlab-ci.yml. Konkret deklarieren wir den Build-Prozess des Projekts in dieser Datei, übertragen dann das erstellte Docker-Image in die Container-Image-Bibliothek und führen dieses Image schließlich in Kubernetes aus. Der Prozess ist wie folgt: 🎜rrreee🎜In dieser Datei erklären wir zunächst, dass unser Prozess zwei Phasen hat: build und release und in build Der Prozess des Erstellens und Übertragens in die Container-Image-Bibliothek wird in der Phase abgeschlossen, und der Kubernetes-Bereitstellungsprozess wird in der Phase release abgeschlossen. Beachten Sie, dass wir hier den CI/CD-Prozess nur für Git-Commits aktivieren, deren Tags Versionsnummern sind. 🎜
      🎜Anwendungsbereitstellung🎜🎜🎜Stellen Sie schließlich unsere Anwendung in unserem Kubernetes bereit. Wir werden eine Datei namens deployment.yml verwenden, um die Bereitstellung abzuschließen. Diese Datei deklariert ein Deployment-Objekt zum Ausführen von Front-End-Anwendungen in Kubernetes. 🎜rrreee🎜Diese Datei gibt die Anzahl der Replikate des Deployment-Objekts an (hier ist 1) und deklariert den Namen und die Portnummer des Container-Images. Nachdem wir diese Bereitstellungsdatei fertiggestellt haben, können wir das Kubernetes-Befehlszeilentool (kubectl) verwenden, um das Bereitstellungsobjekt zu erstellen: 🎜rrreee🎜An diesem Punkt sollte unsere Front-End-Anwendung erfolgreich auf Kubernetes ausgeführt werden können. 🎜🎜Fazit🎜🎜In diesem Artikel wird erläutert, wie Sie Front-End-Projekte automatisch in einer Kubernetes-basierten Containerumgebung bereitstellen. Der Schwerpunkt liegt auf der Verwendung von GitLab CI/CD, Kubernetes und Docker und demonstriert den Bereitstellungsprozess anhand einer vollständigen DEMO. Ich hoffe, dass dieser Artikel für Front-End-Entwicklungsingenieure hilfreich ist. 🎜

Das obige ist der detaillierte Inhalt vonSo stellen Sie Front-End-Gitlab-Projekte automatisch für k8s bereit. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Git vs. GitHub: Versionskontrolle und Code -Hosting Git vs. GitHub: Versionskontrolle und Code -Hosting Apr 11, 2025 am 11:33 AM

Git ist ein Versionskontrollsystem, und GitHub ist eine GIT-basierte Code-Hosting-Plattform. Git wird verwendet, um Codeversionen zu verwalten und unterstützt lokale Operationen. GitHub bietet Online -Zusammenarbeitstools wie das Problem mit der Ausgabe und PullRequest.

Ist Git das gleiche wie GitHub? Ist Git das gleiche wie GitHub? Apr 08, 2025 am 12:13 AM

Git und Github sind nicht dasselbe. Git ist ein Versionskontrollsystem, und GitHub ist eine GIT-basierte Code-Hosting-Plattform. Git wird verwendet, um Codeversionen zu verwalten, und GitHub bietet eine Online -Zusammenarbeit.

Ist Github schwer zu lernen? Ist Github schwer zu lernen? Apr 02, 2025 pm 02:45 PM

Github ist nicht schwer zu lernen. 1) Meister Sie das Grundwissen: GitHub ist ein GIT-basiertes Versionskontrollsystem, mit dem Code Änderungen und kollaborative Entwicklung nachverfolgt werden. 2) Kernfunktionen verstehen: Versionskontrolle zeichnet jede Einreichung, die Unterstützung lokaler Arbeiten und Remote -Synchronisation auf. 3) Lernen Sie, wie Sie verwendet werden: vom Erstellen eines Repositorys bis hin zum Drücken von Commits bis hin zur Verwendung von Zweigen und Ziehenanforderungen. 4) Lösen Sie gemeinsame Probleme: wie Zusammenführungskonflikte und Vergessen, Dateien hinzuzufügen. 5) Optimierungspraxis: Verwenden Sie aussagekräftige Einreichungsnachrichten, Reinigen Sie Niederlassungen und Verwalten Sie Aufgaben mithilfe der Projektplatine. Durch Praxis und Community -Kommunikation ist Githubs Lernkurve nicht steil.

So laden Sie GIT -Projekte auf lokale Herd herunter So laden Sie GIT -Projekte auf lokale Herd herunter Apr 17, 2025 pm 04:36 PM

Um Projekte lokal über Git herunterzuladen, befolgen Sie die folgenden Schritte: Installieren Sie Git. Navigieren Sie zum Projektverzeichnis. Klonen des Remote-Repositorys mit dem folgenden Befehl: Git Clone https://github.com/username/repository-name.git.git

So aktualisieren Sie den Code in Git So aktualisieren Sie den Code in Git Apr 17, 2025 pm 04:45 PM

Schritte zur Aktualisierung von Git -Code: CODEHOUSSCHAFTEN:

Wie man Git Commit benutzt Wie man Git Commit benutzt Apr 17, 2025 pm 03:57 PM

Git Commit ist ein Befehl, mit dem Dateien Änderungen an einem Git -Repository aufgezeichnet werden, um einen Momentaufnahme des aktuellen Status des Projekts zu speichern. So verwenden Sie dies wie folgt: Fügen Sie Änderungen in den temporären Speicherbereich hinzu, schreiben Sie eine prägnante und informative Einreichungsnachricht, um die Einreichungsnachricht zu speichern und zu beenden, um die Einreichung optional abzuschließen: Fügen Sie eine Signatur für die Einreichungs -Git -Protokoll zum Anzeigen des Einreichungsinhalts hinzu.

Was tun, wenn der Git -Download nicht aktiv ist Was tun, wenn der Git -Download nicht aktiv ist Apr 17, 2025 pm 04:54 PM

Auflösung: Wenn die Git -Download -Geschwindigkeit langsam ist, können Sie die folgenden Schritte ausführen: Überprüfen Sie die Netzwerkverbindung und versuchen Sie, die Verbindungsmethode zu wechseln. Optimieren Sie die GIT-Konfiguration: Erhöhen Sie die Post-Puffer-Größe (GIT-Konfiguration --global http.postbuffer 524288000) und verringern Sie die Niedriggeschwindigkeitsbegrenzung (GIT-Konfiguration --global http.lowSpeedLimit 1000). Verwenden Sie einen GIT-Proxy (wie Git-Proxy oder Git-LFS-Proxy). Versuchen Sie, einen anderen Git -Client (z. B. Sourcetree oder Github Desktop) zu verwenden. Überprüfen Sie den Brandschutz

Soll ich Git oder Github in meinen Lebenslauf setzen? Soll ich Git oder Github in meinen Lebenslauf setzen? Apr 04, 2025 am 12:04 AM

In Ihrem Lebenslauf sollten Sie sich dafür entscheiden, Git oder GitHub basierend auf Ihren Positionsanforderungen und persönlichen Erfahrungen zu schreiben. 1. Wenn die Position GIT -Fähigkeiten erfordert, markieren Sie Git. 2. Wenn die Position der Positionsbeteiligung bewertet, zeigen Sie GitHub. 3. Beschreiben Sie die Nutzungserfahrung und die Projektfälle im Detail und beenden Sie einen vollständigen Satz.

See all articles