云原生初體驗:在K8s上部署Springboot應用

2022-10-02    分類: 網(wǎng)站建設

云原生初體驗:在K8s上部署Springboot應用

你會不會對“云原生”很有興趣,卻不知道從何入手?

本文會在window環(huán)境下,構建一套基于k8s的istio環(huán)境,并且通過skaffold完成鏡像的構建和項目部署到集群環(huán)境。其實對于實驗環(huán)境有限的朋友們,完全可以在某里云上,按量付費搞3臺”突發(fā)性能實例“,玩一晚,也就是杯咖啡錢。

好吧,讓我開始吧!

執(zhí)行流程

整體流程的話,如下圖所示,通過 Skaffold+jib 將開發(fā)的應用打包成鏡像,提交到本地倉庫,并且將應用部署到集群中。k8s中部署2個pod,模擬應用不同的版本,并且配置訪問權重20%:80%。

云原生初體驗:在K8s上部署Springboot應用

環(huán)境選擇

我之前有文章詳細介紹過minikube。本次實驗,開始的時候,我就一直沉溺在使用kind的便捷上,而且直接可以在docker上部署集群,可以說非常方便。但是由于我對K8S的理解并不足夠,導致后面遇到了很多問題,所以,在這里建議新上手的小伙伴,還是使用minikube吧。k3s和RKE都需要多臺虛擬機,礙于機器性能,這種方案暫時不考慮了。

下面表格,對比了minikube、kind、k3s 部署環(huán)境,以及支持情況,方便大家選擇。

@nbsp; minikube kind k3s runtime VM container native supported architectures AMD64 AMD64 AMD64, ARMv7, ARM64 supported container runtimes Docker,CRI-O,containerd,gvisor Docker Docker, containerd startup time initial/following 5:19 / 3:15 2:48 / 1:06 0:15 / 0:15 memory requirements 2GB 8GB (Windows, MacOS) 512 MB requires root? no no yes (rootless is experimental) multi-cluster support yes yes no (can be achieved using containers) multi-node support no yes yes project page https://minikube.sigs.k8s.io/ https://kind.sigs.k8s.io/ https://k3s.io/

[1] 表格引用自:http://jiagoushi.pro/minikube-vs-kind-vs-k3s-what-should-i-use

docker desktop 沒有特殊要求。其他的自己用的順手就好,還是需要特別說一下minikube,別用最新的coredns一直都拉不下來,除非你的魔法,可以完全搞定,否則,還是用阿里編譯的minikube版本吧,別跟自己較勁,別問我為什么...

我用的版本羅列在下面了:

?@nbsp;~@nbsp;istioctl@nbsp;version@nbsp; client@nbsp;version:@nbsp;1.10.2@nbsp; control@nbsp;plane@nbsp;version:@nbsp;1.10.2@nbsp; data@nbsp;plane@nbsp;version:@nbsp;1.10.2@nbsp;(10@nbsp;proxies)@nbsp; @nbsp; ?@nbsp;~@nbsp;minikube@nbsp;version@nbsp; minikube@nbsp;version:@nbsp;v1.18.1@nbsp; commit:@nbsp;511aca80987826051cf1c6527c3da706925f7909@nbsp; @nbsp; ?@nbsp;~@nbsp;skaffold@nbsp;version@nbsp; v1.29.0@nbsp; 環(huán)境搭建 使用minikube創(chuàng)建集群

使用 hyperv 作為引擎 , 內(nèi)存 8192M cup 4核,不能再少了,否則拉不起來 istio。

?@nbsp;~@nbsp;minikube@nbsp;start@nbsp;@nbsp;--image-mirror-country='cn'@nbsp;--registry-mirror=https://hq0igpc0.mirror.aliyuncs.com@nbsp;--vm-driver=@quot;hyperv@quot;@nbsp;--memory=8192@nbsp;--cpus=4@nbsp;--hyperv-virtual-switch=@quot;minikubeSwitch@quot;@nbsp;--image-repository=registry.cn-hangzhou.aliyuncs.com/google_containers@nbsp;

還要在 hyperv里創(chuàng)建一個虛擬路由,這里我構建了一個內(nèi)部網(wǎng)絡,這樣可以通過設置網(wǎng)卡的ip,將內(nèi)部網(wǎng)絡的網(wǎng)段固定下來,否則,每次重啟都會變化ip。

云原生初體驗:在K8s上部署Springboot應用

配置讓內(nèi)部網(wǎng)絡,共享訪問互聯(lián)網(wǎng)。

云原生初體驗:在K8s上部署Springboot應用

啟動成功:

?@nbsp;istio-1.10.2@nbsp;minikube@nbsp;start@nbsp; @nbsp;Microsoft@nbsp;Windows@nbsp;10@nbsp;Pro@nbsp;10.0.19042@nbsp;Build@nbsp;19042@nbsp;上的@nbsp;minikube@nbsp;v1.18.1@nbsp; @nbsp;minikube@nbsp;1.20.0@nbsp;is@nbsp;available!@nbsp;Download@nbsp;it:@nbsp;https://github.com/kubernetes/minikube/releases/tag/v1.20.0@nbsp; @nbsp; @nbsp;根據(jù)現(xiàn)有的配置文件使用@nbsp;hyperv@nbsp;驅動程序@nbsp; @nbsp;Starting@nbsp;control@nbsp;plane@nbsp;node@nbsp;minikube@nbsp;in@nbsp;cluster@nbsp;minikube@nbsp; @nbsp;Restarting@nbsp;existing@nbsp;hyperv@nbsp;VM@nbsp;for@nbsp;@quot;minikube@quot;@nbsp;...@nbsp; @nbsp;正在@nbsp;Docker@nbsp;20.10.3@nbsp;中準備@nbsp;Kubernetes@nbsp;v1.20.2…@nbsp; @nbsp;Verifying@nbsp;Kubernetes@nbsp;components...@nbsp; @nbsp;@nbsp;?@nbsp;Using@nbsp;image@nbsp;registry.cn-hangzhou.aliyuncs.com/google_containers/storage-provisioner:v4@nbsp;(global@nbsp;image@nbsp;repository)@nbsp; @nbsp;@nbsp;?@nbsp;Using@nbsp;image@nbsp;registry.hub.docker.com/kubernetesui/dashboard:v2.1.0@nbsp; @nbsp;@nbsp;?@nbsp;Using@nbsp;image@nbsp;registry.hub.docker.com/kubernetesui/metrics-scraper:v1.0.4@nbsp; @nbsp;@nbsp;?@nbsp;Using@nbsp;image@nbsp;registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server-amd64:v0.2.1@nbsp;(global@nbsp;image@nbsp;repository)@nbsp; @nbsp;Enabled@nbsp;addons:@nbsp;metrics-server,@nbsp;storage-provisioner,@nbsp;dashboard,@nbsp;default-storageclass@nbsp; @nbsp;Done!@nbsp;kubectl@nbsp;is@nbsp;now@nbsp;configured@nbsp;to@nbsp;use@nbsp;@quot;minikube@quot;@nbsp;cluster@nbsp;and@nbsp;@quot;default@quot;@nbsp;namespace@nbsp;by@nbsp;default@nbsp; 部署 istio

創(chuàng)建 istio-system 的命名空間

kubectl@nbsp;create@nbsp;namespace@nbsp;istio-system@nbsp;

安裝 istio

istioctl@nbsp;manifest@nbsp;apply@nbsp;--set@nbsp;profile=demo@nbsp;

安裝完成后,執(zhí)行命令 kubectl get svc -n istio-system

?@nbsp;~@nbsp;kubectl@nbsp;get@nbsp;svc@nbsp;-n@nbsp;istio-system@nbsp; NAME@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;TYPE@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;CLUSTER-IP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;EXTERNAL-IP@nbsp;@nbsp;@nbsp;PORT(S)@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;AGE@nbsp; istio-egressgateway@nbsp;@nbsp;@nbsp;ClusterIP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;10.105.31.73@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;none@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;80/TCP,443/TCP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; istio-ingressgateway@nbsp;@nbsp;@nbsp;LoadBalancer@nbsp;@nbsp;@nbsp;10.103.61.73@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;pending@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;15021:31031/TCP,80:31769/TCP,443:30373/TCP,31400:31833/TCP,15443:32411/TCP@nbsp;@nbsp;@nbsp;8d@nbsp; istiod@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ClusterIP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;10.110.109.205@nbsp;@nbsp;@nbsp;@lt;none@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;15010/TCP,15012/TCP,443/TCP,15014/TCP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; 部署 bookinfo

部署 bookinfo demo 驗證環(huán)境

執(zhí)行命令

kubectl@nbsp;label@nbsp;namespace@nbsp;default@nbsp;istio-injection=enabled@nbsp; @nbsp; kubectl@nbsp;apply@nbsp;-f@nbsp;samples/bookinfo/platform/kube/bookinfo.yaml@nbsp;

等待pod都啟動起來以后,添加bookinfo網(wǎng)絡配置,用于訪問 kubectl apply -f .samplesookinfo etworkingookinfo-gateway.yaml

?@nbsp;istio-1.10.2@nbsp;kubectl@nbsp;apply@nbsp;-f@nbsp;.samplesookinfo etworkingookinfo-gateway.yaml@nbsp; @nbsp; gateway.networking.istio.io/bookinfo-gateway@nbsp;created@nbsp; @nbsp; virtualservice.networking.istio.io/bookinfo@nbsp;created@nbsp;

使用命令查看service : kubectl get services

?@nbsp;~@nbsp;kubectl@nbsp;get@nbsp;services@nbsp; NAME@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;TYPE@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;CLUSTER-IP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;EXTERNAL-IP@nbsp;@nbsp;@nbsp;PORT(S)@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;AGE@nbsp; callme-service@nbsp;@nbsp;@nbsp;NodePort@nbsp;@nbsp;@nbsp;@nbsp;10.106.26.24@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;none@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8080:30101/TCP@nbsp;@nbsp;@nbsp;8d@nbsp; details@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ClusterIP@nbsp;@nbsp;@nbsp;10.110.253.19@nbsp;@nbsp;@nbsp;@lt;none@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;9080/TCP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; kubernetes@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ClusterIP@nbsp;@nbsp;@nbsp;10.96.0.1@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;none@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;443/TCP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; productpage@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ClusterIP@nbsp;@nbsp;@nbsp;10.96.246.175@nbsp;@nbsp;@nbsp;@lt;none@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;9080/TCP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; ratings@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ClusterIP@nbsp;@nbsp;@nbsp;10.99.234.109@nbsp;@nbsp;@nbsp;@lt;none@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;9080/TCP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; reviews@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ClusterIP@nbsp;@nbsp;@nbsp;10.103.177.123@nbsp;@nbsp;@nbsp;@lt;none@gt;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;9080/TCP@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp;

查看pods狀態(tài) kubectl get pods

?@nbsp;~@nbsp;kubectl@nbsp;get@nbsp;pods@nbsp; NAME@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;READY@nbsp;@nbsp;@nbsp;STATUS@nbsp;@nbsp;@nbsp;RESTARTS@nbsp;@nbsp;@nbsp;AGE@nbsp; callme-service-v1-76dd76ddcc-znb62@nbsp;@nbsp;@nbsp;2/2@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;Running@nbsp;@nbsp;@nbsp;0@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;4h59m@nbsp; callme-service-v2-679db76bbc-m4svm@nbsp;@nbsp;@nbsp;2/2@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;Running@nbsp;@nbsp;@nbsp;0@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;4h59m@nbsp; details-v1-79f774bdb9-qk9q8@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;2/2@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;Running@nbsp;@nbsp;@nbsp;8@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; productpage-v1-6b746f74dc-p4xcb@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;2/2@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;Running@nbsp;@nbsp;@nbsp;8@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; ratings-v1-b6994bb9-dlvjm@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;2/2@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;Running@nbsp;@nbsp;@nbsp;8@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; reviews-v1-545db77b95-sgdzq@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;2/2@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;Running@nbsp;@nbsp;@nbsp;8@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; reviews-v2-7bf8c9648f-t6s8z@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;2/2@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;Running@nbsp;@nbsp;@nbsp;8@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp; reviews-v3-84779c7bbc-4p8hv@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;2/2@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;Running@nbsp;@nbsp;@nbsp;8@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;8d@nbsp;

查看集群ip 以及 端口

?@nbsp;~@nbsp;kubectl@nbsp;get@nbsp;po@nbsp;-l@nbsp;istio=ingressgateway@nbsp;-n@nbsp;istio-system@nbsp;-o@nbsp;'jsonpath={.items[0].status.hostIP}'@nbsp; 192.168.137.115@nbsp; @nbsp; @nbsp; @nbsp; ?@nbsp;istio-1.10.2@nbsp;kubectl@nbsp;get@nbsp;svc@nbsp;istio-ingressgateway@nbsp;-n@nbsp;istio-system@nbsp; @nbsp; NAME@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;TYPE@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;CLUSTER-IP@nbsp;@nbsp;@nbsp;EXTERNAL-IP@nbsp;PORT(S)@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;AGE@nbsp; @nbsp; istio-ingressgateway@nbsp;LoadBalancer@nbsp;@nbsp;10.110.228.32@nbsp;@lt;pending@gt;@nbsp;@nbsp;@nbsp;15021:32343/TCP,80:30088/TCP,443:31869/TCP,31400:32308/TCP,15443:32213/TCP@nbsp;3m17s@nbsp;

于是訪問地址: http://192.168.137.115:31769/productpage

云原生初體驗:在K8s上部署Springboot應用

我們 bookinfo 就部署成功了。接下來我們創(chuàng)建應用

構建應用

云原生初體驗:在K8s上部署Springboot應用

構建一個普通的springboot工程,添加編譯插件,這里我們使用了本地的docker倉庫存儲鏡像

@lt;build@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;plugins@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;plugin@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;groupId@gt;org.springframework.boot@lt;/groupId@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;artifactId@gt;spring-boot-maven-plugin@lt;/artifactId@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;executions@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;execution@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;goals@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;goal@gt;build-info@lt;/goal@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;goal@gt;repackage@lt;/goal@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/goals@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/execution@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/executions@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/plugin@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;plugin@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;groupId@gt;com.google.cloud.tools@lt;/groupId@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;artifactId@gt;jib-maven-plugin@lt;/artifactId@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;version@gt;3.1.1@lt;/version@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;configuration@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;to@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;image@gt;127.0.0.1:9001/${project.artifactId}:${project.version}@lt;/image@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;auth@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;username@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;xxx@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/username@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;password@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;xxx@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/password@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/auth@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/to@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;allowInsecureRegistries@gt;true@lt;/allowInsecureRegistries@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/configuration@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/plugin@gt;@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/plugins@gt;@nbsp; @nbsp;@nbsp;@lt;/build@gt;@nbsp;

構建一個簡單的rest,現(xiàn)實一個構建名稱,以及配置的一個版本號

@Autowired@nbsp; BuildProperties@nbsp;buildProperties;@nbsp; @Value(@quot;${VERSION}@quot;)@nbsp; private@nbsp;String@nbsp;version;@nbsp; @nbsp; @GetMapping(@quot;/ping@quot;)@nbsp; public@nbsp;String@nbsp;ping()@nbsp;{@nbsp; @nbsp;@nbsp;@nbsp;LOGGER.info(@quot;Ping:@nbsp;name={},@nbsp;version={}@quot;,@nbsp;buildProperties.getName(),@nbsp;version);@nbsp; @nbsp;@nbsp;@nbsp;return@nbsp;@quot;I'm@nbsp;callme-service@nbsp;@quot;@nbsp;+@nbsp;version;@nbsp; }@nbsp;

創(chuàng)建 skaffold.xml 用于給 skafflod 編譯鏡像,提交集群使用

apiVersion:@nbsp;skaffold/v2alpha1@nbsp; kind:@nbsp;Config@nbsp; build:@nbsp; artifacts:@nbsp; @nbsp;@nbsp;-@nbsp;image:@nbsp;127.0.0.1:9001/callme-service@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;jib:@nbsp;{}@nbsp; tagPolicy:@nbsp; @nbsp;@nbsp;gitCommit:@nbsp;{}@nbsp;

創(chuàng)建k8s的部署描述k8s/deployment.yml,以及service用于訪問

apiVersion:@nbsp;apps/v1@nbsp; kind:@nbsp;Deployment@nbsp; metadata:@nbsp; name:@nbsp;callme-service-v1@nbsp; spec:@nbsp; replicas:@nbsp;1@nbsp; selector:@nbsp; @nbsp;@nbsp;matchLabels:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;app:@nbsp;callme-service@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v1@nbsp; template:@nbsp; @nbsp;@nbsp;metadata:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;labels:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;app:@nbsp;callme-service@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v1@nbsp; @nbsp;@nbsp;spec:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;containers:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;name:@nbsp;callme-service@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;image:@nbsp;127.0.0.1:9001/callme-service@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;imagePullPolicy:@nbsp;IfNotPresent@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ports:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;containerPort:@nbsp;8080@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;env:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;name:@nbsp;VERSION@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;value:@nbsp;@quot;v1@quot;@nbsp; ---@nbsp; apiVersion:@nbsp;apps/v1@nbsp; kind:@nbsp;Deployment@nbsp; metadata:@nbsp; name:@nbsp;callme-service-v2@nbsp; spec:@nbsp; replicas:@nbsp;1@nbsp; selector:@nbsp; @nbsp;@nbsp;matchLabels:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;app:@nbsp;callme-service@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v2@nbsp; template:@nbsp; @nbsp;@nbsp;metadata:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;labels:@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;app:@nbsp;callme-service@nbsp; @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v2@nbsp;

名稱欄目:云原生初體驗:在K8s上部署Springboot應用
網(wǎng)頁網(wǎng)址:http://www.bm7419.com/news21/200571.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站、用戶體驗、虛擬主機、建站公司、品牌網(wǎng)站設計網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設