Home Development Tools git How to automatically deploy front-end gitlab projects to k8s

How to automatically deploy front-end gitlab projects to k8s

Mar 29, 2023 pm 12:44 PM

This article mainly introduces how to automatically deploy front-end projects into a Kubernetes-based container environment. Here we use GitLab CI/CD to complete this process. GitLab serves as a platform for code management, version control and collaboration, and Kubernetes serves as a tool for container orchestration and deployment, which can make the front-end development process more efficient and convenient.

  1. GitLab Configuration

First create a project on GitLab and associate it with the Git repository. Then, turn on the CI/CD function in the project settings and select the Runner you want to use. Here we will install GitLab Runner and register it in GitLab's Runner list.

  1. GitLab Runner Installation and Configuration

The process of installing GitLab Runner is relatively simple. You only need to follow the installation guides of different systems and platforms.

After the installation is complete, we need to configure GitLab Runner. Assuming you already have a Kubernetes cluster, we need to configure GitLab Runner to run on the cluster. The specific configuration process is as follows:

① First, we need to configure a Kubernetes Service Account for the Runner. The Service Account needs to be authorized to access the Kubernetes API in the cluster.

② Subsequently, we need to configure this Runner to use the Service Account to access the API. To do this, we need to set the following fields in the Runner's configuration file (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"
Copy after login

Among them, kube-config is the name of the config map related to the Runner, runner-secret is the name of the secret related to Runner.

③ Finally, we need to update and restart GitLab Runner so that it can use containers running in Kubernetes. Run the following command to automatically restart GitLab Runner:

sudo gitlab-runner restart
Copy after login
  1. realize automated deployment

After obtaining a configured Runner, we can start to implement automated deployment. Here we use a file named .gitlab-ci.yml to define our CI/CD process.

First, we need to define a Dockerfile to use when running containers in Kubernetes. This Dockerfile will be used when building the Docker image, as shown below:

FROM nginx:1.15.8-alpine

COPY dist /usr/share/nginx/html

COPY nginx/default.conf /etc/nginx/conf.d/
Copy after login

The image will be nginx:1.15.8-alpine as the base image, copy our front-end files to Nginx Default directory and replace the default Nginx configuration file so that our application can run normally.

Subsequently, define our CI/CD process in the .gitlab-ci.yml file. Specifically, we will declare the project's build process in this file, then push the built Docker image to the container image library, and finally run this image in Kubernetes. The process is as follows:

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*)?$/
Copy after login

In this file, we first declare that our process has two stages: build and release, and in build## The process of building and pushing to the container image library is completed in the # stage, and the Kubernetes deployment process is completed in the release stage. Note that here we only enable the CI/CD process for Git commits whose tags are version numbers.

    Application deployment
Finally, deploy our application in our Kubernetes. We will use a file called

deployment.yml to complete the deployment. This file declares a Deployment object for running front-end applications in 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 # 前端端口
Copy after login
This file specifies the

replicas number of the Deployment object (here is 1), and declares the name and port number of the container image. After completing this deployment file, we can use the Kubernetes command line tool (kubectl) to create the Deployment object:

kubectl apply -f deployment.yml
Copy after login
At this point, our front-end application should be able to run successfully on Kubernetes.

Conclusion

This article introduces how to automatically deploy front-end projects into a Kubernetes-based container environment. It focuses on the use of GitLab CI/CD, Kubernetes and Docker, and demonstrates the deployment process through a complete DEMO. I hope this article is helpful to front-end development engineers.

The above is the detailed content of How to automatically deploy front-end gitlab projects to k8s. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Is GitHub difficult to learn? Is GitHub difficult to learn? Apr 02, 2025 pm 02:45 PM

GitHub is not difficult to learn. 1) Master the basic knowledge: GitHub is a Git-based version control system that helps track code changes and collaborative development. 2) Understand core functions: Version control records each submission, supporting local work and remote synchronization. 3) Learn how to use: from creating a repository to push commits, to using branches and pull requests. 4) Solve common problems: such as merge conflicts and forgetting to add files. 5) Optimization practice: Use meaningful submission messages, clean up branches, and manage tasks using the project board. Through practice and community communication, GitHub’s learning curve is not steep.

Should I put Git or GitHub on my resume? Should I put Git or GitHub on my resume? Apr 04, 2025 am 12:04 AM

On your resume, you should choose to write Git or GitHub based on your position requirements and personal experience. 1. If the position requires Git skills, highlight Git. 2. If the position values ​​community participation, show GitHub. 3. Make sure to describe the usage experience and project cases in detail and end with a complete sentence.

Why is GitLab better than GitHub? Why is GitLab better than GitHub? Apr 03, 2025 am 12:08 AM

GitLab is better for some developers and teams because it provides a complete DevOps toolchain and powerful CI/CD capabilities. 1. GitLab's CI/CD function is integrated within the platform, supporting full process automation from code submission to deployment. 2. Its server-side rendering technology improves page loading speed for large projects. 3. GitLab's permission management system is more flexible and supports fine-grained control.

Should I start with Git or GitHub? Should I start with Git or GitHub? Apr 06, 2025 am 12:09 AM

Starting from Git is more suitable for a deep understanding of version control principles, and starting from GitHub is more suitable for focusing on collaboration and code hosting. 1.Git is a distributed version control system that helps manage code version history. 2. GitHub is an online platform based on Git, providing code hosting and collaboration capabilities.

Does Microsoft own Git or GitHub? Does Microsoft own Git or GitHub? Apr 05, 2025 am 12:20 AM

Microsoft does not own Git, but owns GitHub. 1.Git is a distributed version control system created by Linus Torvaz in 2005. 2. GitHub is an online code hosting platform based on Git. It was founded in 2008 and acquired by Microsoft in 2018.

How to use GitHub for HTML? How to use GitHub for HTML? Apr 07, 2025 am 12:13 AM

The reason for using GitHub to manage HTML projects is that it provides a platform for version control, collaborative development and presentation of works. The specific steps include: 1. Create and initialize the Git repository, 2. Add and submit HTML files, 3. Push to GitHub, 4. Use GitHubPages to deploy web pages, 5. Use GitHubActions to automate building and deployment. In addition, GitHub also supports code review, Issue and PullRequest features to help optimize and collaborate on HTML projects.

Is Git the same as GitHub? Is Git the same as GitHub? Apr 08, 2025 am 12:13 AM

Git and GitHub are not the same thing. Git is a version control system, and GitHub is a Git-based code hosting platform. Git is used to manage code versions, and GitHub provides an online collaboration environment.

See all articles