飞跃高山与大洋的鱼飞跃高山与大洋的鱼
首页
先看
计算机
  • 数学
  • Linux
  • Arch
  • Manjaro
  • Ubuntu
  • CentOS
  • Kubernetes
  • Web
  • JavaScript
  • TypeScript
  • CSS
  • Canvas
  • Vue
  • Vite
  • NuxtJS
  • Webpack
  • Flutter
  • D3
  • Jest
  • WeApp
  • Utils
  • Nodejs
  • Nestjs
  • Golang
  • Nginx
  • Traefik
  • MySQL
  • MongoDB
  • Redis
  • Docker
算法
  • 像素风
  • Git
  • Github
  • VSCode
  • Chrome
  • Google
  • Bookmark scripts
  • 导航 🎉
  • VuePress 侧边栏插件
  • VuePress 官网
🚇 开往
首页
先看
计算机
  • 数学
  • Linux
  • Arch
  • Manjaro
  • Ubuntu
  • CentOS
  • Kubernetes
  • Web
  • JavaScript
  • TypeScript
  • CSS
  • Canvas
  • Vue
  • Vite
  • NuxtJS
  • Webpack
  • Flutter
  • D3
  • Jest
  • WeApp
  • Utils
  • Nodejs
  • Nestjs
  • Golang
  • Nginx
  • Traefik
  • MySQL
  • MongoDB
  • Redis
  • Docker
算法
  • 像素风
  • Git
  • Github
  • VSCode
  • Chrome
  • Google
  • Bookmark scripts
  • 导航 🎉
  • VuePress 侧边栏插件
  • VuePress 官网
🚇 开往
  • KUBERNETES

    • KUBERNETES
    • 重要概念
    • Kubernetes Dashboard
    • kubeadm 部署 k8s 集群
    • Kubernetes 部署 MySQL
      • 准备环境
        • Cluster
        • nfs
      • 安装 mysql
        • 1. pv 和 pvc
        • 2. deployment
      • 执行测试
        • 1. 更新数据库
        • 2. 销毁 node
        • 3. 验证数据一致性

Kubernetes 部署 MySQL

警告

记得在 Node 节点提前准备好 nfs-utils,否则会抛出错误 mount: wrong fs type, bad option, bad superblock。

准备环境

Cluster

10.0.0.140 k8s-master
10.0.0.141 k8s-node1
10.0.0.142 k8s-node2
10.0.0.143 k8s-node3

nfs

在 master 执行:

# nfs
yum install -y rpcbind nfs-utils

# 共享目录
mkdir /nfsdata
# 配置 nfs `vim /etc/exports`
/nfsdata *(insecure,rw,sync,no_root_squash)

# 启动服务
systemctl start rpcbind
systemctl start nfs-server
systemctl enable rpcbind
systemctl enable nfs-server
exportfs -r

# 本地检查
showmount -e

在 node 执行:

# nfs
yum install -y nfs-utils

安装 mysql

准备目录:

mkdir /nfsdata/mysql

1. pv 和 pvc

# mysql-pv-pvc.yaml
apiVersion: v1
kind: PersistentVolume
metadata:
  name: mysql-pv-volume
spec:
  storageClassName: manual
  capacity:
    storage: 1Gi
  accessModes:
    - ReadWriteOnce
  nfs:
    server: 10.0.0.140
    path: "/nfsdata/mysql"
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-pv-claim
spec:
  storageClassName: manual
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 1Gi

2. deployment

# mysql.yaml
apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  ports:
  - port: 3306
  selector:
    app: mysql
  clusterIP: None 
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
spec:
  selector:
    matchLabels:
      app: mysql
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
      - image: mysql:5.6
        name: mysql
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: password
        ports:
        - containerPort: 3306
          name: mysql
        volumeMounts:
        - name: mysql-persistent-storage
          mountPath: /var/lib/mysql
      volumes:
      - name: mysql-persistent-storage
        persistentVolumeClaim:
          claimName: mysql-pv-claim

执行测试

kubectl apply -f mysql-pv-pvc.yaml
kubectl apply -f mysql.yaml

# 检验
kubectl get pod -o wide
NAME                     READY   STATUS    RESTARTS   AGE   IP           NODE        NOMINATED NODE   READINESS GATES
mysql-5456cbb767-kpf4z   1/1     Running   0          32m   10.244.1.8   k8s-node1   <none>           <none>

1. 更新数据库

kubectl run -it --rm --image=mysql:5.6 --restart=Never mysql-client -- mysql -h mysql -ppassword

# 进入数据库后

# 查看数据库列表
show databases;
# 创建 itcource 数据库
create database itcource;
# 使用 itcource
use itcource;
# 创建 user 表
create table user(id int(4));
# 插入用户
insert user values(100);
# 查询
select * from user;

2. 销毁 node

根据上面得到 MySQL 运行在 k8s-node1 的节点上,对该节点模拟宕机。

一段时间后,Kubernetes 将 MySQL 迁移到 k8s-node3 的节点上:

NAME                     READY   STATUS        RESTARTS   AGE   IP            NODE        NOMINATED NODE   READINESS GATES
mysql-5456cbb767-kh29k   1/1     Running       0          27s   10.244.3.13   k8s-node3   <none>           <none>
mysql-5456cbb767-kpf4z   1/1     Terminating   0          42m   10.244.1.8    k8s-node1   <none>           <none>

3. 验证数据一致性

kubectl run -it --rm --image=mysql:5.6 --restart=Never mysql-client -- mysql -h mysql -ppassword

# 进入数据库后

# 查询数据
show databases;
select * from itcource.user;
# 结果
+------+
| id   |
+------+
|  100 |
+------+
编辑文档!
上次更新:
贡献者: shanyuhai123
Prev
kubeadm 部署 k8s 集群