k8s部署MySQL并持久化数据

k8s部署标准化MySQL

转载请注明出处

之前使用k8s部署了MySQL,但数据并没有做持久化,导致重启MySQL数据就丢了。
持久化数据以正常挂pv的方式会导致一直报容器没有常驻进程起不来的错误,使用subpath子目录挂载解决问题
在启用之前要先给用于挂载的本地服务器目录添加权限 chown -R mysql:mysql /path

部分mysql-deployment.yaml

        volumeMounts:
        - mountPath: /etc/mysql/my.cnf
          name: mysql-ini
          subPath: my.cnf
        - mountPath: /var/lib/init.sh
          name: script
          subPath: init.sh
        - mountPath: /data/mysql
          name: mysql-store
          subPath: mysqldata
# 初始化时pv不为空,使用子目录挂载解决这个问题
        command: ['/bin/bash', '-c', '/var/lib/init.sh;/usr/bin/mysqld_safe --user=mysql']
      volumes:
      - configMap:
          defaultMode: 420
          name: mysqlcnf
        name: mysql-ini
      - configMap:
          defaultMode: 511
          name: init
        name: script
      - name: mysql-store
        persistentVolumeClaim:
          claimName: mysql-chart-pvc

init.yaml

apiVersion: v1
data:
  init.sh: |-
    mkdir -p /home/mysql/;
    mkdir -p /data/mysql/data/;
    mkdir -p /data/mysql/log/;
    mkdir -p /data/mysql/run/;
    mkdir -p /data/mysql/tmp/;
    chown -R mysql:mysql /home/mysql;
    chown -R mysql:mysql /data/mysql/;
    /usr/sbin/mysqld --defaults-file=/etc/mysql/my.cnf --initialize-insecure --user=mysql --basedir=/data/mysql --datadir=/data/mysql/data &
kind: ConfigMap
metadata:
  name: init

myconf.yaml

apiVersion: v1
data:
  my.cnf: "[client] 
  port = 3306 
  socket = /data/mysql/tmp/mysql.sock 
  [mysqld]
    port = 3306 
    socket = /data/mysql/tmp/mysql.sock 
    basedir = /data/mysql
    datadir= /data/mysql/data 
    user = mysql
    server-id = 1 
    lc-messages-dir = /usr/share/mysql
    log-error=/data/mysql/log/mysqld.log
    pid-file=/data/mysql/run/mysqld.pid"
kind: ConfigMap
metadata:
  name: mysqlcnf

持久化数据pv

apiVersion: v1
kind: PersistentVolume
metadata:
  name: mysqlnfs
spec:
  accessModes:
  - ReadWriteOnce
  volumeMode: Filesystem
  capacity:
    storage: 10Gi
  persistentVolumeReclaimPolicy: Recycle
  storageClassName: slow
  nfs:
    path: /data/nfs
    server: ip

持久化数据pvc

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-chart-pvc
spec:
  accessModes:
    - ReadWriteOnce
  volumeMode: Filesystem
  resources:
    requests:
      storage: 10Gi
  storageClassName: slow
  volumeMode: Filesystem
  volumeName: mysqlnfs

初次登录mysql没有密码,直接mysql进入数据库
初次初始化mysql密码的语句/usr/bin/mysqladmin -u root password xxxxxx;

后续创建用户和密码需要用初始化的账号密码登录进去创建
create user 'username'@'host' identified by 'password';

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Kubernetes中,持久化存储是一种用于长期保存应用程序数据的机制。通过使用持久化存储,我们可以确保即使在Pod被删除或重启后,数据仍然可以保留下来并可用。 在Kubernetes中,有几种不同的方法可以实现持久化存储。 一种常见的方法是使用PersistentVolume(PV)和PersistentVolumeClaim(PVC)。 PersistentVolume是一种抽象的存储卷,它独立于Pod而存在,并且可以被多个Pod共享。 PersistentVolumeClaim是对PersistentVolume的声明,它允许Pod请求使用一个或多个PersistentVolume。 通过使用StorageClass,我们可以动态地创建PersistentVolume,并将其与PersistentVolumeClaim关联起来,从而自动完成存储的挂载和卸载过程。 另一种常见的方法是使用StatefulSet。StatefulSet是一种可以保证Pods的有序部署和唯一标识的控制器。在StatefulSet中,每个Pod都拥有一个唯一的标识符和稳定的网络标识符,并且可以保留其持久化数据。通过StatefulSet,我们可以轻松地部署和管理需要持久化存储的应用程序,例如MySQL和Redis等数据库。 除了上述方法之外,Kubernetes还支持其他一些存储解决方案,例如使用CSI(Container Storage Interface)插件来动态地挂载和管理存储卷,以及使用云提供商的块存储或文件存储来实现数据持久化。 总之,Kubernetes提供了多种持久化存储的选项,使得我们可以根据应用程序的需求选择合适的方法来保留数据,并确保数据的持久性和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值