Kubernetes实践--hello world 示例

本文所说的Hello world是一个web留言板应用,而且是基于PHP+Redis的两层分布式架构的web应用,前端PHP web网站经过访问后端Redis数据库完成用户留言的查询和添加功能,具有读写分离能力,留言板内容是从redis中查询到的,首页中添加刘潭并提交以后留言会被添加到redis中。php

Redis层采用一个Master与两个salve,Master负责写操做,slave负责读操做,PHPweb层启动三个实例组成集群,对网站的访问进行负载均衡。 
本文的例子首选须要将Docker环境和k8s环境搭建完毕,这个在前一节中已经作了讲解,有须要的能够参考前一节内容部署一下Docker和k8s环境。 
实验环境: Centos7.2 64位,虚拟机。 
下面进行实例的具体操做。前端

1. 建立redis-master Pod和服务

先定义RC来建立pod,而后定义与之关联的service。 
为redis-master服务新建一个名为redis-master-controller.yaml的RC定义文件,内容为:node

apiVersion: v1
kind: ReplicationController
metadata:
  name: redis-master
  labels:
    name: redis-master
spec:
  replicas: 1
  selector:
    name: redis-master
  template:
    metadata:
     labels:
       name: redis-master
    spec:
      containers:
      - name: master
        image: kubeguide/redis-master
        ports:
        - containerPort: 6379

新建好文件以后执行以下命令:mysql

kuberctl create -f redis-master-controller.yaml

删除:将create换为delete便可。 
查看刚刚新建的redis-master:web

kuberctl get rc

检查pod信息:redis

kuberctl get pods

解决kubectl get pods时 No resources found.问题

  1. 使用yum直接安装etcd, kubectl,按顺序启动以下服务:etcd, docker, kube-apiserver, kube-controller-manager, kube-scheduler, kubelet, kube-proxy.
  2. 建立了mysql-rc.yaml.
  3. 执行kubectl create -f mysql-rc.yaml,反馈正常
  4. 执行kubectl get rc, 反馈正常
  5. 执行kubectl get pods,显示no resources found.
  6. 解决方法:
  7. 一、$ vi /etc/kubernetes/apiserver
  8. 二、找到这一行 "KUBE_ADMISSION_CONTROL="--admission_control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ServiceAccount,ResourceQuota",去掉ServiceAccount,保存退出。
  9. 三、从新启动kube-apiserver服务便可
  10. 此时执行kubectl get pods, no resources found问题得以解决

 

下面新建与上面建的pod相关联的service,service对应的文件redis-master-service.yaml,内容以下:sql

apiVersion: v1
kind: Service
metadata:
  name: redis-master
  labels:
    name: redis-master
spec:
  ports:
  - port: 6379
    targetPort: 6379
  selector:
    name: redis-master

建立service:docker

kubectl create -f redis-master-service.yaml

查看新建的service:数据库

kubectl get services

2. redis-salve Pod和服务

步骤和redis-master的同样。 
新建文件redis-salve-controller.yaml,内容以下:后端

apiVersion: v1
kind: ReplicationController
metadata:
  name: redis-slave
  labels:
    name: redis-slave
spec:
  replicas: 2
  selector:
    name: redis-slave
  template:
    metadata:
     labels:
       name: redis-slave
    spec:
      containers:
      - name: slave
        image: kubeguide/guestbook-redis-slave
        env:
        - name: GET_HOSTS_FROM
          value: env
        ports:
        - containerPort: 6379

运行kubectl create命令:

kubectl create -f redis-salve-controller.yaml

查看RC:

kubectl get rc

查看pod:

kubectl get pods

配置文件redis-salve-service.yaml内容以下:

apiVersion: v1
kind: Service
metadata:
  name: redis-slave
  labels:
    name: redis-slave
spec:
  ports:
  - port: 6379
  selector:
    name: redis-slave

建立service:

kubectl create -f redis-slave-service.yaml

检查service:

kubectl get services;

3. 建立frontend Pod和服务

文件frontend-controller.yaml内容以下:

apiVersion: v1
kind: ReplicationController
metadata:
  name: frontend
  labels:
    name: frontend
spec:
  replicas: 3
  selector:
    name: frontend
  template:
    metadata:
     labels:
       name: frontend
    spec:
      containers:
      - name: frontend
        image: kubeguide/guestbook-php-frontend
        env:
        - name: GET_HOSTS_FROM
          value: env
        ports:
        - containerPort: 80

执行命令kubectl create:

kubectl create -f frontend-controller.yaml

检查RC:

kunectl get rc

检查pod:

kubectl get pods

文件frontend-service.yaml内容以下:

apiVersion: v1
kind: Service
metadata:
  name: frontend
  labels:
    name: frontend
spec:
  type: NodePort
  ports:
  - port: 80
    nodePort: 30001
  selector:
    name: frontend

建立服务:

kubectl create -f frontend-service.yaml

检查service:

kubectl get services;

4. 访问网站

如个人虚拟机IP为xx.xx.xx.xx则浏览器访问: xx.xx.xx.xx:30001 成功的话会出现简单的留言板界面,并可进行留言commit。

相关文章
相关标签/搜索