在k8s上部署Springboot
文章目录前言创建ReplicationController(RC)创建RC yaml文件使用kubectl根据yaml创建RC创建Service用户访问创建SVC yaml文件使用kubectl根据yaml创建Service访问Springboot项目的接口前言在教程开始前,大家需要先搭建好k8s集群、Harbor私有仓库和构建自己的Springboot镜像,可以参考以下文章:使用kubea...
文章目录
前言
在教程开始前,大家需要先搭建好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: jenkinsdemo
labels:
name: jenkinsdemo
spec:
replicas: 2
selector:
name: jenkinsdemo
template:
metadata:
labels:
name: jenkinsdemo
spec:
containers:
- name: jenkinsdemo
image: 192.168.108.131/library/jenkins_demo:v1.0.0
imagePullPolicy: IfNotPresent
ports:
- 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: jenkinsdemo
labels:
name: jenkinsdemo
spec:
type: NodePort
ports:
- port: 8080
protocol: TCP
targetPort: 8080
name: http
nodePort: 30000
selector:
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
结果正如我们所看到的。
更多推荐
所有评论(0)