𝑰’𝒎 𝒉𝒉𝒈, 𝑰 𝒂𝒎 𝒂 𝒈𝒓𝒂𝒅𝒖𝒂𝒕𝒆 𝒔𝒕𝒖𝒅𝒆𝒏𝒕 𝒇𝒓𝒐𝒎 𝑵𝒂𝒏𝒋𝒊𝒏𝒈, 𝑪𝒉𝒊𝒏𝒂.
RC(ReplicationController)是Kubernetes系统中的核心概念之一,简单来说,它其实定义了一个期望的场景,即声明某种Pod的副本数量在任意时刻都符合某个预期值,所以RC的定义包括如下几个部分。
◎ Pod期待的副本数量。
◎ 用于筛选目标Pod的Label Selector。
◎ 当Pod的副本数量小于预期数量时,用于创建新Pod的Pod模板(template)。
首先先编排一个关于mysql的RC(ReplicationController)yaml文件。
apiVersion: v1
kind: ReplicationController # 类型是副本控制器
metadata:
name: mysql # RC的名称全局是唯一的,这里name是mysql
spec:
replicas: 1 # 副本数量1
selector: # RC管理 拥有label={app:mysql}这个标签的 pod
app: mysql
template: # template代表下面开始定义一个pod
metadata:
labels:
app: mysql # 这个pod拥有{app:mysql}这样一个标签
spec:
containers: # pod中的容器定义部分
- name: mysql
image: mysql:5.7
ports:
- containerPort: 3306 # 容器监听的端口
env: # 注入容器里面的环境变量
- name: MYSQL_ROOT_PASSWORD
value: "123456"
以上YAML定义文件中
将RC发布到k8s集群里面去
kubectl create -f myweb-rc.yaml
[root@k8s-master ~]# kubectl get pod,rc
NAME READY STATUS RESTARTS AGE
pod/mysql-lbrf7 1/1 Running 0 3h58m
pod/myweb-2ksdd 1/1 Running 0 4h17m
pod/myweb-9h9k7 1/1 Running 0 4h17m
pod/myweb-d25bx 1/1 Running 0 4h17m
pod/myweb-fd9ts 1/1 Running 0 4h17m
pod/myweb-mj2fg 1/1 Running 0 4h17m
NAME DESIRED CURRENT READY AGE
replicationcontroller/mysql 1 1 1 4h26m
replicationcontroller/myweb 5 5 5 4h17m
apiVersion: v1
kind: Service # 类型是service
metadata:
name: mysql # 这个service的全局唯一名称
spec:
ports:
- port: 3306 # service提供服务的端口号
selector:
app: mysql # 把拥有{app:label}这个标签的pod应用到这个服务里面
光有RC是不行的,RC不会提供服务的,需要一个Service。将它应用到集群里面去。
kubectl create -f mysql-svc.yaml
[root@k8s-master ~]# kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 13d
mysql ClusterIP 10.106.208.18 <none> 3306/TCP 4h40m
以发现,MySQL服务被分配了一个值为10.106.208.18的Cluster IP地址。随后,Kubernetes集群中其他新创建的Pod就可以通过Service的Cluster IP+端口号3306来连接和访问它了。但是要注意,外部是无法去访问这个Mysql的,3306只是对其他pod开放的端口号。回忆一下,之前的pod,node架构图就知道了。
通常,Cluster IP是在Service创建后由Kubernetes系统自动分配的,其他Pod无法预先知道某个Service的Cluster IP地址,因此需要一个服务发现机制来找到这个服务。为此,最初时,Kubernetes巧妙地使用了Linux环境变量(Environment Variable)来解决这个问题,后面会详细说明其机制。现在只需知道,根据Service的唯一名称,容器可以从环境变量中获取Service对应的Cluster IP地址和端口,从而发起TCP/IP连接请求。这个地方挺像Nacos里面一样的,只要应用名称就可以自动访问到。不用配置什么具体的ip什么的。
这个tomcat是书里面特定的,所以说我们要先去拉取一下这个镜像,这个镜像是作者已经制定好了的。
docker pull kubeguide/tomcat-app:v1
apiVersion: v1
kind: ReplicationController
metadata:
name: myweb
spec:
replicas: 5
selector:
app: myweb
template:
metadata:
labels:
app: myweb
spec:
containers:
- name: myweb
image: kubeguide/tomcat-app:v1
ports:
- containerPort: 8080
env:
- name: MYSQL_SERVICE_HOST
value: 'mysql'
- name: MYSQL_SERVICE_PORT
value: '3306'
apiVersion: v1
kind: Service
metadata:
name: myweb
spec:
type: NodePort
ports:
- port: 8080
nodePort: 30001 # 对外暴露端口,使得k8s之外的人可以访问到这个服务
selector:
app: myweb
type=NodePort和nodePort=30001的两个属性表明此Service开启了NodePort方式的外网访问模式。在Kubernetes集群之外,比如在本机的浏览器里,可以通过30001这个端口访问myweb(对应到8080的虚端口上)。
http://192.168.88.130:30001/demo/ ip填你的node的地址
K8S权威指南