Compare commits
40 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a2cea3ca9a | ||
|
|
b37172331e | ||
|
|
6d9fba8ea8 | ||
|
|
77a1f50115 | ||
|
|
1f7d5eb904 | ||
|
|
9f4028e439 | ||
|
|
b7085d2765 | ||
|
|
d2d3e9e3f5 | ||
|
|
95edbd85aa | ||
|
|
255baf2f3d | ||
|
|
713a47c337 | ||
|
|
044ddf9ef1 | ||
|
|
7d057843be | ||
|
|
d837507f10 | ||
|
|
9dd0d38cf8 | ||
|
|
647ee0937e | ||
|
|
2444817f63 | ||
|
|
6e0fe5d06b | ||
|
|
38e753b473 | ||
|
|
89f4565cd7 | ||
|
|
2da2f058ca | ||
|
|
af34178bf5 | ||
|
|
355372126f | ||
|
|
829c7b569b | ||
|
|
272b36d656 | ||
|
|
80341eb16c | ||
|
|
366c38401e | ||
|
|
b09e99e348 | ||
|
|
644d75b828 | ||
|
|
9136396673 | ||
|
|
d1a8a63579 | ||
|
|
5afbb5e642 | ||
|
|
dbf588a8d1 | ||
|
|
b365bf356a | ||
|
|
8f782c8327 | ||
|
|
a92abc0425 | ||
|
|
2c7953a17e | ||
|
|
f279baf126 | ||
|
|
6d86a69c0b | ||
|
|
cc7e260325 |
@@ -1,79 +1,61 @@
|
|||||||
---
|
---
|
||||||
## k8s默认是访问不了外部服务的,需要代理,以mysql和redis为例,代理myservice名称到192.168.0.100,配置文件中对应的ip修改为myservice
|
|
||||||
#apiVersion: v1
|
|
||||||
#kind: Endpoints
|
|
||||||
#metadata:
|
|
||||||
# name: myservice
|
|
||||||
#subsets:
|
|
||||||
# - addresses:
|
|
||||||
# - ip: 192.168.0.100
|
|
||||||
# ports:
|
|
||||||
# - port: 6379
|
|
||||||
# protocol: TCP
|
|
||||||
# name: redis
|
|
||||||
# - port: 3306
|
|
||||||
# protocol: TCP
|
|
||||||
# name: mysql
|
|
||||||
#---
|
|
||||||
#apiVersion: v1
|
|
||||||
#kind: Service
|
|
||||||
#metadata:
|
|
||||||
# name: myservice
|
|
||||||
#spec:
|
|
||||||
# ports:
|
|
||||||
# - port: 6379
|
|
||||||
# targetPort: 6379
|
|
||||||
# protocol: TCP
|
|
||||||
# name: redis
|
|
||||||
# - port: 3306
|
|
||||||
# targetPort: 3306
|
|
||||||
# protocol: TCP
|
|
||||||
# name: mysql
|
|
||||||
#
|
|
||||||
---
|
|
||||||
apiVersion: apps/v1
|
apiVersion: apps/v1
|
||||||
kind: Deployment
|
kind: Deployment
|
||||||
metadata:
|
metadata:
|
||||||
name: myk3sTest
|
labels:
|
||||||
|
app: $APP_NAME
|
||||||
|
version: $APP_TAG
|
||||||
|
name: $APP_NAME
|
||||||
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
replicas: 2
|
progressDeadlineSeconds: 600
|
||||||
revisionHistoryLimit: 3
|
replicas: 1
|
||||||
|
revisionHistoryLimit: 2
|
||||||
selector:
|
selector:
|
||||||
matchLabels:
|
matchLabels:
|
||||||
app: myk3sTest
|
app: $APP_NAME
|
||||||
|
strategy:
|
||||||
|
rollingUpdate:
|
||||||
|
maxSurge: 50%
|
||||||
|
maxUnavailable: 50%
|
||||||
|
type: RollingUpdate
|
||||||
template:
|
template:
|
||||||
metadata:
|
metadata:
|
||||||
labels:
|
labels:
|
||||||
app: myk3sTest
|
app: $APP_NAME
|
||||||
|
version: $APP_TAG
|
||||||
spec:
|
spec:
|
||||||
containers:
|
containers:
|
||||||
- image: ${env.REGISTRY}/${env.IMAGE_NAME}:${steps.datetime.outputs.datetime}
|
- image: registry.cn-chengdu.aliyuncs.com/bamanker/myk3stest:$APP_TAG #$REGISTRY/$DOCKERHUB_NAMESPACE/$APP_NAME
|
||||||
name: myk3sTest
|
name: $APP_NAME
|
||||||
imagePullPolicy: Always
|
imagePullPolicy: Always
|
||||||
readinessProbe:
|
readinessProbe:
|
||||||
httpGet:
|
httpGet:
|
||||||
path: /actuator/health
|
path: /actuator/health
|
||||||
port: 9090
|
port: 9090
|
||||||
initialDelaySeconds: 1
|
initialDelaySeconds: 1
|
||||||
|
timeoutSeconds: 10
|
||||||
|
failureThreshold: 30
|
||||||
successThreshold: 5
|
successThreshold: 5
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 9090
|
- containerPort: 9090
|
||||||
imagePullSecrets:
|
imagePullSecrets:
|
||||||
- name: dockerhub-id
|
- name: dockerhub-id
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: Service
|
kind: Service
|
||||||
metadata:
|
metadata:
|
||||||
name: myk3sTest
|
labels:
|
||||||
|
app: $APP_NAME
|
||||||
|
name: $APP_NAME
|
||||||
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
type: NodePort
|
type: NodePort
|
||||||
externalTrafficPolicy: Local
|
externalTrafficPolicy: Local
|
||||||
ports:
|
ports:
|
||||||
- name: http-8080
|
- name: http
|
||||||
protocol: TCP
|
protocol: TCP
|
||||||
port: 9090
|
port: 9090
|
||||||
nodePort: 30099
|
nodePort: 9090
|
||||||
selector:
|
selector:
|
||||||
app: myk3sTest
|
app: $APP_NAME
|
||||||
|
|||||||
@@ -2,15 +2,19 @@ name: Build Push and Deploy Image
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
#tag 触发
|
||||||
- main
|
tags:
|
||||||
|
- 'v*'
|
||||||
|
# 分支触发
|
||||||
|
# branches:
|
||||||
|
# - main
|
||||||
workflow_dispatch: #手动构建h
|
workflow_dispatch: #手动构建h
|
||||||
|
|
||||||
env:
|
env:
|
||||||
PATH: /opt/node/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
PATH: /opt/node/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
||||||
REGISTRY: registry.cn-chengdu.aliyuncs.com
|
REGISTRY: registry.cn-chengdu.aliyuncs.com
|
||||||
IMAGE_NAME: bamanker/myk3stest
|
IMAGE_NAME: bamanker/myk3stest
|
||||||
CONTAINER_NAME: myk3stest
|
APP_NAME: myk3s-test
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
# 构建 Job
|
# 构建 Job
|
||||||
@@ -22,17 +26,31 @@ jobs:
|
|||||||
# 下载仓库源码,依赖java环境,因此构建服务器本地需要下载安装java并设置环境变量
|
# 下载仓库源码,依赖java环境,因此构建服务器本地需要下载安装java并设置环境变量
|
||||||
- name: Checkout repository code
|
- name: Checkout repository code
|
||||||
uses: http://139.9.216.111:3000/bamanker/checkout@v6
|
uses: http://139.9.216.111:3000/bamanker/checkout@v6
|
||||||
# - name: Set up Java
|
# - name: Set up Java
|
||||||
# uses: https://gitee.com/bamanker/setup-java@v5
|
# uses: https://gitee.com/bamanker/setup-java@v5
|
||||||
# with:
|
# with:
|
||||||
# java-version: '25.0.1'
|
# java-version: '25.0.1'
|
||||||
# distribution: 'openjdk'
|
# distribution: 'openjdk'
|
||||||
# cache: 'maven'
|
# cache: 'maven'
|
||||||
#检查java版本
|
#检查java版本
|
||||||
|
- name: Get version
|
||||||
|
id: get_version
|
||||||
|
# e.g. refs/tags/v1.0.0
|
||||||
|
run: |
|
||||||
|
echo "version=${GITHUB_REF/refs\/tags\/v}" >> $GITHUB_OUTPUT
|
||||||
- name: Check java version
|
- name: Check java version
|
||||||
run: java -version
|
run: java -version
|
||||||
- name: Show now path
|
- name: Set Env Var
|
||||||
run: echo $(pwd)
|
env:
|
||||||
|
TAG: ${{ steps.get_version.outputs.version }}
|
||||||
|
run: |
|
||||||
|
export APP_TAG=${{ env.TAG }} |
|
||||||
|
echo APP_TAG=${{ env.TAG }} |
|
||||||
|
export APP_NAME=${{ env.APP_NAME }} |
|
||||||
|
echo APP_NAME=${{ env.APP_NAME }} |
|
||||||
|
- name: Inject Env Var
|
||||||
|
run: |
|
||||||
|
envsubst < .deploy/deployment.yml
|
||||||
- name: Build with Maven
|
- name: Build with Maven
|
||||||
# 设置Maven执行权限,使用maven绝对路径执行打包命令
|
# 设置Maven执行权限,使用maven绝对路径执行打包命令
|
||||||
run: /usr/local/maven/bin/mvn clean package -DskipTests -Pprod
|
run: /usr/local/maven/bin/mvn clean package -DskipTests -Pprod
|
||||||
@@ -46,7 +64,7 @@ jobs:
|
|||||||
# 这里也可以通过 secrets 传入,后面再介绍
|
# 这里也可以通过 secrets 传入,后面再介绍
|
||||||
password: ${{ secrets.DOCKERHUB_PASSWORD }}
|
password: ${{ secrets.DOCKERHUB_PASSWORD }}
|
||||||
|
|
||||||
# 获取时间戳,用于设置镜像 TAG 版本
|
# 获取时间戳
|
||||||
- name: Get datetime
|
- name: Get datetime
|
||||||
id: datetime
|
id: datetime
|
||||||
run: |
|
run: |
|
||||||
@@ -54,25 +72,32 @@ jobs:
|
|||||||
|
|
||||||
# 构建并上传镜像
|
# 构建并上传镜像
|
||||||
- name: Build and push Docker image
|
- name: Build and push Docker image
|
||||||
uses: http://139.9.216.111:3000/bamanker/build-push-action@v6
|
uses: http://139.9.216.111:3000/bamanker/build-push-action@v6 # 获取上一步截取到的版本号,既 1.0.0
|
||||||
|
env:
|
||||||
|
TAG: ${{ steps.get_version.outputs.version }}
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
platforms: linux/amd64
|
platforms: linux/amd64
|
||||||
file: Dockerfile
|
file: Dockerfile
|
||||||
push: true
|
push: true
|
||||||
tags: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ steps.datetime.outputs.datetime }}
|
tags: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.TAG }}
|
||||||
|
|
||||||
|
|
||||||
- name: k8s Check and Apply New Deployment
|
- name: k8s Check and Apply New Deployment
|
||||||
uses: http://139.9.216.111:3000/bamanker/kubectl@master
|
uses: http://139.9.216.111:3000/bamanker/steevchen-kubectl@master
|
||||||
env:
|
|
||||||
KUBE_CONFIG: ${{ secrets.KUBE_CONFIG }}
|
|
||||||
with:
|
with:
|
||||||
args: apply -f http://${{ secrets.DEVOPS_GITEA_TOKEN }}@/bamanker/myk3sTest/src/branch/master/.deploy/deployment.yml
|
config: ${{ secrets.KUBE_CONFIG }}
|
||||||
- name: k8s Update Deployment
|
command: apply -f http://139.9.216.111:3000/bamanker/myk3sTest/raw/branch/master/.deploy/deployment.yml
|
||||||
uses: http://139.9.216.111:3000/bamanker/kubectl@master
|
- name: k8s Check Pods Health
|
||||||
env:
|
uses: http://139.9.216.111:3000/bamanker/steevchen-kubectl@master
|
||||||
KUBE_CONFIG: ${{ secrets.KUBE_CONFIG }}
|
|
||||||
with:
|
with:
|
||||||
args: rollout restart deployment ${{ env.CONTAINER_NAME }}-${{ gitea.ref_name }}
|
config: ${{ secrets.KUBE_CONFIG }}
|
||||||
|
command: get pod -n default -l app=${{ env.APP_NAME }}
|
||||||
|
|
||||||
|
- name: k8s Update Deployment
|
||||||
|
uses: http://139.9.216.111:3000/bamanker/steevchen-kubectl@master
|
||||||
|
env:
|
||||||
|
KUBE_CONFIG: ${{ secrets.KUBE_CONFIG }}
|
||||||
|
with:
|
||||||
|
command: rollout restart deployment ${{ env.APP_NAME }}-${{ gitea.ref_name }}
|
||||||
|
|
||||||
|
|||||||
2
pom.xml
2
pom.xml
@@ -66,8 +66,6 @@
|
|||||||
<configuration>
|
<configuration>
|
||||||
<source>25</source>
|
<source>25</source>
|
||||||
<target>25</target>
|
<target>25</target>
|
||||||
|
|
||||||
|
|
||||||
<annotationProcessorPaths>
|
<annotationProcessorPaths>
|
||||||
<path>
|
<path>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
|||||||
Reference in New Issue
Block a user