在Kubenetes上部署单应用Mysql

在Kubenetes上部署单应用Mysql

Kubernetes是开发中一项重大的改进,而数据库是应用程序的重要组成部分。

Kubernetes上的数据库

我们可以将数据库作为有状态应用程序部署到Kubernetes。通常,当我们部署Pod时,它们具有自己的存储空间,但是该存储空间是短暂的-如果容器被杀死了,则其存储空间将随之消失

因此,我们需要有一个Kubernetes资源对象来解决这种情况:当我们想要数据持久化时,我们就把Pod和持久化存储卷声明关联。通过这种方式,如果我们的容器被杀死了,我们的数据仍将位于集群中,新的pod也能够相应地访问数据。

Pod -> PVC-> PV

  • PV =持久性存储
  • PVC =持久性存储声明

在Kubernetes上部署数据库是否可行?

在现如今,已经有许多的大厂公司致力于容器技术。容器技术在给应用上带来了便利。 既然谈到了容器技术免不了需要用到容器的管理部署平台。
这里我们就谈到了Kubenetes(容器管理平台)对数据库进行部署是否可行?

  1. 完全托管数据库
    数据库对外来说无非就是增删改查,对内而已数据库还涉及到了备份、版本拓展补丁、数据库维护任务。如果说我们将数据库托管给云平台,让云平台为我们提供这些运营的服务。这样对于应用而言更加方便省时。

  2. 数据存储
    容器技术虽然编写,但是存储的数据并不像我们原先在主机上部署的安全。在我们将数据写入容器之后,若是哪天容器内部出现错误无法使用后。此时删除或是重启容器会发现容器内的数据已经丢失。此时如果我们使用Kubenetes对Mysql容器进行部署的话,可以为容器提供存储卷(Volume)。这样的话当容器拓展数量或是重启容器的时候便不会出现数据丢失的情况

在Kubernetes上部署有状态应用程序

.

步骤1:部署MySQL服务

apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  selector:
    app: mysql
  type: NodePort
  ports:
  - port: 3306
    nodePort: 30006

首先,我们在端口3306上为MySQL数据库部署服务,所有Pod均具有标签键app: mysql。

接下来,创建以下资源:

Kubectl create -f mysql_service.yaml

步骤2:部署MySQL Deployment

apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
spec:
  selector:
    matchLabels:
      app: mysql
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
      - image: mysql:5.6
        name: mysql
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: "123456"
        ports:
        - containerPort: 3306
          name: mysql
        volumeMounts:
        - name: mysql-storage
          mountPath: /var/lib/mysql
      volumes:
      - name: mysql-storage
        persistentVolumeClaim:
          claimName: mysql-pv-claim

此Deployment在3306端口上创建带有MySQL5.6镜像和密码(使用secret)的Pod。我们还将附加一个持久卷mysql-pv-claim,将在接下来的步骤中进行显示。

创建资源:

Kubectl create -f mysql_deployment.yaml

步骤3:创建持久卷

apiVersion: v1
kind: PersistentVolume
metadata:
  name: mysql-pv-volume
  labels:
    type: local
spec:
  storageClassName: manual
  capacity:
    storage: 20Gi
  accessModes:
  - ReadWriteOnce
  hostPath:
    path: "/root/zookeeper/kerryData"

这将创建一个持久卷,我们将使用它来附加到容器,以确保Pod重启时的数据安全。该持久卷具有ReadWriteOne访问模式,拥有20GB的存储空间,存放路径是/ mnt/data,我们所有的数据都将保存在该路径中。

创建以下资源:

Kubectl create -f persistence_volume.yaml

步骤4:创建持久卷声明

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-pv-claim
spec:
  storageClassName: manual
  accessModes:
  - ReadWriteOnce
  resources:
    requests:
      storage: 20Gi

该声明从上面创建的“持久卷”中声明20GB,并具有与上面的“持久卷”相同的访问模式。

创建以下资源:

Kubectl create -f pvClaim.yaml

查看PVC是否绑定上PV

kubectl get pv,pvc

运行结果:当PVC和PV的STATUS状态显示Bound的时候则说明已经绑定上了
在这里插入图片描述

步骤5:查看最终结果

查询代码:

kubectl get pods,deploy,svc 

运行结果:此时可以看到已经全部运行起来了
在这里插入图片描述

在我们往Pod中存放数据后,我们可以直接通过代码对Pod进行删除,此时Deployment会重新去拉取新的Pod此时我们去访问新的Pod的时候就可以看到原先的数据还存在,并未丢失。

kubectl delete pod mysql-64d97cd569-tkgtn 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kerry_x

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值