作者:小伟 | 来源:互联网 | 2023-09-10 11:41
文章目录
- 前言
- 创建ReplicationController(RC)
- 创建RC yaml文件
- 使用kubectl根据yaml创建RC
- 创建Service用户访问
- 创建SVC yaml文件
- 使用kubectl根据yaml创建Service
- 访问Springboot项目的接口
前言
在教程开始前,大家需要先搭建好k8s集群、Harbor私有仓库和构建自己的Springboot镜像,可以参考以下文章:
使用kubeadm搭建(kubernetes)k8s集群
Harbor 安装
Dockerfile构建springboot Image
创建ReplicationController(RC)
创建RC yaml文件
首先需要先创建RC的yaml文件,本教程使用的镜像来源于文章《Dockerfile构建springboot Image》,yaml文件命名为:jenkins_demo_rc.yaml
apiVersion: v1
kind: ReplicationController
metadata:name: jenkinsdemolabels:name: jenkinsdemo
spec:replicas: 2selector:name: jenkinsdemotemplate:metadata:labels:name: jenkinsdemospec:containers:- name: jenkinsdemoimage: 192.168.108.131/library/jenkins_demo:v1.0.0imagePullPolicy: IfNotPresentports:- containerPort: 8080
里面的name
为自己自定义app名字,用作后面Service引用,image
为自己在harbor仓库的位置,192.168.108.131
是harbor的ip,library
harobr里面的项目名,jenkins_demo
是image的名称,v1.0.0
为当前image的版本号。replicas: 2
的意思是,创建2个pod。容器端口8080,说的是pod暴露出来的端口。
使用kubectl根据yaml创建RC
使用kubectl apply
kubectl apply -f jenkins_demo_rc.yaml
在使用get pods查看是否构建成功,如下图:
kubectl get pods
创建Service用户访问
创建SVC yaml文件
apiVersion: v1
kind: Service
metadata:name: jenkinsdemolabels:name: jenkinsdemo
spec:type: NodePortports:- port: 8080protocol: TCPtargetPort: 8080name: httpnodePort: 30000selector:name: jenkinsdemo
其中kind
指定为Service,name
都是用上面RC的那么,特别是selector
里面的name
一定要和RC里面的一样。ports
里面指定node ports也就是k8s里面服务器节点的端口30000映射到pod里面的8080端口,也就是我们可以通过访问k8s主机的30000端口来访问这个springboot项目。
使用kubectl根据yaml创建Service
使用kubectl apply:
kubectl apply -f jenkins_demo_svc.yaml
使用kubectl get services查看创建情况
kubectl get services
访问Springboot项目的接口
curl 192.168.108.136:30000/testMethod
其中192.168.108.136
是我的k8s Master的ip,/testMethod
是Springboot项目里面的一个接口,返回的结果包括:响应pod的ip。
我们可以通过kubectl get来获取pod详细信息来校验时候上面响应的pod的ip是否为k8s里面的。
kubectl get pods -o wide
结果正如我们所看到的。