前言

在教程开始前,大家需要先搭建好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,libraryharobr里面的项目名,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

在这里插入图片描述
结果正如我们所看到的。

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐