From 795a1b8d479cf66db3d05e28e48d53913736b138 Mon Sep 17 00:00:00 2001 From: otto <965391514@qq.com> Date: Mon, 24 Jun 2024 11:35:24 +0800 Subject: [PATCH] up --- .gitignore | 42 +++++++++++ Dockerfile | 21 ++++++ Jenkinsfile | 143 +++++++++++++++++++++++++++++++++++++ build.sh | 35 +++++++++ configs/config | 19 +++++ configs/config-dev | 19 +++++ configs/config-master | 19 +++++ go.mod | 64 +++++++++++++++++ hotspot-clear-job-dev.yaml | 22 ++++++ main.go | 60 ++++++++++++++++ 10 files changed, 444 insertions(+) create mode 100644 .gitignore create mode 100644 Dockerfile create mode 100644 Jenkinsfile create mode 100644 build.sh create mode 100644 configs/config create mode 100644 configs/config-dev create mode 100644 configs/config-master create mode 100644 go.mod create mode 100644 hotspot-clear-job-dev.yaml create mode 100644 main.go diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..46d95bc --- /dev/null +++ b/.gitignore @@ -0,0 +1,42 @@ +# Reference https://github.com/github/gitignore/blob/master/Go.gitignore +# Binaries for programs and plugins +*.exe +*.exe~ +*.dll +*.so +*.dylib + +# Test binary, built with `go test -c` +*.test + +# Output of the go coverage tool, specifically when used with LiteIDE +*.out + +# Dependency directories (remove the comment below to include it) +vendor/ + +# Go workspace file +go.work + +# Compiled Object files, Static and Dynamic libs (Shared Objects) +*.o +*.a +*.so + +# OS General +Thumbs.db +.DS_Store + +# project +*.cert +*.key +*.log +bin/ +# Develop tools +.vscode/ +.idea/ +*.swp +go.sum + +test +main \ No newline at end of file diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..3b87e58 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,21 @@ +FROM 192.168.1.131:8888/library/golang:1.20.5 AS builder + +COPY . /src +WORKDIR /src + +RUN go mod tidy +RUN go build hot.go + +FROM 192.168.1.131:8888/library/alpine:3.13 +RUN apk add make +RUN set -eux && sed -i 's/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g' /etc/apk/repositories +RUN apk update && apk add tzdata +RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime +RUN echo "Asia/Shanghai" > /etc/timezone + +WORKDIR /app + +COPY --from=builder /src/configs /app/configs +COPY --from=builder /src/hot /app/hot +ENTRYPOINT ["./hot"] + diff --git a/Jenkinsfile b/Jenkinsfile new file mode 100644 index 0000000..b6fb035 --- /dev/null +++ b/Jenkinsfile @@ -0,0 +1,143 @@ +// 获取当前的git分支 +def branch(){ + switch("${env.GIT_BRANCH}") { + case "origin/dev": + return "dev" + case "origin/release": + return "release" + case "origin/beta": + return "beta" + case "origin/master": + return "master" + case "*/dev": + return "dev" + case "*/release": + return "release" + case "*/beta": + return "beta" + case "*/master": + return "master" + } + return "" +} +// 同步yaml部署文件 +def yaml(){ + switch("${env.Branch}") { + case "dev": + sshPublisher(publishers: [sshPublisherDesc(configName: 'k8s', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: '', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: "${NAME}-job-${env.BRANCH}.yaml")], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)]) + break + case "release": + break + case "beta": + echo "yaml beta" + break + case "master": + sshPublisher(publishers: [sshPublisherDesc(configName: 'master-k8s', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: '', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: "${NAME}-job-${env.BRANCH}.yaml")], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)]) + break + } +} + +// 执行yaml部署 +def apply(){ + switch("${env.Branch}") { + case "dev": + sh "ssh root@192.168.1.156 kubectl apply -f /usr/local/k8s/${NAME}-job-${env.BRANCH}.yaml" + break + case "release": + echo "apply release" + break + case "beta": + echo "apply beta" + break + case "master": + sshagent(['test-k8s-login-key']) { + sh "ssh root@193.112.79.170 kubectl apply -f /usr/local/k8s/${NAME}-job-${env.BRANCH}.yaml" + } + break + } +} + +def image(){ + switch("${env.Branch}") { + case "dev": + sh "ssh root@192.168.1.156 kubectl set image Deployment/${env.K8S_DEPLOYMENT} ${env.NAME}=192.168.1.131:8888/job/${env.BRANCH}/${env.NAME}:${env.VERSION} -n ${env.BRANCH}" + break + case "release": + echo "image release" + break + case "beta": + echo "image beta" + break + case "master": + sshagent(['test-k8s-login-key']) { + sh "ssh root@193.112.79.170 kubectl set image Deployment/${env.K8S_DEPLOYMENT} ${env.NAME}=192.168.0.19:5000/job/${env.BRANCH}/${env.NAME}:${env.VERSION} -n ${env.BRANCH}" + } + break + } +} + +pipeline { + agent any + + environment { + // 服务名 + NAME = 'message-clear' + // 镜像名称,对应K8S_FILE里面Deployment.containers的name + + // git路径 + // GIT_URL = 'http://git.gz.internal.jumaiyx.cn/job/hotspot-clear.git' + + // k8s deployment名称,对应K8S_FILE里面Deployment的name + K8S_DEPLOYMENT = 'message-clear-job' + + // 分支 + BRANCH = branch() + + // 更新的版本 + VERSION = "${env.GIT_COMMIT}" + + // 自动生成版本号,仅限dev和release使用,master按照tag版本 + IMAGE_VERSION = UUID.randomUUID().toString() + + } + + + stages { + // 首次部署需要使用,后期可以直接注释掉此步骤 + stage('传入yaml') { + steps { + yaml() + echo '传入yaml 完成' + } + } + // 首次部署需要使用,后期可以直接注释掉此步骤 + stage('apply') { + + steps { + // apply() + echo '执行apply 完成' + } + } + stage('更新image') { + steps { +// image() + echo '更新image 完成' + } + + } + + } + post { + always { + echo 'I will always say Hello again!' + } + success { + // FeiShu(webhook:fei(),proxy:'',msg:'',atAll:false,type:'') + echo '部署完成' + } + failure { + // FeiShu(webhook:fei(),proxy:'',msg:'',atAll:false,type:'') + echo 'I will always say Hello again!' + } + } +} diff --git a/build.sh b/build.sh new file mode 100644 index 0000000..ed1cffe --- /dev/null +++ b/build.sh @@ -0,0 +1,35 @@ +#!/bin/bash +#version=git log --format='%H' -n1 +project_name="message-clear" +version=$(git log --format='%H' -n1) +environment=$(git rev-parse --abbrev-ref HEAD) +hostname="192.168.1.131:8888" + +if [ ! -n "$version" ] ;then + echo "未获取到版本信息" + return +fi + +echo "打包的环境:$environment" +echo "打包版本号:$version" +echo "项目名称:$project_name" + +if [ $environment == "dev" ] ;then + echo "======登录镜像仓库======" + docker login -u admin -p jumai123 192.168.1.131:8888 +fi + +if [ $environment == "master" ] ;then + hostname="harbor.homieyy.com" + echo "======登录镜像仓库======" + docker login -u admin -p 1EeFT5qjpM harbor.homieyy.com +fi + +echo "======build======" +docker build -t $project_name:latest . +echo "======tag=======" +docker tag $project_name:latest $hostname/job/$environment/$project_name:$version +echo "======push=======" +docker push $hostname/job/$environment/$project_name:$version +echo "======delete=====" +docker rmi $project_name:latest $hostname/job/$environment/$project_name:$version diff --git a/configs/config b/configs/config new file mode 100644 index 0000000..11e56cc --- /dev/null +++ b/configs/config @@ -0,0 +1,19 @@ +apiVersion: v1 +clusters: +- cluster: + certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUN5RENDQWJDZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQjRYRFRJME1EUXdNVEE1TkRnek1Wb1hEVE0wTURNek1EQTVORGd6TVZvd0ZURVRNQkVHQTFVRQpBeE1LYTNWaVpYSnVaWFJsY3pDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBS014ClZYTWxmNWlDS09pRHRkMEN6QkY3OUF5VzRaa0hLbG4yYTJERExWbW5GNFNsSTA4SFhRcm1lRGN1b21MQzR6a3IKMzdLcFNQRVdrMUhDUG5ZWTM2b3d4dmlBVWNhR0s1aVJ2TGlPc08rQzJ1WU02d2ozMEJoRkw1Mk9EV3NkS045UwptN1hqQk1nR0lCb3ZaZEs1Z3dJOHdvckIvYTlXYUw3cVltOWpqcGgzcWtWeEk0Y2crV3VYS1dicG9Ha3NpdENvCk5aMmNKTTlXV2FxWjMvcE1yeEFTbXJ5UlcxWVBtd3VLQW94Y3V1cFJtbVdtM1lmOWNraVBpMy9IZ3VWY0pTVkkKdVhabmVaMXZFVlVXc0pjUnphdFBzVDI2MnBhT1BFS251S0g3ZHlvankvekVSWE5RZVVUNS9kWVloTDdHYnJDRwpjWks3OFBMMEhlU0N4MElmbVBzQ0F3RUFBYU1qTUNFd0RnWURWUjBQQVFIL0JBUURBZ0trTUE4R0ExVWRFd0VCCi93UUZNQU1CQWY4d0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dFQkFDRk4xUkZjZnl3MW9FRnlCZ1ArSTVxU1JVZzAKQXkrTTdPMTl5QTB2SXRQY2RkRTJQYUxGendTSVhlY0dUamkxK0g4T1hEZHRJR0RSMXpDczJ1Z0s3cG1KTGhqWQpaRmsyS3JXM3pxUzNJYktiT1BvdkpQeUhJNU9WNDN6ZXpQaFdla1Rqc1AyMnBITHE2d2ZoSVV4bk01cEJsL21SCnRGbFI5aUhnVElYaC9HbHFnSlZxamVDdFBGOUhhNS8vQmlWQXk5T2pqQm1zN2djemV3TmZmRWJFaG5OWTVvL0QKZlc3SnoyZTRKaWhtRkZxZWdUYXBDMjJXaDdEYU9rV2NhbXVjRFJzMDlPdEVyRm8zNVRsdjdRL0RidjNDU1hPcwpHcVp2dlB3Rkt1Y2JhZjAzOFdyT1dmcXlsdTBpT2VFVEN5MkVPaEtYOUxjZ3pHeTRvNnFRNDNaRllNMD0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo= + server: https://192.168.1.156:6443 + name: kubernetes +contexts: +- context: + cluster: kubernetes + user: kubernetes-admin + name: kubernetes-admin@kubernetes +current-context: kubernetes-admin@kubernetes +kind: Config +preferences: {} +users: +- name: kubernetes-admin + user: + client-certificate-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUM4akNDQWRxZ0F3SUJBZ0lJRzFyL0hQZ2VCd3d3RFFZSktvWklodmNOQVFFTEJRQXdGVEVUTUJFR0ExVUUKQXhNS2EzVmlaWEp1WlhSbGN6QWVGdzB5TkRBME1ERXdPVFE0TXpGYUZ3MHlOVEEwTURFd09UUTRNek5hTURReApGekFWQmdOVkJBb1REbk41YzNSbGJUcHRZWE4wWlhKek1Sa3dGd1lEVlFRREV4QnJkV0psY201bGRHVnpMV0ZrCmJXbHVNSUlCSWpBTkJna3Foa2lHOXcwQkFRRUZBQU9DQVE4QU1JSUJDZ0tDQVFFQTVydU5Mc0MrVHVZb3lxOFUKdXREVlN6bEpWdzVxZmlncUZvYlF6WjVjUXFMaFlxMU1RSXlRUEhDdjBPVUdVUmh4eWtHS3pZNU1NZWk4cjFxdwo0VUU2RGIxQnhtZVBZNlQ5VUY5Wnh4bzJHajBFYmNIaDlWc3FZZnNGYkVXMFB6dlR4QW16WE1wZkNhVWphOTlLClRmdGZsa1JQY0hVZ2JDN0dXMW4xZjE0NExYa3RHcnIzU3JHaTA5WTVBRzhBdVJSNnNMQUp5cEdBZUE0UE9sVE8KMlBRR1NXRnZ6MUcwS2hUQmxVWjYyVEc0REZaN3I4ZlZOTlVDZ1BmdngvZUk2REZGL08vbnJCYVpCZWpmWS92agorVmFCSU1hb2RrL3JEZlc2VEQrbjVhUjI2aVpGQ1FzMjdwMUpNWWhKT2JBVThHcWRVZElwWVp0RGEyZVM4MzN1CkYwOE9ud0lEQVFBQm95Y3dKVEFPQmdOVkhROEJBZjhFQkFNQ0JhQXdFd1lEVlIwbEJBd3dDZ1lJS3dZQkJRVUgKQXdJd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dFQkFCVmpzOFo4NUM0Tk1hekkwZVVRWUZLeGhSbzh0YzhJMXRHYgp0a2E5ZXZDeERkY3Z2SCt5bVpoTSt4YXdTZVh3MTI0R0QxdGxZN3dOSTF1VW54cFYwcWF4bmt6RXFhSHJxM1d0CnRUZWcxaU81OE5qYXdoaGtWditQLytGbENlQzZnbTlWeWdwckY2NFNkU1p3VFpkOW9CNXhyRGQxa21GamJxMzUKUzNMYlZTcVlJUFRPNGRzRVl6WjVld2dSSlZpTkEvSzJzMTg5QWh3Y29rZlY5OTQ0TXU2MmQvd25ZOGNkM0QwRQpkbWVFdEhqVGM0M3lpODY2aWpLUlE3OWFMOEFyQWlXVFJxVXlEdWVqRWxuK3dzWnlGZ1I5SEFuQjdoZ21GQ0VECnp0ZW5yUjVMandXdStGZnZOYXVkam9mTjNqRnJNd3ZDK2hlRXJwZ3JRaWRzMlR0ei9RRT0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo= + client-key-data: LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlFcFFJQkFBS0NBUUVBNXJ1TkxzQytUdVlveXE4VXV0RFZTemxKVnc1cWZpZ3FGb2JRelo1Y1FxTGhZcTFNClFJeVFQSEN2ME9VR1VSaHh5a0dLelk1TU1laThyMXF3NFVFNkRiMUJ4bWVQWTZUOVVGOVp4eG8yR2owRWJjSGgKOVZzcVlmc0ZiRVcwUHp2VHhBbXpYTXBmQ2FVamE5OUtUZnRmbGtSUGNIVWdiQzdHVzFuMWYxNDRMWGt0R3JyMwpTckdpMDlZNUFHOEF1UlI2c0xBSnlwR0FlQTRQT2xUTzJQUUdTV0Z2ejFHMEtoVEJsVVo2MlRHNERGWjdyOGZWCk5OVUNnUGZ2eC9lSTZERkYvTy9uckJhWkJlamZZL3ZqK1ZhQklNYW9kay9yRGZXNlREK241YVIyNmlaRkNRczIKN3AxSk1ZaEpPYkFVOEdxZFVkSXBZWnREYTJlUzgzM3VGMDhPbndJREFRQUJBb0lCQVFDQWhsU2NpR3o1MGlkQwp6OGdDVURXZjAyZFJBUXk4L1c2RVlkQ0oyUDZYZDllSWVmUVJ1THJYa0FXL25QT3AxSzM5OWdoMWZDQmhaTDFHCkNJU2kxUXliZnFMVysvVFprcHd3V3d6TlpZSmhseitTUy8rc0JuNVRXZHFwZHlKeVhzY1ZXam41SkJsUWJCYVIKRGk1N3hkeDIvZElxV0hRWkR1MGJFYjg0bGFsQldrR1JiaERBMVVaZTRmWVBrTG1aM3hPNGxZYjJhVDBKQmVDUQpyVENIYktDVkZLL0plTis2Y2dyd1ZaazdXMGdOSTVvNFlyVUczNFpZYTErelI5cUhYNmwrQmhZNXYyMERwRGd6CkRjMVp4V25QTzRybGtMaFQ2VnZ2UDAxaUJUZTJlSnAwaWs4cHQxaVl5QjduaStUUmo5MXV0YXFxaXB4cnMwVlUKYTUvdEJybnhBb0dCQU9rMmZpa0kvd3VnbUxaVk5raVJpVnpkNzZmbE9rWG80WEFSZWFrV3oybHh1OFE4MThlVQpTSGRHdFZEZ3QzQmFkWVdrSUxQSGxqamRrazBjZlZxTi9pYWN5V3pjeiszSWZONXVQQmN5dlpSL2lXakl4T0MrCmdNdm9zOG10VUJvMlJPY3oyVWMzTlNDWUxwUWZTU2hzSHd4YmdxMS93Q3RobFJUM2JXOUJlMC9MQW9HQkFQMUgKQk5EMUNVa0podjdMVWNtODNTTlovSmhsMWxQNGpXMEFnZkNBTS9UQThoWTdYSjRKRHMwelVBR2tTNk1DWHdYcwpDS2F5TStqZlhzcFVCUm5XekJvcEU2UnNYQW10YXVreFNTVVJGRXEvYVdtd2RvbE5tNDZ3LzQ1OS9PcmtKd2xrCnl1ai9qR0laMjNoRHZnOHBua0JRV0FlU0dhY3d0MHBONkg1VFp6bjlBb0dCQUwyWXI3aHN0K3ljQTRzNGU0bEQKeUlqWFpaNzVuUVo0N2M1T1pyb3c4UzZvYUI2QjJHdEpBaUQyT3pJbGZ2eTRqaEszL0Y0c1JOUzJUZHFpN3NaUAo2ZTg2U0FkWS9USXpiRkRwRGJGT2J4SHJIYXN5amR5cEE4ekN3bWVUbnl1d014UkQ4c0VUQVA0ZXVyOXhMK2pNCi9mRHQ5SzlZek1KMzh0dTR6QjlHL1JsQkFvR0JBT1J6YjRPdTBhNUFXclJ0M2hyU01NRFhSUUNOTXJKUkNmZWMKc3Bla2U3aXpaR2pyS0ZJZnAyc3RjbWZZc3FTWTJlNzBoS1VmTGJWSjdTMGdkZTFsa25teVBWWmNxdlBMcVJnbgpiV3R5cVZQMnJQVTR4dUozenV6NDk3bW1LRUFTaEtkemM1YVFFaWJXWGVCdmNmb3BOdVdaMHAwWmlld0ZBLzZRCm9UbDRyeTVkQW9HQWFxemt3V1B5TUs5RENkMTE5d1laSC9ualpmbVBzK2lxVTJSTzhkVXFEZDVHZjhyd0o0NDkKOWNxYWw3Mkx5Ni91RkRKRVRqbDQxd0c0QWZWbmovUHlSNXRZWXptSVV4bzcxN0YyNXdlK1VnY003a1B3NmIregpjL0lySTBiY0RsTkxPSzRyWGRCOUk5YzQ1bVZpUldNeTNITW1mTU5uMnkxanRUUnBMWGgyQ09zPQotLS0tLUVORCBSU0EgUFJJVkFURSBLRVktLS0tLQo= \ No newline at end of file diff --git a/configs/config-dev b/configs/config-dev new file mode 100644 index 0000000..11e56cc --- /dev/null +++ b/configs/config-dev @@ -0,0 +1,19 @@ +apiVersion: v1 +clusters: +- cluster: + certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUN5RENDQWJDZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQjRYRFRJME1EUXdNVEE1TkRnek1Wb1hEVE0wTURNek1EQTVORGd6TVZvd0ZURVRNQkVHQTFVRQpBeE1LYTNWaVpYSnVaWFJsY3pDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBS014ClZYTWxmNWlDS09pRHRkMEN6QkY3OUF5VzRaa0hLbG4yYTJERExWbW5GNFNsSTA4SFhRcm1lRGN1b21MQzR6a3IKMzdLcFNQRVdrMUhDUG5ZWTM2b3d4dmlBVWNhR0s1aVJ2TGlPc08rQzJ1WU02d2ozMEJoRkw1Mk9EV3NkS045UwptN1hqQk1nR0lCb3ZaZEs1Z3dJOHdvckIvYTlXYUw3cVltOWpqcGgzcWtWeEk0Y2crV3VYS1dicG9Ha3NpdENvCk5aMmNKTTlXV2FxWjMvcE1yeEFTbXJ5UlcxWVBtd3VLQW94Y3V1cFJtbVdtM1lmOWNraVBpMy9IZ3VWY0pTVkkKdVhabmVaMXZFVlVXc0pjUnphdFBzVDI2MnBhT1BFS251S0g3ZHlvankvekVSWE5RZVVUNS9kWVloTDdHYnJDRwpjWks3OFBMMEhlU0N4MElmbVBzQ0F3RUFBYU1qTUNFd0RnWURWUjBQQVFIL0JBUURBZ0trTUE4R0ExVWRFd0VCCi93UUZNQU1CQWY4d0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dFQkFDRk4xUkZjZnl3MW9FRnlCZ1ArSTVxU1JVZzAKQXkrTTdPMTl5QTB2SXRQY2RkRTJQYUxGendTSVhlY0dUamkxK0g4T1hEZHRJR0RSMXpDczJ1Z0s3cG1KTGhqWQpaRmsyS3JXM3pxUzNJYktiT1BvdkpQeUhJNU9WNDN6ZXpQaFdla1Rqc1AyMnBITHE2d2ZoSVV4bk01cEJsL21SCnRGbFI5aUhnVElYaC9HbHFnSlZxamVDdFBGOUhhNS8vQmlWQXk5T2pqQm1zN2djemV3TmZmRWJFaG5OWTVvL0QKZlc3SnoyZTRKaWhtRkZxZWdUYXBDMjJXaDdEYU9rV2NhbXVjRFJzMDlPdEVyRm8zNVRsdjdRL0RidjNDU1hPcwpHcVp2dlB3Rkt1Y2JhZjAzOFdyT1dmcXlsdTBpT2VFVEN5MkVPaEtYOUxjZ3pHeTRvNnFRNDNaRllNMD0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo= + server: https://192.168.1.156:6443 + name: kubernetes +contexts: +- context: + cluster: kubernetes + user: kubernetes-admin + name: kubernetes-admin@kubernetes +current-context: kubernetes-admin@kubernetes +kind: Config +preferences: {} +users: +- name: kubernetes-admin + user: + client-certificate-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUM4akNDQWRxZ0F3SUJBZ0lJRzFyL0hQZ2VCd3d3RFFZSktvWklodmNOQVFFTEJRQXdGVEVUTUJFR0ExVUUKQXhNS2EzVmlaWEp1WlhSbGN6QWVGdzB5TkRBME1ERXdPVFE0TXpGYUZ3MHlOVEEwTURFd09UUTRNek5hTURReApGekFWQmdOVkJBb1REbk41YzNSbGJUcHRZWE4wWlhKek1Sa3dGd1lEVlFRREV4QnJkV0psY201bGRHVnpMV0ZrCmJXbHVNSUlCSWpBTkJna3Foa2lHOXcwQkFRRUZBQU9DQVE4QU1JSUJDZ0tDQVFFQTVydU5Mc0MrVHVZb3lxOFUKdXREVlN6bEpWdzVxZmlncUZvYlF6WjVjUXFMaFlxMU1RSXlRUEhDdjBPVUdVUmh4eWtHS3pZNU1NZWk4cjFxdwo0VUU2RGIxQnhtZVBZNlQ5VUY5Wnh4bzJHajBFYmNIaDlWc3FZZnNGYkVXMFB6dlR4QW16WE1wZkNhVWphOTlLClRmdGZsa1JQY0hVZ2JDN0dXMW4xZjE0NExYa3RHcnIzU3JHaTA5WTVBRzhBdVJSNnNMQUp5cEdBZUE0UE9sVE8KMlBRR1NXRnZ6MUcwS2hUQmxVWjYyVEc0REZaN3I4ZlZOTlVDZ1BmdngvZUk2REZGL08vbnJCYVpCZWpmWS92agorVmFCSU1hb2RrL3JEZlc2VEQrbjVhUjI2aVpGQ1FzMjdwMUpNWWhKT2JBVThHcWRVZElwWVp0RGEyZVM4MzN1CkYwOE9ud0lEQVFBQm95Y3dKVEFPQmdOVkhROEJBZjhFQkFNQ0JhQXdFd1lEVlIwbEJBd3dDZ1lJS3dZQkJRVUgKQXdJd0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dFQkFCVmpzOFo4NUM0Tk1hekkwZVVRWUZLeGhSbzh0YzhJMXRHYgp0a2E5ZXZDeERkY3Z2SCt5bVpoTSt4YXdTZVh3MTI0R0QxdGxZN3dOSTF1VW54cFYwcWF4bmt6RXFhSHJxM1d0CnRUZWcxaU81OE5qYXdoaGtWditQLytGbENlQzZnbTlWeWdwckY2NFNkU1p3VFpkOW9CNXhyRGQxa21GamJxMzUKUzNMYlZTcVlJUFRPNGRzRVl6WjVld2dSSlZpTkEvSzJzMTg5QWh3Y29rZlY5OTQ0TXU2MmQvd25ZOGNkM0QwRQpkbWVFdEhqVGM0M3lpODY2aWpLUlE3OWFMOEFyQWlXVFJxVXlEdWVqRWxuK3dzWnlGZ1I5SEFuQjdoZ21GQ0VECnp0ZW5yUjVMandXdStGZnZOYXVkam9mTjNqRnJNd3ZDK2hlRXJwZ3JRaWRzMlR0ei9RRT0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo= + client-key-data: LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlFcFFJQkFBS0NBUUVBNXJ1TkxzQytUdVlveXE4VXV0RFZTemxKVnc1cWZpZ3FGb2JRelo1Y1FxTGhZcTFNClFJeVFQSEN2ME9VR1VSaHh5a0dLelk1TU1laThyMXF3NFVFNkRiMUJ4bWVQWTZUOVVGOVp4eG8yR2owRWJjSGgKOVZzcVlmc0ZiRVcwUHp2VHhBbXpYTXBmQ2FVamE5OUtUZnRmbGtSUGNIVWdiQzdHVzFuMWYxNDRMWGt0R3JyMwpTckdpMDlZNUFHOEF1UlI2c0xBSnlwR0FlQTRQT2xUTzJQUUdTV0Z2ejFHMEtoVEJsVVo2MlRHNERGWjdyOGZWCk5OVUNnUGZ2eC9lSTZERkYvTy9uckJhWkJlamZZL3ZqK1ZhQklNYW9kay9yRGZXNlREK241YVIyNmlaRkNRczIKN3AxSk1ZaEpPYkFVOEdxZFVkSXBZWnREYTJlUzgzM3VGMDhPbndJREFRQUJBb0lCQVFDQWhsU2NpR3o1MGlkQwp6OGdDVURXZjAyZFJBUXk4L1c2RVlkQ0oyUDZYZDllSWVmUVJ1THJYa0FXL25QT3AxSzM5OWdoMWZDQmhaTDFHCkNJU2kxUXliZnFMVysvVFprcHd3V3d6TlpZSmhseitTUy8rc0JuNVRXZHFwZHlKeVhzY1ZXam41SkJsUWJCYVIKRGk1N3hkeDIvZElxV0hRWkR1MGJFYjg0bGFsQldrR1JiaERBMVVaZTRmWVBrTG1aM3hPNGxZYjJhVDBKQmVDUQpyVENIYktDVkZLL0plTis2Y2dyd1ZaazdXMGdOSTVvNFlyVUczNFpZYTErelI5cUhYNmwrQmhZNXYyMERwRGd6CkRjMVp4V25QTzRybGtMaFQ2VnZ2UDAxaUJUZTJlSnAwaWs4cHQxaVl5QjduaStUUmo5MXV0YXFxaXB4cnMwVlUKYTUvdEJybnhBb0dCQU9rMmZpa0kvd3VnbUxaVk5raVJpVnpkNzZmbE9rWG80WEFSZWFrV3oybHh1OFE4MThlVQpTSGRHdFZEZ3QzQmFkWVdrSUxQSGxqamRrazBjZlZxTi9pYWN5V3pjeiszSWZONXVQQmN5dlpSL2lXakl4T0MrCmdNdm9zOG10VUJvMlJPY3oyVWMzTlNDWUxwUWZTU2hzSHd4YmdxMS93Q3RobFJUM2JXOUJlMC9MQW9HQkFQMUgKQk5EMUNVa0podjdMVWNtODNTTlovSmhsMWxQNGpXMEFnZkNBTS9UQThoWTdYSjRKRHMwelVBR2tTNk1DWHdYcwpDS2F5TStqZlhzcFVCUm5XekJvcEU2UnNYQW10YXVreFNTVVJGRXEvYVdtd2RvbE5tNDZ3LzQ1OS9PcmtKd2xrCnl1ai9qR0laMjNoRHZnOHBua0JRV0FlU0dhY3d0MHBONkg1VFp6bjlBb0dCQUwyWXI3aHN0K3ljQTRzNGU0bEQKeUlqWFpaNzVuUVo0N2M1T1pyb3c4UzZvYUI2QjJHdEpBaUQyT3pJbGZ2eTRqaEszL0Y0c1JOUzJUZHFpN3NaUAo2ZTg2U0FkWS9USXpiRkRwRGJGT2J4SHJIYXN5amR5cEE4ekN3bWVUbnl1d014UkQ4c0VUQVA0ZXVyOXhMK2pNCi9mRHQ5SzlZek1KMzh0dTR6QjlHL1JsQkFvR0JBT1J6YjRPdTBhNUFXclJ0M2hyU01NRFhSUUNOTXJKUkNmZWMKc3Bla2U3aXpaR2pyS0ZJZnAyc3RjbWZZc3FTWTJlNzBoS1VmTGJWSjdTMGdkZTFsa25teVBWWmNxdlBMcVJnbgpiV3R5cVZQMnJQVTR4dUozenV6NDk3bW1LRUFTaEtkemM1YVFFaWJXWGVCdmNmb3BOdVdaMHAwWmlld0ZBLzZRCm9UbDRyeTVkQW9HQWFxemt3V1B5TUs5RENkMTE5d1laSC9ualpmbVBzK2lxVTJSTzhkVXFEZDVHZjhyd0o0NDkKOWNxYWw3Mkx5Ni91RkRKRVRqbDQxd0c0QWZWbmovUHlSNXRZWXptSVV4bzcxN0YyNXdlK1VnY003a1B3NmIregpjL0lySTBiY0RsTkxPSzRyWGRCOUk5YzQ1bVZpUldNeTNITW1mTU5uMnkxanRUUnBMWGgyQ09zPQotLS0tLUVORCBSU0EgUFJJVkFURSBLRVktLS0tLQo= \ No newline at end of file diff --git a/configs/config-master b/configs/config-master new file mode 100644 index 0000000..f3af8f0 --- /dev/null +++ b/configs/config-master @@ -0,0 +1,19 @@ +apiVersion: v1 +clusters: +- cluster: + certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUN5RENDQWJDZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQjRYRFRJME1ETXhNVEF5TVRVd05Gb1hEVE0wTURNd09UQXlNVFV3TkZvd0ZURVRNQkVHQTFVRQpBeE1LYTNWaVpYSnVaWFJsY3pDQ0FTSXdEUVlKS29aSWh2Y05BUUVCQlFBRGdnRVBBRENDQVFvQ2dnRUJBTVZQCko2aXZPTHdFU2R6eWJnaUV4RUNGNjFSaEJoc0hvS2VYTDkzMDZ5bkZwQlNFM05aR3BoN2NDNDllQXRzWldYdnoKR1F3RHFjQ25Wd0tKZ1RRWElGaEtnTXV5UVZVdWdnQ3NuRVpIcW40K2dCbE8xQnNoWFlrNUgvdDFjTEJRaks5TAo1dG5RMXdPbkFRU2tocHRJaTM0YmZPdWpUdkpjYWV0QWc4dC9LdzJkRm1aZFdVWUlYUmJhRE5LSzU0UmVHeDh4CmFUa29JWk43Ym8xOUZsOCtRWXVyYlh5QmEvZjMzcE1UVzhRVzl2cUFCWVBGSEtEM0VNZlphdThZaWpockY4QmoKNXhkdFRidThJRUhkTFVYQU56aUkxWGFtNVR1bnJibktTTll1cEpON2plRGtpT2NDdUJZbk9UOW02b1lzNFhnMwppeHdsSFhyK3owZ3R2dkJvZFBjQ0F3RUFBYU1qTUNFd0RnWURWUjBQQVFIL0JBUURBZ0tVTUE4R0ExVWRFd0VCCi93UUZNQU1CQWY4d0RRWUpLb1pJaHZjTkFRRUxCUUFEZ2dFQkFDcFNTYVp6a0RtMzhteUtXSDNsYkVHSDJ3MWgKb3p2cStreWRDQ251VUYrRWlOOFlQeWJ4LzVkUFcyL2xwdm8xdkozTm1hZjBmd1dyeW5HVnZWS01zYVZYU3NOWgpnR0ZvOG5BTXc5ZEswNytzcGVRdHJjaG43bHlzZTNJcjUrcEt5ekNpMG5ZNktMSUV2d3JnallzbU9vbTZKVGVSCmd1UVN6cE9HUlJwN3FndHNpa1M1RnFEYXhLU1QwQ2tZT2U0eTZGOGZDTEhOTXJqeDEvYWVQZlpBWVlhbC9QU2gKL0dicEVJVFg4QWFKeDhiM2xURlF2UFZadTFucUJzTitpV3BuMFQ0Tm14Y09IbjNyeWJqa09jdU9GL0p4aVFhUwpTQVFic1l2Q01pQkZXZHRoeDFNSFpBOWRkTHMrSk96bjdzVFZ1Y2RtcU04YkRaNVNJOGhGRGRvU1JhND0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo= + server: https://192.168.0.20 + name: cls-1wvehx8c +contexts: +- context: + cluster: cls-1wvehx8c + user: "100029630066" + name: cls-1wvehx8c-100029630066-context-default +current-context: cls-1wvehx8c-100029630066-context-default +kind: Config +preferences: {} +users: +- name: "100029630066" + user: + client-certificate-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSURERENDQWZTZ0F3SUJBZ0lJV1Y4cjFQQWxPYmt3RFFZSktvWklodmNOQVFFTEJRQXdGVEVUTUJFR0ExVUUKQXhNS2EzVmlaWEp1WlhSbGN6QWVGdzB5TkRBek1URXdNakkyTURsYUZ3MDBOREF6TVRFd01qSTJNRGxhTURZeApFakFRQmdOVkJBb1RDWFJyWlRwMWMyVnljekVnTUI0R0ExVUVBeE1YTVRBd01ESTVOak13TURZMkxURTNNVEF4Ck1qTTVOamt3Z2dFaU1BMEdDU3FHU0liM0RRRUJBUVVBQTRJQkR3QXdnZ0VLQW9JQkFRREtZTmxhT2VPYXZIa04Kbnp6dEwxeG9UQ2trMzMzY2kzS2k4d1dJc0x4aExNa0c5aDhqbFRacy85SC90dXcyRWVteVJ4UEpiTW4vYXNVLwpzTk85OEh3VXNEdjFNNEtwSThSdTBGeVdUQTgxb21oRnNKQW5vS1Z3NlArL0kxcUFnU21qNTRzM3pzdWJOdTVLCkZISkpmQ1RVd1ByMVEzcVBjdVY0Sy9qbktxYittYlZKUHRmSEk5d1JMcGttUFlpSlZTbmx6SHVhRHk4MVJFalUKbWZGZ3QyZFJ1a1g2ak9oS0NvZmtCVENyclg0cHVhcTlEaitPZ0ovcm4yZmgzZFhDMTJNSjFheW5GVTU2S2pXQwp0eUJkUUJiTi9YVGhlMzlyTm0rKzlmY0djTC9SWVgzZFp5dEhrNUdFMHRCRE9yTGJocHAxeE54YWhzTW92SHZECmplOU8xOEdQQWdNQkFBR2pQekE5TUE0R0ExVWREd0VCL3dRRUF3SUNoREFkQmdOVkhTVUVGakFVQmdnckJnRUYKQlFjREFnWUlLd1lCQlFVSEF3RXdEQVlEVlIwVEFRSC9CQUl3QURBTkJna3Foa2lHOXcwQkFRc0ZBQU9DQVFFQQpjZ0gyMVFtSnhVbSttRUxSbjRlU0dZUHJoUjZxQ3RTMGN4a2k2KzJ2RU1HM1VLbHN1UzlOVStlWWpXYldSK0tiCnV6VWtPdHBCQnJ1bVFIZ1VkTlZlelArNm9JNXJzMzMzTWs3R2w2ZXFLSmIzZWZYV2dEK20rYis1U1lpbmp4amQKcW5SL2JSSGpWdUtESVZjUXErNjJYdG5Bd0dGSVhGTmxjTHVyYXpWcXJTcUlSakY2dUpicHh4WldwTlRDbGp1dQo2blhuRjRKMGxoV21qRkxkVHFMa3hGSm5QTWR2QWdFWXBUSksvWHFiZXJuOE9yRnIvMDBLQUlDT2I4ckJnQk9GClhZL09CT2p2Nnd4ZmhWWXZnaEk1SG8vS3piY3hydytKNGQxTmhBVk8yL1NzR05wZkFhdEl6MGVQM2IrUWE3OE8KSm9uUHRadFA2KzZXUktodU5aSlFEdz09Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K + client-key-data: LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlFcEFJQkFBS0NBUUVBeW1EWldqbmptcng1RFo4ODdTOWNhRXdwSk45OTNJdHlvdk1GaUxDOFlTekpCdllmCkk1VTJiUC9SLzdic05oSHBza2NUeVd6Si8yckZQN0RUdmZCOEZMQTc5VE9DcVNQRWJ0QmNsa3dQTmFKb1JiQ1EKSjZDbGNPai92eU5hZ0lFcG8rZUxOODdMbXpidVNoUnlTWHdrMU1ENjlVTjZqM0xsZUN2NDV5cW0vcG0xU1Q3WAp4eVBjRVM2WkpqMklpVlVwNWN4N21nOHZOVVJJMUpueFlMZG5VYnBGK296b1NncUg1QVV3cTYxK0tibXF2UTQvCmpvQ2Y2NTluNGQzVnd0ZGpDZFdzcHhWT2VpbzFncmNnWFVBV3pmMTA0WHQvYXpadnZ2WDNCbkMvMFdGOTNXY3IKUjVPUmhOTFFRenF5MjRhYWRjVGNXb2JES0x4N3c0M3ZUdGZCandJREFRQUJBb0lCQUI5YkJoSU9xZzhOYUl3Tgp3ZmpWdjdHQksxYkZNZEQ3NGhVUkppaFppYlpjcEFEcUhVVDhGMlNuOWpkeWRnS2luOXk1V24xNDE0czFWYjVhCmZWUU9jSXNjQ3c0Z252dnB5TU9La08zUWR3TE9XTzJEUDdLRUYxMzVHN2JYbVd3VGx3b0lFKy9mb0hnNStJMk4Kd1c5VlJyZVg5c29OWEczaFZXQmJIOE5oUG1KdjA2M2lOLzl3dTlQVE5mbXo3R2VNTW5SSThRb2JUOElucmoxWApjUlA5MFdGUUdQYk1GZ05zUGY0eWN3dFAwTDBNMkRUVkpxaFhWdGNROUVRL3QwQzN1alFGL29nazE3amhqV3NzCnJKUUlJZ0hvOWdQUkNLWGZiaTlEdTJya08xTVM5c05FOWo0Vi9ETllFMkV4a2tkdWhxN2NGZGhGbVFXdWFHZjUKNmptTUpDRUNnWUVBMi9wN2FPd2FRVWk3Vkw1bGhOSFNNNGg3WjltSlNOODM1bklFZHNGRWY2SlcxRkx6ZnNsWQp0NklkWDEyaWd3M2w0Uk50ZERlS1AxQ0RwdnBqd1pRSDFiSnh0ZXBTZ0pRcnRUMW9mVWwrY3p0b0J4TGo1Njg5CmpzZFRwRHliWnlnYzJuK2h2blNPS1AxOHhhWlFTT0xRYlRnUUl4QjBBK29SZHU5dCtpMFFyOGNDZ1lFQTY0U1IKWFpHbkpXSVFmaDRUcWF5QkM5VXdSTHk3Z05qY2EvQ1ZucU8yVmtra2p4UldFNHNHWTI2NGloem9wQ2drSVk4UwpOYVVyVjdpY2dHSGE1NHdSeVF5T202dEhuNFFLSkMzYm9KYXdNUUptQ0dMQ3BJVGJldjVYcmZBMjZRcUhHYlJPCkNOdktBSktGN082VDVvcnJYdCtMd3h6b2FMeDlMb1RteGJKdTcva0NnWUVBaE9xSmpQRTBRQVFoWk9nU1VUbXkKcC82c2lpaFFJbDcxMk9GRnZ6ZXlHdWpOVEVlKzV2bmtDRGtGUkcxQVY2MmJHKzl3TUV1cTFlemhUNUIxbkM3RQp1U08wUDNZUldhMnQ1em51bTkwL2NZTVFyVTJGdGFVV0xlSlVzS1VLUlQ5Z2g4bWN3b2FNcTBuWERWb2JvcDZoCno0eVRlNHhpZlViK1BINFpWcFBLUkZzQ2dZRUFyUnBsNFprUmVpZUdxYnVmaGlGVlJBWXdrUVVLNTV2OC9wVDQKMDMzT29jTG16UWNNY1JiSTNrSmQvcDFhM0hUb2dZWHZ3MkFmNkR5M1FxRXB6UEFsamxqZFpFdFN2RXJIVFdvcgpOL0FwbGd3R1JIbWFTR09pRWRkcFNGMzdiZk9mOHVPVVMyeUlIejJTazkrUzgycjlybUN1RC8xcVVMamhaVlNuCmJYMUZqcmtDZ1lCTXdNSGtVbjQyWnc1ZE5FQW5CRzdJOU1abXI5Y2d2YXhWd3ExRFRMRDRoR3hkY1pDaEhJK0wKbzNFRVFvbDF4NUdUUHVGQ0x0KzJLa1hEQ3hQbThSZWZWVHdPZm1leFJObzdESTlFQk5IaGhabTBrMmdqaURKLworWW1jQ0pUSjRYQ0phT1k4eDhzYlJ6ZVdGUDB1bHRrOEczcGNLWWtFNmRHdUdiTkU4RDNoNUE9PQotLS0tLUVORCBSU0EgUFJJVkFURSBLRVktLS0tLQo= \ No newline at end of file diff --git a/go.mod b/go.mod new file mode 100644 index 0000000..a88254a --- /dev/null +++ b/go.mod @@ -0,0 +1,64 @@ +module git.gz.internal.jumaiyx.cn/job/message-clear + +go 1.20 + +require ( + git.gz.internal.jumaiyx.cn/jm/jmproto v0.0.0-20240624021437-3371166bf601 + git.gz.internal.jumaiyx.cn/pkg/client v0.0.0-20240515061156-c1741246ef08 + git.gz.internal.jumaiyx.cn/pkg/jtime v0.0.0-20240511034446-4ac0f30c3d97 + git.gz.internal.jumaiyx.cn/pkg/k8s-client/v2 v2.0.3-0.20240514094846-93f9e5808a5d + git.gz.internal.jumaiyx.cn/pkg/webhook v0.0.0-20240314063906-8db8467590c4 +) + +require ( + git.gz.internal.jumaiyx.cn/pkg/kubediscovery v0.0.0-20240514095004-cb5816f3b6ee // indirect + git.gz.internal.jumaiyx.cn/proto/game-server v0.0.0-20240423100311-c410de6080d6 // indirect + github.com/davecgh/go-spew v1.1.1 // indirect + github.com/emicklei/go-restful/v3 v3.11.0 // indirect + github.com/go-kratos/aegis v0.2.0 // indirect + github.com/go-kratos/kratos/v2 v2.7.1 // indirect + github.com/go-logr/logr v1.4.1 // indirect + github.com/go-openapi/jsonpointer v0.20.0 // indirect + github.com/go-openapi/jsonreference v0.20.2 // indirect + github.com/go-openapi/swag v0.22.4 // indirect + github.com/go-playground/form/v4 v4.2.1 // indirect + github.com/gogo/protobuf v1.3.2 // indirect + github.com/golang/protobuf v1.5.4 // indirect + github.com/google/gnostic-models v0.6.8 // indirect + github.com/google/gofuzz v1.2.0 // indirect + github.com/google/uuid v1.4.0 // indirect + github.com/gorilla/mux v1.8.0 // indirect + github.com/imdario/mergo v0.3.16 // indirect + github.com/josharian/intern v1.0.0 // indirect + github.com/json-iterator/go v1.1.12 // indirect + github.com/mailru/easyjson v0.7.7 // indirect + github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect + github.com/modern-go/reflect2 v1.0.2 // indirect + github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect + github.com/pkg/errors v0.9.1 // indirect + github.com/spf13/pflag v1.0.5 // indirect + golang.org/x/net v0.23.0 // indirect + golang.org/x/oauth2 v0.13.0 // indirect + golang.org/x/sys v0.18.0 // indirect + golang.org/x/term v0.18.0 // indirect + golang.org/x/text v0.14.0 // indirect + golang.org/x/time v0.3.0 // indirect + google.golang.org/appengine v1.6.8 // indirect + google.golang.org/genproto v0.0.0-20231030173426-d783a09b4405 // indirect + google.golang.org/genproto/googleapis/api v0.0.0-20231030173426-d783a09b4405 // indirect + google.golang.org/genproto/googleapis/rpc v0.0.0-20231030173426-d783a09b4405 // indirect + google.golang.org/grpc v1.59.0 // indirect + google.golang.org/protobuf v1.33.0 // indirect + gopkg.in/inf.v0 v0.9.1 // indirect + gopkg.in/yaml.v2 v2.4.0 // indirect + gopkg.in/yaml.v3 v3.0.1 // indirect + k8s.io/api v0.28.9 // indirect + k8s.io/apimachinery v0.28.9 // indirect + k8s.io/client-go v0.28.9 // indirect + k8s.io/klog/v2 v2.120.1 // indirect + k8s.io/kube-openapi v0.0.0-20240322212309-b815d8309940 // indirect + k8s.io/utils v0.0.0-20240310230437-4693a0247e57 // indirect + sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd // indirect + sigs.k8s.io/structured-merge-diff/v4 v4.4.1 // indirect + sigs.k8s.io/yaml v1.4.0 // indirect +) diff --git a/hotspot-clear-job-dev.yaml b/hotspot-clear-job-dev.yaml new file mode 100644 index 0000000..504e980 --- /dev/null +++ b/hotspot-clear-job-dev.yaml @@ -0,0 +1,22 @@ +apiVersion: batch/v1beta1 +kind: CronJob +metadata: + name: message-clear-job + namespace: dev +spec: +# schedule: "*/5 * * * *" # 10分钟 + schedule: "0 * * * *" # 一小时 + jobTemplate: + spec: + template: + spec: + containers: + - name: message-clear + image: 192.168.1.131:8888/job/dev/message-clear:7d42712db2fa490b8763183fecb1c0e291b80f7a + env: + - name: JM_ENVIRONMENT + value: dev + imagePullPolicy: IfNotPresent + restartPolicy: OnFailure + imagePullSecrets: + - name: local-harbor \ No newline at end of file diff --git a/main.go b/main.go new file mode 100644 index 0000000..c2826f2 --- /dev/null +++ b/main.go @@ -0,0 +1,60 @@ +package main + +import ( + "context" + livev1 "git.gz.internal.jumaiyx.cn/jm/jmproto/live/v1" + "git.gz.internal.jumaiyx.cn/pkg/client" + "git.gz.internal.jumaiyx.cn/pkg/jtime" + k8sclient "git.gz.internal.jumaiyx.cn/pkg/k8s-client/v2" + "git.gz.internal.jumaiyx.cn/pkg/webhook/wechat" + "strconv" + "time" +) + +func main() { + start := time.Now().Unix() + err := task() + times := time.Now().Unix() - start + if times == 0 { + times = 1 + } + wechatHook(times, err) +} + +func task() error { + ctx := context.Background() + liveClient, liveClientClose, err := client.GetLiveClient(ctx) + if err != nil { + return err + } + defer func() { _ = liveClientClose() }() + _, err = liveClient.ClearMessage(ctx, &livev1.ClearMessageReq{ + LtCreateTimes: jtime.SecondsAgoTime(time.Now(), -(86400 * 7)).Unix(), + }) + if err != nil { + return err + } + return nil +} + +func wechatHook(times int64, err error) { + if err == nil { + return + } + + envi := "测试" + if k8sclient.Environment() == k8sclient.MasterNamespace { + envi = "正式" + } + hook := wechat.NewMarkdown("https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=88967358-abc1-4e06-bac6-ec202f18875a"). + Title(1, "聊天记录清除").Br(). + Text("环境:" + envi).Br(). + Text("耗时:" + strconv.Itoa(int(times)) + "s").Br().Text("状态:") + if err != nil { + hook = hook.FontColor("失败", wechat.Warning).Br().Text("异常:").FontColor(err.Error(), wechat.Warning) + } else { + hook = hook.FontColor("完成", wechat.Info) + } + _ = hook.Send() + +}