IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> k8s部署MySQL并持久化数据 -> 正文阅读

[系统运维]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';

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-03-10 23:03:01  更:2022-03-10 23:05:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/16 3:44:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码