服务器之家:专注于服务器技术及软件下载分享
分类导航

服务器资讯|IT/互联网|云计算|区块链|软件资讯|操作系统|手机数码|百科知识|免费资源|头条新闻|

服务器之家 - 新闻资讯 - 云计算 - 云原生初体验:在K8s上部署Springboot应用

云原生初体验:在K8s上部署Springboot应用

2021-08-26 21:49麒思妙想dafei1288 云计算

本文会在window环境下,构建一套基于k8s的istio环境,并且通过skaffold完成镜像的构建和项目部署到集群环境。其实对于实验环境有限的朋友们,完全可以在某里云上,按量付费搞3台”突发性能实例“,玩一晚,也就是杯咖啡钱。

云原生初体验:在K8s上部署Springboot应用

你会不会对“云原生”很有兴趣,却不知道从何入手?

本文会在window环境下,构建一套基于k8s的istio环境,并且通过skaffold完成镜像的构建和项目部署到集群环境。其实对于实验环境有限的朋友们,完全可以在某里云上,按量付费搞3台”突发性能实例“,玩一晚,也就是杯咖啡钱。

好吧,让我开始吧!

执行流程

整体流程的话,如下图所示,通过 Skaffold+jib 将开发的应用打包成镜像,提交到本地仓库,并且将应用部署到集群中。k8s中部署2个pod,模拟应用不同的版本,并且配置访问权重20%:80%。

云原生初体验:在K8s上部署Springboot应用

环境选择

我之前有文章详细介绍过minikube。本次实验,开始的时候,我就一直沉溺在使用kind的便捷上,而且直接可以在docker上部署集群,可以说非常方便。但是由于我对K8S的理解并不足够,导致后面遇到了很多问题,所以,在这里建议新上手的小伙伴,还是使用minikube吧。k3s和RKE都需要多台虚拟机,碍于机器性能,这种方案暂时不考虑了。

下面表格,对比了minikube、kind、k3s 部署环境,以及支持情况,方便大家选择。

@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版本吧,别跟自己较劲,别问我为什么...

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

  1. ➜@nbsp;~@nbsp;istioctl@nbsp;version@nbsp;
  2. client@nbsp;version:@nbsp;1.10.2@nbsp;
  3. control@nbsp;plane@nbsp;version:@nbsp;1.10.2@nbsp;
  4. data@nbsp;plane@nbsp;version:@nbsp;1.10.2@nbsp;(10@nbsp;proxies)@nbsp;
  5. @nbsp;
  6. ➜@nbsp;~@nbsp;minikube@nbsp;version@nbsp;
  7. minikube@nbsp;version:@nbsp;v1.18.1@nbsp;
  8. commit:@nbsp;511aca80987826051cf1c6527c3da706925f7909@nbsp;
  9. @nbsp;
  10. ➜@nbsp;~@nbsp;skaffold@nbsp;version@nbsp;
  11. v1.29.0@nbsp;

环境搭建

使用minikube创建集群

使用 hyperv 作为引擎 , 内存 8192M cup 4核,不能再少了,否则拉不起来 istio。

  1. ➜@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里创建一个虚拟路由,这里我构建了一个内部网络,这样可以通过设置网卡的ip,将内部网络的网段固定下来,否则,每次重启都会变化ip。

云原生初体验:在K8s上部署Springboot应用

配置让内部网络,共享访问互联网。

云原生初体验:在K8s上部署Springboot应用

启动成功:

  1. ➜@nbsp;istio-1.10.2@nbsp;minikube@nbsp;start@nbsp;
  2. @nbsp;Microsoft@nbsp;Windows@nbsp;10@nbsp;Pro@nbsp;10.0.19042@nbsp;Build@nbsp;19042@nbsp;上的@nbsp;minikube@nbsp;v1.18.1@nbsp;
  3. @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;
  4. @nbsp;
  5. @nbsp;根据现有的配置文件使用@nbsp;hyperv@nbsp;驱动程序@nbsp;
  6. @nbsp;Starting@nbsp;control@nbsp;plane@nbsp;node@nbsp;minikube@nbsp;in@nbsp;cluster@nbsp;minikube@nbsp;
  7. @nbsp;Restarting@nbsp;existing@nbsp;hyperv@nbsp;VM@nbsp;for@nbsp;@quot;minikube@quot;@nbsp;...@nbsp;
  8. @nbsp;正在@nbsp;Docker@nbsp;20.10.3@nbsp;中准备@nbsp;Kubernetes@nbsp;v1.20.2…@nbsp;
  9. @nbsp;Verifying@nbsp;Kubernetes@nbsp;components...@nbsp;
  10. @nbsp;@nbsp;▪@nbsp;Using@nbsp;image@nbsp;registry.cn-hangzhou.aliyuncs.com/google_containers/storage-provisioner:v4@nbsp;(global@nbsp;image@nbsp;repository)@nbsp;
  11. @nbsp;@nbsp;▪@nbsp;Using@nbsp;image@nbsp;registry.hub.docker.com/kubernetesui/dashboard:v2.1.0@nbsp;
  12. @nbsp;@nbsp;▪@nbsp;Using@nbsp;image@nbsp;registry.hub.docker.com/kubernetesui/metrics-scraper:v1.0.4@nbsp;
  13. @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;
  14. @nbsp;Enabled@nbsp;addons:@nbsp;metrics-server,@nbsp;storage-provisioner,@nbsp;dashboard,@nbsp;default-storageclass@nbsp;
  15. @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

创建 istio-system 的命名空间

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

安装 istio

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

安装完成后,执行命令 kubectl get svc -n istio-system

  1. ➜@nbsp;~@nbsp;kubectl@nbsp;get@nbsp;svc@nbsp;-n@nbsp;istio-system@nbsp;
  2. 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;
  3. 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;
  4. 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;
  5. 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 验证环境

执行命令

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

等待pod都启动起来以后,添加bookinfo网络配置,用于访问 kubectl apply -f .samplesookinfo etworkingookinfo-gateway.yaml

  1. ➜@nbsp;istio-1.10.2@nbsp;kubectl@nbsp;apply@nbsp;-f@nbsp;.samplesookinfo etworkingookinfo-gateway.yaml@nbsp;
  2. @nbsp;
  3. gateway.networking.istio.io/bookinfo-gateway@nbsp;created@nbsp;
  4. @nbsp;
  5. virtualservice.networking.istio.io/bookinfo@nbsp;created@nbsp;

使用命令查看service : kubectl get services

  1. ➜@nbsp;~@nbsp;kubectl@nbsp;get@nbsp;services@nbsp;
  2. 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;
  3. 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;
  4. 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;
  5. 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;
  6. 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;
  7. 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;
  8. 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状态 kubectl get pods

  1. ➜@nbsp;~@nbsp;kubectl@nbsp;get@nbsp;pods@nbsp;
  2. 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;
  3. 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;
  4. 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;
  5. 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;
  6. 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;
  7. 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;
  8. 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;
  9. 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;
  10. 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 以及 端口

  1. ➜@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;
  2. 192.168.137.115@nbsp;
  3. @nbsp;
  4. @nbsp;
  5. @nbsp;
  6. ➜@nbsp;istio-1.10.2@nbsp;kubectl@nbsp;get@nbsp;svc@nbsp;istio-ingressgateway@nbsp;-n@nbsp;istio-system@nbsp;
  7. @nbsp;
  8. 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;
  9. @nbsp;
  10. 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 就部署成功了。接下来我们创建应用

构建应用

云原生初体验:在K8s上部署Springboot应用

构建一个普通的springboot工程,添加编译插件,这里我们使用了本地的docker仓库存储镜像

  1. @lt;build@gt;@nbsp;
  2. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;plugins@gt;@nbsp;
  3. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;plugin@gt;@nbsp;
  4. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;groupId@gt;org.springframework.boot@lt;/groupId@gt;@nbsp;
  5. @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;
  6. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;executions@gt;@nbsp;
  7. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;execution@gt;@nbsp;
  8. @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;
  9. @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;
  10. @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;
  11. @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;
  12. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/execution@gt;@nbsp;
  13. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/executions@gt;@nbsp;
  14. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/plugin@gt;@nbsp;
  15. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;plugin@gt;@nbsp;
  16. @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;
  17. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;artifactId@gt;jib-maven-plugin@lt;/artifactId@gt;@nbsp;
  18. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;version@gt;3.1.1@lt;/version@gt;@nbsp;
  19. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;configuration@gt;@nbsp;
  20. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;to@gt;@nbsp;
  21. @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;
  22. @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;
  23. @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;
  24. @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;
  25. @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;
  26. @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;
  27. @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;
  28. @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;
  29. @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;
  30. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/to@gt;@nbsp;
  31. @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;
  32. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/configuration@gt;@nbsp;
  33. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/plugin@gt;@nbsp;
  34. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@lt;/plugins@gt;@nbsp;
  35. @nbsp;@nbsp;@lt;/build@gt;@nbsp;

构建一个简单的rest,现实一个构建名称,以及配置的一个版本号

  1. @Autowired@nbsp;
  2. BuildProperties@nbsp;buildProperties;@nbsp;
  3. @Value(@quot;${VERSION}@quot;)@nbsp;
  4. private@nbsp;String@nbsp;version;@nbsp;
  5. @nbsp;
  6. @GetMapping(@quot;/ping@quot;)@nbsp;
  7. public@nbsp;String@nbsp;ping()@nbsp;{@nbsp;
  8. @nbsp;@nbsp;@nbsp;LOGGER.info(@quot;Ping:@nbsp;name={},@nbsp;version={}@quot;,@nbsp;buildProperties.getName(),@nbsp;version);@nbsp;
  9. @nbsp;@nbsp;@nbsp;return@nbsp;@quot;I'm@nbsp;callme-service@nbsp;@quot;@nbsp;+@nbsp;version;@nbsp;
  10. }@nbsp;

创建 skaffold.xml 用于给 skafflod 编译镜像,提交集群使用

  1. apiVersion:@nbsp;skaffold/v2alpha1@nbsp;
  2. kind:@nbsp;Config@nbsp;
  3. build:@nbsp;
  4. artifacts:@nbsp;
  5. @nbsp;@nbsp;-@nbsp;image:@nbsp;127.0.0.1:9001/callme-service@nbsp;
  6. @nbsp;@nbsp;@nbsp;@nbsp;jib:@nbsp;{}@nbsp;
  7. tagPolicy:@nbsp;
  8. @nbsp;@nbsp;gitCommit:@nbsp;{}@nbsp;

创建k8s的部署描述k8s/deployment.yml,以及service用于访问

  1. apiVersion:@nbsp;apps/v1@nbsp;
  2. kind:@nbsp;Deployment@nbsp;
  3. metadata:@nbsp;
  4. name:@nbsp;callme-service-v1@nbsp;
  5. spec:@nbsp;
  6. replicas:@nbsp;1@nbsp;
  7. selector:@nbsp;
  8. @nbsp;@nbsp;matchLabels:@nbsp;
  9. @nbsp;@nbsp;@nbsp;@nbsp;app:@nbsp;callme-service@nbsp;
  10. @nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v1@nbsp;
  11. template:@nbsp;
  12. @nbsp;@nbsp;metadata:@nbsp;
  13. @nbsp;@nbsp;@nbsp;@nbsp;labels:@nbsp;
  14. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;app:@nbsp;callme-service@nbsp;
  15. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v1@nbsp;
  16. @nbsp;@nbsp;spec:@nbsp;
  17. @nbsp;@nbsp;@nbsp;@nbsp;containers:@nbsp;
  18. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;name:@nbsp;callme-service@nbsp;
  19. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;image:@nbsp;127.0.0.1:9001/callme-service@nbsp;
  20. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;imagePullPolicy:@nbsp;IfNotPresent@nbsp;
  21. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ports:@nbsp;
  22. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;containerPort:@nbsp;8080@nbsp;
  23. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;env:@nbsp;
  24. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;name:@nbsp;VERSION@nbsp;
  25. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;value:@nbsp;@quot;v1@quot;@nbsp;
  26. ---@nbsp;
  27. apiVersion:@nbsp;apps/v1@nbsp;
  28. kind:@nbsp;Deployment@nbsp;
  29. metadata:@nbsp;
  30. name:@nbsp;callme-service-v2@nbsp;
  31. spec:@nbsp;
  32. replicas:@nbsp;1@nbsp;
  33. selector:@nbsp;
  34. @nbsp;@nbsp;matchLabels:@nbsp;
  35. @nbsp;@nbsp;@nbsp;@nbsp;app:@nbsp;callme-service@nbsp;
  36. @nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v2@nbsp;
  37. template:@nbsp;
  38. @nbsp;@nbsp;metadata:@nbsp;
  39. @nbsp;@nbsp;@nbsp;@nbsp;labels:@nbsp;
  40. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;app:@nbsp;callme-service@nbsp;
  41. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v2@nbsp;
  42. @nbsp;@nbsp;spec:@nbsp;
  43. @nbsp;@nbsp;@nbsp;@nbsp;containers:@nbsp;
  44. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;name:@nbsp;callme-service@nbsp;
  45. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;image:@nbsp;127.0.0.1:9001/callme-service@nbsp;
  46. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;imagePullPolicy:@nbsp;IfNotPresent@nbsp;
  47. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;ports:@nbsp;
  48. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;containerPort:@nbsp;8080@nbsp;
  49. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;env:@nbsp;
  50. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;name:@nbsp;VERSION@nbsp;
  51. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;value:@nbsp;@quot;v2@quot;@nbsp;
  52. ---@nbsp;
  53. apiVersion:@nbsp;v1@nbsp;
  54. kind:@nbsp;Service@nbsp;
  55. metadata:@nbsp;
  56. name:@nbsp;callme-service@nbsp;
  57. labels:@nbsp;
  58. @nbsp;@nbsp;app:@nbsp;callme-service@nbsp;
  59. spec:@nbsp;
  60. type:@nbsp;NodePort@nbsp;
  61. ports:@nbsp;
  62. -@nbsp;port:@nbsp;8080@nbsp;
  63. @nbsp;@nbsp;name:@nbsp;http@nbsp;
  64. @nbsp;@nbsp;nodePort:@nbsp;30101@nbsp;
  65. selector:@nbsp;
  66. @nbsp;@nbsp;app:@nbsp;callme-service@nbsp;

创建 istio描述文件 k8sistio-rules.yaml

  1. apiVersion:@nbsp;networking.istio.io/v1beta1@nbsp;
  2. kind:@nbsp;DestinationRule@nbsp;
  3. metadata:@nbsp;
  4. name:@nbsp;callme-service-destination@nbsp;
  5. spec:@nbsp;
  6. host:@nbsp;callme-service@nbsp;
  7. subsets:@nbsp;
  8. @nbsp;@nbsp;-@nbsp;name:@nbsp;v1@nbsp;
  9. @nbsp;@nbsp;@nbsp;@nbsp;labels:@nbsp;
  10. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v1@nbsp;
  11. @nbsp;@nbsp;-@nbsp;name:@nbsp;v2@nbsp;
  12. @nbsp;@nbsp;@nbsp;@nbsp;labels:@nbsp;
  13. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;version:@nbsp;v2@nbsp;
  14. #@nbsp;trafficPolicy:@nbsp;#@nbsp;---@nbsp;enable@nbsp;for@nbsp;adding@nbsp;circuit@nbsp;breaker@nbsp;into@nbsp;DestinationRule@nbsp;
  15. #@nbsp;@nbsp;@nbsp;connectionPool:@nbsp;
  16. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;http:@nbsp;
  17. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;http1MaxPendingRequests:@nbsp;1@nbsp;
  18. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;maxRequestsPerConnection:@nbsp;1@nbsp;
  19. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;maxRetries:@nbsp;0@nbsp;
  20. #@nbsp;@nbsp;@nbsp;outlierDetection:@nbsp;
  21. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;consecutive5xxErrors:@nbsp;3@nbsp;
  22. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;interval:@nbsp;30s@nbsp;
  23. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;baseEjectionTime:@nbsp;1m@nbsp;
  24. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;maxEjectionPercent:@nbsp;100@nbsp;
  25. ---@nbsp;
  26. apiVersion:@nbsp;networking.istio.io/v1beta1@nbsp;
  27. kind:@nbsp;VirtualService@nbsp;
  28. metadata:@nbsp;
  29. name:@nbsp;callme-service-route@nbsp;
  30. spec:@nbsp;
  31. hosts:@nbsp;
  32. @nbsp;@nbsp;-@nbsp;callme-service@nbsp;
  33. http:@nbsp;
  34. @nbsp;@nbsp;-@nbsp;route:@nbsp;
  35. @nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;destination:@nbsp;
  36. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;host:@nbsp;callme-service@nbsp;
  37. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;subset:@nbsp;v2@nbsp;
  38. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;weight:@nbsp;80@nbsp;
  39. @nbsp;@nbsp;@nbsp;@nbsp;-@nbsp;destination:@nbsp;
  40. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;host:@nbsp;callme-service@nbsp;
  41. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;subset:@nbsp;v1@nbsp;
  42. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;weight:@nbsp;20@nbsp;
  43. @nbsp;@nbsp;@nbsp;@nbsp;retries:@nbsp;
  44. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;attempts:@nbsp;3@nbsp;
  45. @nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;retryOn:@nbsp;gateway-error,connect-failure,refused-stream@nbsp;
  46. @nbsp;@nbsp;@nbsp;@nbsp;timeout:@nbsp;0.5s@nbsp;
  47. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;fault:@nbsp;#@nbsp;---@nbsp;enable@nbsp;for@nbsp;inject@nbsp;fault@nbsp;into@nbsp;the@nbsp;route@nbsp;
  48. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;delay:@nbsp;
  49. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;percentage:@nbsp;
  50. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;value:@nbsp;33@nbsp;
  51. #@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;@nbsp;fixedDelay:@nbsp;3s@nbsp;

运行 skaffold 进行编译,提交镜像,并部署应用 skaffold run --tail

  1. ➜@nbsp;callme-service@nbsp;git:(master)@nbsp;✗@nbsp;skaffold@nbsp;run@nbsp;--tail@nbsp;
  2. Generating@nbsp;tags...@nbsp;
  3. @nbsp;
  4. -@nbsp;127.0.0.1:9001/callme-service@nbsp;-@gt;@nbsp;127.0.0.1:9001/callme-service:e9c731f-dirty@nbsp;
  5. @nbsp;@nbsp;Checking@nbsp;cache...@nbsp;
  6. -@nbsp;127.0.0.1:9001/callme-service:@nbsp;Found@nbsp;Locally@nbsp;
  7. @nbsp;@nbsp;Starting@nbsp;test...@nbsp;
  8. @nbsp;@nbsp;Tags@nbsp;used@nbsp;in@nbsp;deployment:@nbsp;
  9. -@nbsp;127.0.0.1:9001/callme-service@nbsp;-@gt;@nbsp;127.0.0.1:9001/callme-service:60f1bf39367673fd0d30ec1305d8a02cb5a1ed43cf6603e767a98dc0523c65f3@nbsp;
  10. @nbsp;@nbsp;Starting@nbsp;deploy...@nbsp;
  11. -@nbsp;deployment.apps/callme-service-v1@nbsp;configured@nbsp;
  12. -@nbsp;deployment.apps/callme-service-v2@nbsp;configured@nbsp;
  13. -@nbsp;service/callme-service@nbsp;configured@nbsp;
  14. -@nbsp;destinationrule.networking.istio.io/callme-service-destination@nbsp;configured@nbsp;
  15. -@nbsp;virtualservice.networking.istio.io/callme-service-route@nbsp;configured@nbsp;
  16. @nbsp;@nbsp;Waiting@nbsp;for@nbsp;deployments@nbsp;to@nbsp;stabilize...@nbsp;
  17. -@nbsp;deployment/callme-service-v1:@nbsp;waiting@nbsp;for@nbsp;init@nbsp;container@nbsp;istio-init@nbsp;to@nbsp;start@nbsp;
  18. @nbsp;@nbsp;-@nbsp;pod/callme-service-v1-76dd76ddcc-znb62:@nbsp;waiting@nbsp;for@nbsp;init@nbsp;container@nbsp;istio-init@nbsp;to@nbsp;start@nbsp;
  19. -@nbsp;deployment/callme-service-v2:@nbsp;waiting@nbsp;for@nbsp;init@nbsp;container@nbsp;istio-init@nbsp;to@nbsp;start@nbsp;
  20. @nbsp;@nbsp;-@nbsp;pod/callme-service-v2-679db76bbc-m4svm:@nbsp;waiting@nbsp;for@nbsp;init@nbsp;container@nbsp;istio-init@nbsp;to@nbsp;start@nbsp;
  21. -@nbsp;deployment/callme-service-v2@nbsp;is@nbsp;ready.@nbsp;[1/2@nbsp;deployment(s)@nbsp;still@nbsp;pending]@nbsp;
  22. -@nbsp;deployment/callme-service-v1@nbsp;is@nbsp;ready.@nbsp;
  23. @nbsp;@nbsp;Deployments@nbsp;stabilized@nbsp;in@nbsp;45.671@nbsp;seconds@nbsp;

访问查看结果

云原生初体验:在K8s上部署Springboot应用

致此,我们初级的环境搭建基本完成了,对应云原生,感觉懂了一点,好像又没有懂,需要理解的东西还有很多,这个系列也会持续下去,希望大家和我交流,也欢迎关注,转发。

参考链接;

https://piotrminkowski.com/2020/02/14/local-java-development-on-kubernetes/

https://pklinker.medium.com/integrating-a-spring-boot-application-into-an-istio-service-mesh-a55948666fd

https://blog.csdn.net/xixingzhe2/article/details/88537038

https://blog.csdn.net/chenleiking/article/details/86716049

原文地址:https://mp.weixin.qq.com/s/2_Uh7zLlYwlUBDoMTJ97Pw

延伸 · 阅读

精彩推荐