K8s部署發(fā)布Golang應(yīng)用程序的實(shí)現(xiàn)方法
alertGo程序可以參考上篇文章,主要用于alertmanager實(shí)現(xiàn)釘釘報(bào)警
創(chuàng)建dockerfile
FROM golang:1.14-alpine ENV GOPROXY=https://goproxy.cn WORKDIR /build COPY . . EXPOSE 8088 RUN mkdir /app RUN go mod tidy RUN go build -o /app/alertGo alertGo.go WORKDIR /app CMD ["/app/alertGo"]
打包并且推送
docker build -t 10.206.16.4/k8s-go/alert.sentsss.com:v2 . docker push 10.206.16.4/k8s-go/alert.sentsss.com:v2
創(chuàng)建namespace
apiVersion: v1 kind: Namespace metadata: name: k8s-go
創(chuàng)建deployment
apiVersion: apps/v1
kind: Deployment
metadata:
name: alertgo
namespace: k8s-go
spec:
selector:
matchLabels:
app: alertgo
replicas: 2
template:
metadata:
labels:
app: alertgo
spec:
imagePullSecrets:
- name: registry-pull-secret
containers:
- name: alertgo
image: 10.206.16.4/k8s-go/alert.sentsss.com:v2
ports:
- containerPort: 8088
livenessProbe:
httpGet:
path: /
port: 8088
initialDelaySeconds: 30
periodSeconds: 10
successThreshold: 1
failureThreshold: 3
timeoutSeconds: 1
readinessProbe:
httpGet:
path: /
port: 8088
initialDelaySeconds: 30
periodSeconds: 10
successThreshold: 1
failureThreshold: 3
timeoutSeconds: 1
lifecycle:
preStop:
exec:
command: ["/bin/bash","-c","sleep 20"]
resources:
limits:
cpu: 20m
memory: 20Mi
requests:
cpu: 10m
memory: 10Mi
創(chuàng)建service
apiVersion: v1
kind: Service
metadata:
name: alertgo
namespace: k8s-go
spec:
selector:
app: alertgo
ports:
- port: 80
targetPort: 8088
創(chuàng)建ingress
kind: Ingress # 對(duì)象類(lèi)型
apiVersion: networking.k8s.io/v1beta1
metadata:
name: alertgo
namespace: k8s-go
spec:
rules:
- host: alertgo.xxx.com
http:
paths:
- path: /
backend:
serviceName: alertgo
servicePort: 80
創(chuàng)建hpa
kind: HorizontalPodAutoscaler # 對(duì)象類(lèi)型,簡(jiǎn)稱(chēng) hpa,水平自動(dòng)伸縮
apiVersion: autoscaling/v2beta2 # autoscaling/v2beta2 與 autoscaling/v1 的 API 有很大的不同,注意識(shí)別兩者的差異
metadata:
name: alertgo
namespace: fronted
spec:
scaleTargetRef: # 伸縮的目標(biāo)對(duì)象
apiVersion: apps/v1 # 對(duì)象版本
kind: Deployment # 目標(biāo)對(duì)象的類(lèi)型
name: alertgo # 目標(biāo)對(duì)象的名稱(chēng)
minReplicas: 3 # 最小副本數(shù)
maxReplicas: 6 # 最大副本數(shù)
metrics: # 指標(biāo)
- type: Resource # 類(lèi)型:資源
resource:
name: memory # 內(nèi)存
target:
type: Utilization
averageUtilization: 70 # 1% 這個(gè)值是為了實(shí)驗(yàn),具體值請(qǐng)參考業(yè)務(wù)方實(shí)際情況而定
- type: Resource
resource:
name: cpu
target:
type: Utilization
averageUtilization: 70
結(jié)果查看
[root@k8s-master-01 alertGo]# kubectl get pods,svc,ingress,hpa -n k8s-go
NAME READY STATUS RESTARTS AGE
pod/alertgo-5bc79ccd65-8thmw 1/1 Running 0 37m
pod/alertgo-5bc79ccd65-dm8ll 1/1 Running 0 38m
pod/alertgo-5bc79ccd65-m9cd4 0/1 ContainerCreating 0 0sNAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/alertgo ClusterIP 10.1.140.126 <none> 80/TCP 65mNAME HOSTS ADDRESS PORTS AGE
ingress.extensions/alertgo alertgo.sentsss.com 80 34mNAME REFERENCE TARGETS MINPODS MAXPODS REPLICAS AGE
horizontalpodautoscaler.autoscaling/alertgo Deployment/alertgo 79%/70%, 10%/70% 2 6 2 15s
到此這篇關(guān)于K8s部署發(fā)布Golang應(yīng)用程序的實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)K8s部署發(fā)布Golang內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解如何使用Golang實(shí)現(xiàn)Cron定時(shí)任務(wù)
定時(shí)任務(wù)是許多應(yīng)用程序中常見(jiàn)的一種需求,它們可以用于執(zhí)行定期的清理任務(wù),發(fā)送通知,生成報(bào)告等,在這篇博客中,我們將介紹如何在Go語(yǔ)言中使用robfig/cron包來(lái)實(shí)現(xiàn)Cron定時(shí)任務(wù),需要的朋友可以參考下2024-04-04
go?sync?Waitgroup數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)基本操作詳解
這篇文章主要為大家介紹了go?sync?Waitgroup數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)基本操作詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
淺談golang package中init方法的多處定義及運(yùn)行順序問(wèn)題
這篇文章主要介紹了淺談golang package中init方法的多處定義及運(yùn)行順序問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-05-05
go語(yǔ)言中數(shù)據(jù)接口set集合的實(shí)現(xiàn)
set集合是一種常見(jiàn)的數(shù)據(jù)結(jié)構(gòu),它代表了一個(gè)唯一元素的集合,本文主要介紹了set的基本特性,包括唯一性、無(wú)序性、可變性和集合運(yùn)算,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-10-10
go mutex互斥鎖使用Lock和Unlock方法占有釋放資源
Go號(hào)稱(chēng)是為了高并發(fā)而生的,在高并發(fā)場(chǎng)景下,勢(shì)必會(huì)涉及到對(duì)公共資源的競(jìng)爭(zhēng),當(dāng)對(duì)應(yīng)場(chǎng)景發(fā)生時(shí),我們經(jīng)常會(huì)使用 mutex 的 Lock() 和 Unlock() 方法來(lái)占有或釋放資源,雖然調(diào)用簡(jiǎn)單,但 mutex 的內(nèi)部卻涉及挺多的,本文來(lái)好好研究一下2023-09-09
利用Go語(yǔ)言初步搭建一個(gè)web應(yīng)用的教程
這篇文章主要介紹了利用Go語(yǔ)言初步搭建一個(gè)web應(yīng)用的教程,由于很多國(guó)人盲目迷信谷歌,導(dǎo)致Go語(yǔ)言在國(guó)內(nèi)的人氣遠(yuǎn)超國(guó)外...需要的朋友可以參考下2015-06-06
Go語(yǔ)言實(shí)現(xiàn)猜數(shù)字小游戲
這篇文章主要為大家詳細(xì)介紹了Go語(yǔ)言實(shí)現(xiàn)猜數(shù)字小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10

