docker + K3S + Jenkins + Harbor自動化部署

最近公司在研究自動化部署的一套流程,下面記錄一下配置流程

需要提前準備好Jenkins? Harbor? Git(其他管理工具也可以)

我這里的打包編譯流程是Jenkins上配置打包任務-->自動到git目錄下找打包文件---->項目編譯后打鏡像包------>打完鏡像包將鏡像上傳到harbor倉庫----->通過yaml配置文件手動部署(最后一步其實也可以合并到Jenkins中,需要的自行學習)

一.準備打包文件

我的項目是springboot+vue 的所以我把打包文件分開寫了,你也可以合并到一起。

文件中標紅的內容需要替換自己的信息

1.Spring boot后臺項目目錄下添加打包文件

后臺Jenkinsfile文件內容

pipeline {
agent {
node {
label 'maven'
}

}

parameters {
gitParameter name: 'BRANCH_NAME', branch: '', branchFilter: '.*',defaultValue: 'master',description: '請選擇要發布的分支',quickFilterEnabled: false,type: 'PT_BRANCH_TAG'
choice(name: 'NAMESPACE', choices: ['master', 'fea-alert','dev-sit'],description: '命名空間')
string(name: 'TAG_NAME', defaultValue: 'snapshot', description: '標簽名稱,必須以 v 開頭,例如:v1、v1.0.0')
}
environment {
DOCKER_CREDENTIAL_ID = 'harbor-user-pass'?// 替換為你的 Docker Hub 憑證 ID
GIT_REPO_URL = '192.168.xxx.xxx' //git地址
GIT_CREDENTIAL_ID = 'private-git-token' //git憑證id
GIT_ACCOUNT = 'usernamexxx' //git賬號
REGISTRY = '192.168.xxx.xxx:80' //harbor地址
DOCKERHUB_NAMESPACE = 'zdyxxx' //harbor命名空間 換自己的
APP_NAME = 'itwg-monitor-platformxxx' //應用名稱

}
stages {
stage('chechout scm') {
steps {
checkout scmGit(branches: [[name: "$BRANCH_NAME"]], extensions: [], userRemoteConfigs: [[credentialsId: "$GIT_CREDENTIAL_ID", url: "https://192.168.xxx.xxx/xxx.git"]])
}
}
stage('unit test manager') {
steps {
withMaven(jdk: 'jdk17') {
sh 'mvn clean test -f zdy-hertzbeat/pom.xml -P prod'
}
}
}
stage('build & push mamager') {
steps {
withMaven(jdk: 'jdk17') {
sh 'mvn clean package -DskipTests -f zdy-hertzbeat/pom.xml'
}
sh 'docker build -f zdy-hertzbeat/kubernetes/build/manage/Dockerfile -t $REGISTRY/$DOCKERHUB_NAMESPACE/$APP_NAME:SNAPSHOT-$BUILD_NUMBER .'
withCredentials([usernamePassword(passwordVariable : 'DOCKER_PASSWORD' ,usernameVariable : 'DOCKER_USERNAME' ,credentialsId : "$DOCKER_CREDENTIAL_ID")]) {
sh 'echo "$DOCKER_PASSWORD" | docker login $REGISTRY -u "$DOCKER_USERNAME" --password-stdin'
sh 'docker push $REGISTRY/$DOCKERHUB_NAMESPACE/$APP_NAME:SNAPSHOT-$BUILD_NUMBER'
}

}
}

stage('push latest manager') {
steps {
sh 'docker tag $REGISTRY/$DOCKERHUB_NAMESPACE/$APP_NAME:SNAPSHOT-$BUILD_NUMBER $REGISTRY/$DOCKERHUB_NAMESPACE/$APP_NAME:latest'
sh 'docker push $REGISTRY/$DOCKERHUB_NAMESPACE/$APP_NAME:latest'
}
}
}
}

后臺Dockerfile

## 基礎鏡像

FROM openjdk:17

## 作者
LABEL org.opencontainers.image.authors="738749649@qq.com"

## 定義參數

## 創建并進入工作目錄
#RUN mkdir -p /project/hlxx/config
#RUN mkdir -p /project/xcyth
WORKDIR /project/zrq
## maven 插件構建時得到 buildArgs 種的值
COPY zdy-hertzbeat/hertzbeat-manager/target/*.jar app.jar

## 設置 TZ 時區
## 設置 JAVA_OPTS 環境變量,可通過 docker run -e "JAVA_OPTS=" 進行覆蓋
ENV TZ=Asia/Shanghai JAVA_OPTS="-Xms2048m -Xmx4096m"

## 暴露端口
EXPOSE 1157

## 容器啟動命令
## CMD 第一個參數之后的命令可以在運行時被替換
CMD java ${JAVA_OPTS} -Djava.security.egd=file:/dev/./urandom -jar /project/zrq/app.jar

?2.vue前臺添加打包文件

前端Jenkinsfile內容如下:

pipeline {

agent {

node {

label 'maven'

}

}

parameters {

gitParameter name: 'BRANCH_NAME', branch: '', branchFilter: '.*',defaultValue: 'main',description: '請選擇要發布的分支',quickFilterEnabled: false,type: 'PT_BRANCH_TAG'

choice(name: 'NAMESPACE', choices: ['main'],description: '命名空間')

string(name: 'TAG_NAME', defaultValue: 'snapshot', description: '標簽名稱,必須以 v 開頭,例如:v1、v1.0.0')

}

environment {

DOCKER_CREDENTIAL_ID = 'harbor-user-pass'?// 替換為你的 Docker Hub 憑證 ID
GIT_REPO_URL = '192.168.xxx.xxx' //git地址
GIT_CREDENTIAL_ID = 'private-git-token' //git憑證id
GIT_ACCOUNT = 'usernamexxx' //git賬號
REGISTRY = '192.168.xxx.xxx:80' //harbor地址
DOCKERHUB_NAMESPACE = 'zdyxxx' //harbor命名空間 換自己的

WEB_NAME = 'itwg-monitor-webxxx'

}

stages {

stage('chechout scm') {

steps {

checkout scmGit(branches: [[name: "$BRANCH_NAME"]], extensions: [], userRemoteConfigs: [[credentialsId: "$GIT_CREDENTIAL_ID", url: "https://192.168.xxx.xxx/xxxx.git"]])

}

}

//

stage('build & push') {

steps {

nodejs('nodejs20') {

dir('zdy-hertzbeat-ui-vue') {

sh 'pnpm install'

sh 'pnpm run build'

}

}

sh 'docker build -f kubernetes/build/web/Dockerfile -t $REGISTRY/$DOCKERHUB_NAMESPACE/$WEB_NAME:SNAPSHOT-$BUILD_NUMBER .'

withCredentials([usernamePassword(passwordVariable : 'DOCKER_PASSWORD' ,usernameVariable : 'DOCKER_USERNAME' ,credentialsId : "$DOCKER_CREDENTIAL_ID")]) {

sh 'echo "$DOCKER_PASSWORD" | docker2 login $REGISTRY -u "$DOCKER_USERNAME" --password-stdin'

sh 'docker push $REGISTRY/$DOCKERHUB_NAMESPACE/$WEB_NAME:SNAPSHOT-$BUILD_NUMBER'

}

}

}

stage('push latest') {

steps {

sh 'docker tag $REGISTRY/$DOCKERHUB_NAMESPACE/$WEB_NAME:SNAPSHOT-$BUILD_NUMBER $REGISTRY/$DOCKERHUB_NAMESPACE/$WEB_NAME:latest'

sh 'docker push $REGISTRY/$DOCKERHUB_NAMESPACE/$WEB_NAME:latest'

}

}

}

}

前端Dockerfile文件:

FROM docker.m.daocloud.io/nginx

LABEL org.opencontainers.image.authors="738749649@qq.com"

# 復制自定義的 Nginx 配置文件到鏡像中

COPY kubernetes/build/nginx/nginx.conf /etc/nginx/nginx.conf

ADD dist/ /usr/share/nginx/html/

EXPOSE 80

CMD ["/bin/sh", "-c", "nginx -g 'daemon off;'"]

?

前端nginx.conf

user nginx;

worker_processes 1;

error_log /var/log/nginx/error.log warn;

pid /var/run/nginx.pid;

events {

worker_connections 1024;

}

http {

include /etc/nginx/mime.types;

default_type application/octet-stream;

log_format main '$remote_addr - $remote_user [$time_local] "$request" '

'$status $body_bytes_sent "$http_referer" '

'"$http_user_agent" "$http_x_forwarded_for"';

access_log /var/log/nginx/access.log main;

sendfile on;

keepalive_timeout 65;

open_file_cache max=1000 inactive=20s;

open_file_cache_valid 30s;

open_file_cache_min_uses 2;

open_file_cache_errors on;

# client_max_body_size 用來修改允許客戶端上傳文件的大小。默認為1m,如果設置為0,表示上傳文件大小不受限制。

# 可以在以下模塊設置: http, server, location

client_max_body_size 100m;

# include /etc/nginx/conf.d/*.conf;

server {

listen 80 default_server;

listen [::]:80 default_server;

server_name localhost;

#

root /usr/share/nginx/html; # Vue 靜態文件根目錄(Docker 中默認掛載的 dist 目錄)

index index.html;

location / {

try_files $uri $uri/ /index.html; # 支持 Vue Router 的 history 模式

}

location /api {

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header REMOTE-HOST $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

#itwg-monitor-platform kubectl啟動后臺的服務名:端口

proxy_pass http://itwg-monitor-platform:1157/api;

}

#

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root /usr/share/nginx/html;

}

}

}

二.Jenkins新建任務?

上面我們準備好了我們打包需要的配置文件,這些文件都需要我們上傳項目git

到這里我們就可以在Jenkins上配置打包流程了。

我的項目是前后端分離的所以我配置兩個任務,一個后端,一個前端

下面截圖只是后端配置任務,前端的一樣只需修改對應的Jenkins腳本路徑和git配置

?

?三.Jenkins編譯打包

每個任務都需要編譯

?

?

四.在服務器部署

在服務器部署,需要我們寫個配置文件

配置文件中的image鏡像需要修改為自己的

前臺配置文件web.yaml

apiVersion: apps/v1
kind: Deployment
metadata:annotations:labels:app: itwg-monitor-webname: itwg-monitor-webnamespace: hertzbeat
spec:replicas: 1selector:matchLabels:app: itwg-monitor-webstrategy:rollingUpdate:maxSurge: 25%maxUnavailable: 25%type: RollingUpdatetemplate:metadata:labels:app: itwg-monitor-webspec:containers:- image: itwg-monitor-web  #鏡像imagePullPolicy: IfNotPresent   # 關鍵配置!name: itwg-monitor-webresources: {}terminationMessagePath: /dev/termination-logterminationMessagePolicy: FilednsPolicy: ClusterFirstrestartPolicy: AlwaysschedulerName: default-schedulersecurityContext: {}terminationGracePeriodSeconds: 30
----
apiVersion: v1
kind: Service
metadata:labels:app: itwg-monitor-webname: itwg-monitor-webnamespace: hertzbeat
spec:ports:- port: 80protocol: TCPtargetPort: 80nodePort: 30000selector:app: itwg-monitor-webtype: NodePort

后臺service.yaml

apiVersion: apps/v1
kind: Deployment
metadata:labels:app: itwg-monitor-platformname: itwg-monitor-platformnamespace: hertzbeat
spec:replicas: 1selector:matchLabels:app: itwg-monitor-platformstrategy:rollingUpdate:maxSurge: 25%maxUnavailable: 25%type: RollingUpdatetemplate:metadata:creationTimestamp: nulllabels:app: itwg-monitor-platformspec:containers:- name: itwg-monitor-platformimage: 192.168.6.114:80/zdy/itwg-monitor-platformimagePullPolicy: Alwaysresources: {}terminationMessagePath: /dev/termination-logterminationMessagePolicy: FilevolumeMounts:# 將宿主機的容器日志路徑掛載為 /usr/local/logs- name: container-logsmountPath: /usr/local/logsreadOnly: truevolumes:- name: container-logshostPath:path: /var/log/containerstype: DirectorydnsPolicy: ClusterFirstrestartPolicy: AlwaysschedulerName: default-schedulersecurityContext: {}terminationGracePeriodSeconds: 30
----
apiVersion: v1
kind: Service
metadata:labels:app: itwg-monitor-platformname: itwg-monitor-platformnamespace: hertzbeat
spec:ports:- port: 1157protocol: TCPtargetPort: 1157selector:app: itwg-monitor-platformtype: ClusterIP

?部署命令:

kubectl apply -f??service.yaml? -n? 命名空間

kubectl apply -f??web.yaml? -n? 命名空間

查看命令

kubectl get po -n??命名空間

kubectl get svc -n?命名空間

kubectl 常用命令

查看日志

kubectl describe pod <pod-name> -n <namespace>

kubectl logs <pod-name> -n <namespace>

刪除

kubectl delete svc hertzbeat-manager -n hertzbeat

kubectl delete deploy hertzbeat-manager -n hertzbeat

?五.問題記錄

? 1.如果Jenkins編譯前端無法install,編譯報錯提示

ERR_PNPM_OUTDATED_LOCKFILE ?Cannot install with "frozen-lockfile" because pnpm-lock.yaml is not up ?

執行pnpm install --no-frozen-lockfile

命令,然后將pnpm-lock.yaml文件提交后再進行編譯

? 2.如果前臺后端都部署到服務器前臺無法到服務器

先檢查前臺打包配置文件env.production中配置地址是否正確

檢查掛載到nginx中的代理轉發是否正確

?

3.如果遇到Maven打包后打包鏡像運行找不到主類問題,需要在maven打包中添加下面配置
<plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><!--加入下面兩項配置--><executions><execution><goals><goal>repackage</goal></goals></execution></executions><configuration><includeSystemScope>true</includeSystemScope></configuration>
</plugin><!-- Maven Dependency Plugin -->
<plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-dependency-plugin</artifactId><version>3.7.0</version><executions><execution><id>copy-dependencies</id><phase>package</phase><goals><goal>copy-dependencies</goal></goals><configuration><outputDirectory>${project.build.directory}/lib</outputDirectory></configuration></execution></executions>
</plugin>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/79299.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/79299.shtml
英文地址,請注明出處:http://en.pswp.cn/web/79299.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《用MATLAB玩轉游戲開發:從零開始打造你的數字樂園》基礎篇(2D圖形交互)-《打磚塊:向量反射與實時物理模擬》MATLAB教程

《用MATLAB玩轉游戲開發&#xff1a;從零開始打造你的數字樂園》基礎篇&#xff08;2D圖形交互&#xff09;-《打磚塊&#xff1a;向量反射與實時物理模擬》MATLAB教程 &#x1f3ae; 文章目錄 《用MATLAB玩轉游戲開發&#xff1a;從零開始打造你的數字樂園》基礎篇&#xff08…

Redisson 看門狗機制

何為看門狗 看門狗機制的主要作用是自動續期鎖&#xff0c;確保在節點完成任務之前&#xff0c;鎖不會過期。具體來說&#xff0c;當一個節點獲取到鎖后&#xff0c;看門狗會定期檢查該鎖的過期時間&#xff0c;并在必要時延長鎖的過期時間&#xff0c;確保節點可以順利完成任…

[架構之美]linux常見故障問題解決方案(十九)

[架構之美]linux下常見故障問題解決方案 一&#xff0c;文本文件忙 問題一&#xff1a;rootwh-VMware-Virtual-Platform:/home/hail# cp /root/containerd/bin/* /usr/bin/ cp: 無法創建普通文件 ‘/usr/bin/containerd’: 文本文件忙 在Linux系統中遇到“文本文件忙”錯誤時…

QT實現曲線圖縮放、拖拽以及框選放大

.h文件 protected: void saveAxisRange();void wheelEvent(QWheelEvent *event) override;void mousePressEvent(QMouseEvent *event) override;void mouseMoveEvent(QMouseEvent *event) override;void mouseReleaseEvent(QMouseEvent *event) override;private:QPoint m_…

【Pandas】pandas DataFrame corr

Pandas2.2 DataFrame Computations descriptive stats 方法描述DataFrame.abs()用于返回 DataFrame 中每個元素的絕對值DataFrame.all([axis, bool_only, skipna])用于判斷 DataFrame 中是否所有元素在指定軸上都為 TrueDataFrame.any(*[, axis, bool_only, skipna])用于判斷…

青藏高原七大河流源區徑流深、蒸散發數據集(TPRED)

時間分辨率 月空間分辨率 1km - 10km共享方式 開放獲取數據大小 83.27 MB數據時間范圍 1998-07-01 — 2017-12-31元數據更新時間 2024-07-22 數據集摘要 通過構建耦合積雪、凍土、冰川等冰凍圈水文物理過程的WEB-DHM模型&#xff08;Water and Energy Budget-based Distribute…

window環境下,如何通過USB接口控制打印機

雖然說大多數情況下&#xff0c;我們可以非常便利的通過打印機驅動來控制打印機&#xff0c;但還是有一些特殊情況&#xff0c;導致無法通過打印機驅動來完成我們預想的任務&#xff0c;比如&#xff0c;打印機只是一個系統設備中的一部分&#xff0c;需要協調其它設備一起工作…

CDGP數據治理主觀題評分標準與得分策略

1.數據模型題目評分標準 1)準確理解題目中所描述的業務邏輯和需求得[1分] 2)正確使用模型設計方法,使用信息工程、信息建模集成定義、巴克符號、陳氏符號等其中一種得[1分] 3)正確設計實體和屬性,題目中涉及的實體數量為25-30個,10個以內得[2分],10-20個得[3分],25個…

工業設計破局密碼:3D 可視化技術點燃產業升級引擎

3D可視化是一種將數據、信息或抽象概念以三維圖形、模型和動畫的形式呈現出來的技術。3D可視化技術通過構建三維數字孿生體&#xff0c;將設計思維轉化為可交互的虛擬原型&#xff0c;不僅打破了傳統二維設計的空間局限&#xff0c;更在效率、精度與用戶體驗層面開創了全新維度…

Qt中在子線程中刷新UI的方法

Qt中在子線程中刷新UI的方法 在Qt中UI界面并不是線程安全的&#xff0c;意味著在子線程中不能隨意操作UI界面組件&#xff08;比如按鈕、標簽&#xff09;等&#xff0c;如果強行操作這些組件有可能會導致程序崩潰。那么在Qt中如何在子線程中刷新UI控件呢&#xff1f; 兩種方…

為了摸魚和吃瓜,我開發了一個網站

平時上班真的比較累&#xff0c;摸魚和吃瓜還要跳轉多個平臺的話&#xff0c;就累上加累了。 所以做了一個聚合了全網主流平臺熱搜的網站。 目前市面上確實有很多這種網站了&#xff0c;所以目前最主要有兩點和他們不同&#xff1a; 給熱搜列表增加了配圖&#xff0c;刷的時候…

操作系統學習筆記第2章 (竟成)

第 2 章 進程管理 【考綱內容】 1.進程與線程&#xff1a; (1) 進程 / 線程的基本概念&#xff1b; (2) 進程 / 線程的狀態與轉換&#xff1b; (3) 線程的實現&#xff1a;內核支持的線程&#xff1b;線程庫支持的線程&#xff1b; (4) 進程與線程的組織與控制&#xff1b; (5)…

77.評論日記

房間要經常搞衛生&#xff0c;不然會很多灰&#xff0c;很多頭發&#xff0c;很多垃圾。 當然&#xff0c;即使一直搞衛生&#xff0c;在一些看不到的角落也是會慢慢囤積垃圾。 想要把那些角落也打掃干凈&#xff0c;沒別的辦法&#xff0c;只有把那個角落上所有的東西都移開&a…

語音合成之十二 TTS聲學編解碼器的演進

TTS聲學編解碼器的演進 1 引言&#xff1a;聲碼器/聲學編解碼器在現代TTS中的關鍵作用2 奠定基石&#xff1a;從早期聲碼器到神經合成的曙光3. HiFi-GAN: 革新高效高保真波形生成4. 新的疆域&#xff1a;面向富語義TTS的先進聲學編解碼器5. XCodec2.0: 統一聲學與語義信息6.BiC…

大學之大:悉尼科技大學2025.5.10

悉尼科技大學&#xff1a;從技術先驅到全球創新樞紐的百年征程 一、歷史沿革&#xff1a;從技工培訓到世界百強名校的蛻變 1. 工業革命的技術火種&#xff08;1843-1945&#xff09; 悉尼科技大學的歷史可追溯至1843年成立的悉尼機械學院&#xff08;Sydney Mechanics’ Scho…

安裝阿里云的yum源并且下載軟件(CentOS7版本)

目錄 1. 進入root模式: 2. 進入yum.repos.d文件下 3.備份 4. 安裝阿里云的yum源 5. 安裝dnf 6. 安裝epel-release 7. 清除緩存,并新建緩存 8. 安裝智能拼音軟件包 8.1安裝 8.2 進入應用程序 -- 系統工具 -- 設置 8.3重啟后就可以打中文啦~ (需要重新啟動才能)…

Discriminative and domain invariant subspace alignment for visual tasks

用于視覺任務的判別性和域不變子空間對齊 作者&#xff1a;Samaneh Rezaei&#xff0c;Jafar Tahmoresnezhad 文章于2018年12月4日收到&#xff0c;2019年5月24日被接受&#xff0c;2019年6月3日在線發表于Iran Journal of Computer Science期刊&#xff0c;DOI: 10.1007/s42…

用jsp簡單實現C語言標準化測試系統

C語言標準化測試系統 在Web編程技術的學習過程中&#xff0c;我們小組為了深入理解相關技術原理&#xff0c;提升實踐能力&#xff0c;開發了一個基于動態Web工程框架的C語言標準化考試系統。現在&#xff0c;就來和大家分享一下我們的項目經歷。 一、實驗目的剖析 這個項目…

QMK鍵盤固件自定義指南 - 打造你的專屬鍵盤體驗

QMK鍵盤固件自定義指南 - 打造你的專屬鍵盤體驗 &#x1f680; 前言 在機械鍵盤的世界里&#xff0c;QMK固件讓你的鍵盤不再只是簡單的輸入設備&#xff0c;而是可以按照你的意愿定制的強大工具。本文將深入淺出地介紹如何自定義QMK鍵盤的行為&#xff0c;從基礎概念到高級應…

5.9培訓

文件上傳 先找文件上傳的地方&#xff0c;打開代理鏈接BP&#xff0c;它需要一個xls文件 我們創建一個sqzr.xls bp攔截了之后&#xff0c;我們修改請求&#xff0c;把后綴改成php&#xff0c;發送請求 找到我們的靜態資源所在的位置 訪問http://192.168.1.100:81/static/upload…