成都創(chuàng)新互聯(lián)專注于網(wǎng)站建設(shè),為客戶提供成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、成都外貿(mào)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)開發(fā)服務(wù),多年建網(wǎng)站服務(wù)經(jīng)驗(yàn),各類網(wǎng)站都可以開發(fā),成都品牌網(wǎng)站建設(shè),公司官網(wǎng),公司展示網(wǎng)站,網(wǎng)站設(shè)計(jì),建網(wǎng)站費(fèi)用,建網(wǎng)站多少錢,價(jià)格優(yōu)惠,收費(fèi)合理。
一、配置:
環(huán)境:
CentOS7?
VMware
筆者配置了四臺(tái)虛擬機(jī):
K8S-Master節(jié)點(diǎn): 3GB內(nèi)存? ?2核CPU ? 20GB硬盤空間
K8S-node1節(jié)點(diǎn):? 2GB內(nèi)存? ?2核CPU ? 30GB硬盤空間
K8S-node2節(jié)點(diǎn):? 2GB內(nèi)存? ?2核CPU ? 30GB硬盤空間
鏡像倉庫節(jié)點(diǎn):? ? ? 2GB內(nèi)存? ?2核CPU ? 50GB硬盤空間
二、節(jié)點(diǎn)規(guī)劃:
使用三臺(tái)虛擬機(jī)搭建K8S集群,使用一臺(tái)虛擬機(jī)搭建鏡像倉庫。
每臺(tái)虛擬機(jī)配置兩塊網(wǎng)卡,其中一塊為“NAT模式”,用于拉取鏡像等功能。
另外一塊網(wǎng)卡為“僅主機(jī)模式”,用于集群節(jié)點(diǎn)間的通信。歸劃如下:
K8s-master節(jié)點(diǎn):
僅主機(jī)模式:10.10.10.200
NAT模式: ?192.168.200.130
K8S-node1節(jié)點(diǎn):
僅主機(jī)模式:10.10.10.201
NAT模式: ?192.168.200.131
K8S-node2節(jié)點(diǎn):
僅主機(jī)模式:10.10.10.202
NAT模式: ?192.168.200.132
鏡像倉庫節(jié)點(diǎn):
僅主機(jī)模式:10.10.10.101
NAT模式: ?192.168.200.150
三、版本信息
Linux內(nèi)核版本:
Linux version 3.10.0-862.el7.x86_64 (builder@kbuilder.dev.centos.org)
(gcc version 4.8.5 20150623 (Red Hat 4.8.5-28) (GCC) )
#1 SMP Fri Apr 20 16:44:24 UTC 2018
K8s集群版本為1.15.0版本:
四、基于StatefulSet與PV/PVC的MySql持久化存儲(chǔ)實(shí)驗(yàn)
1. 在每個(gè)節(jié)點(diǎn)安裝nfs服務(wù)
在“鏡像倉庫”節(jié)點(diǎn),執(zhí)行以下命令:
yum install -y nfs-common nfs-utils rpcbind
在k8s集群,執(zhí)行以下命令:
yum install -y nfs-utils rpcbind
2. 在“鏡像倉庫”節(jié)點(diǎn)下,配置nfs服務(wù)器
mkdir /nfs_mysql
Chmod?777?/nfs_mysql/
(在測(cè)試環(huán)境中,為了不考慮用戶屬性,暫時(shí)賦予777權(quán)限,但在生產(chǎn)環(huán)境不推薦這樣做)
Chown?nfsnobody?/nfs_mysql/
echo “/nfs_mysql *(rw,no_root_squash,no_all_squash,sync)”? /etc/exports
cat /etc/exports
/nfs_mysql?*(rw,no_root_squash,no_all_squash,sync)
systemctl start rpcbind
systemctl start nfs
3. 測(cè)試nfs服務(wù)是否可用
mkdir /test
showmount -e 10.10.10.101
可見/nfs_mysql *已暴露于共享目錄,接下來測(cè)試掛載是否可用:
在master節(jié)點(diǎn)下執(zhí)行:
mount -t nfs 10.10.10.101:/nfs_mysql /test/
echo "hello-world"/test/1.txt
在鏡像倉庫節(jié)點(diǎn)下查看1.txt是否存在,若存在則掛載成功:
可見nfs服務(wù)可以正常使用,接下來刪除test目錄和1.txt
在鏡像倉庫下:
[root@hub nfs_mysql]# rm -f 1.txt
在Master節(jié)點(diǎn)下:
[root@k8s-master ~]# umount /test/
[root@k8s-master ~]# rm -rf /test/
同理,依照以上步驟同時(shí)創(chuàng)建:(提供多個(gè)mysql副本進(jìn)行掛載)
nfs_mysql1
nfs_mysql2
完成后需要重啟nfs服務(wù)
systemctl restart rpcbind
systemctl restart nfs
最終效果:
4. 將nfs封裝成pv
創(chuàng)建mysql_test文件夾,將yaml文件統(tǒng)一保存在此目錄下
mkdir mysql_test
cd mysql_test
vim mysql-pv.yml
mysql-pv.yml配置如下:
apiVersion: v1
kind: PersistentVolume
metadata:
name: mysql-pv
spec:
capacity:
storage: 5Gi
accessModes:
- ?ReadWriteOnce
persistentVolumeReclaimPolicy: Retain
storageClassName: nfs
nfs:
path: /nfs_mysql
server: 10.10.10.101
---
apiVersion: v1
kind: PersistentVolume
metadata:
name: mysql-pv1
spec:
capacity:
storage: 5Gi
accessModes:
- ?ReadWriteOnce
persistentVolumeReclaimPolicy: Retain
storageClassName: nfs
nfs:
path: /nfs_mysql1
server: 10.10.10.101
---
apiVersion: v1
kind: PersistentVolume
metadata:
name: mysql-pv2
spec:
capacity:
storage: 5Gi
accessModes:
- ?ReadWriteOnce
persistentVolumeReclaimPolicy: Retain
storageClassName: nfs
nfs:
path: /nfs_mysql2
server: 10.10.10.101
注意:
在k8s集群15版本中recycle回收策略已被刪除,只能用retain策略或者Delete策略。這里我們使用 persistentVolumeReclaimPolicy: Retain
執(zhí)行命令:
kubectl create -f mysql-pv.yml
kubectl get pv
如圖所示,即為Pv創(chuàng)建成功。
5. 部署MySQL,在mysql_test目錄下編寫mysql.yml,配置文件如下
apiVersion: v1
kind: Service
metadata:
name: mysql
labels:
app: mysql
spec:
ports:
- port: 3306
name: mysql
clusterIP: None
selector:
app: mysql
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: mysql
spec:
selector:
matchLabels:
app: mysql
serviceName: "mysql"
replicas: 3
template:
metadata:
labels:
app: mysql
spec:
containers:
- name: mysql
image: mysql:5.6
env:
- name: MYSQL_ROOT_PASSWORD
value: password
ports:
- containerPort: 3306
name: mysql
volumeMounts:
- name: mysql-persistent-storage
mountPath: /var/lib/mysql
volumeClaimTemplates:
- metadata:
name: mysql-persistent-storage
spec:
accessModes: ["ReadWriteOnce"]
storageClassName: "nfs"
resources:
requests:
storage: 1Gi ?
執(zhí)行以下命令,部署mysql服務(wù):
kubectl create -f mysql.yml
如圖可知,mysql按StatefulSet依次創(chuàng)建了mysql-0 mysql-1 mysql-2
查看各個(gè)Pod部在哪個(gè)節(jié)點(diǎn):
6. 通過創(chuàng)建臨時(shí)容器,使用MySQL客戶端發(fā)送測(cè)試請(qǐng)求給MySQL master節(jié)點(diǎn)
注意:
主機(jī)名為mysql-0.mysql;跨命名空間的話,主機(jī)名請(qǐng)使用mysql-0.mysql. [NAMESPACE_NAME].如果沒有指定命名空間,默認(rèn)為default,即 mysql-0.mysql. default。
這里筆者打算關(guān)閉node2節(jié)點(diǎn)來模擬node2宕機(jī),來測(cè)試是否實(shí)現(xiàn)數(shù)據(jù)的持久化存儲(chǔ),
所以我們向node2上的mysql1寫入數(shù)據(jù)。
執(zhí)行以下命令,訪問mysql1:
kubectl run mysql-client --image=mysql:5.6 -it --rm --restart=Never -- mysql -h mysql-1.mysql.default -p?password
創(chuàng)建數(shù)據(jù)庫demo,并向messages表中寫入hello-world
CREATE DATABASE demo;?
CREATE TABLE demo.messages (message VARCHAR(250));?
INSERT INTO demo.messages VALUES ('hello-world');
如圖所示
接下來我們來關(guān)閉k8s-node2虛擬機(jī),模擬宕機(jī)
查看nodes的運(yùn)行狀態(tài),可知node2的狀態(tài)已轉(zhuǎn)變?yōu)镹otReady
一段時(shí)間后,k8s將Pod MySql -1遷移到節(jié)點(diǎn)k8s-node1
由于時(shí)間過長(zhǎng),筆者把三個(gè)Pod都刪除重啟后,驗(yàn)證數(shù)據(jù):
MySQL服務(wù)恢復(fù),數(shù)據(jù)完好無損!
MySQL 8.0 以前 auto_increment 無法持久化,MySQL 8.0支持 auto_increment 持久化。文檔鏈接:
MySQL5.7 重啟后 auto_increment 會(huì)重置成 max(id)+1。
pt-archiver 加了個(gè)邏輯:選擇不歸檔(刪除) max(id) 這一行數(shù)據(jù),防止重啟丟失 auto_increment 值。這個(gè)行為由 --safe-auto-increment 參數(shù)控制(默認(rèn))。如果要關(guān)閉這一邏輯,可以使用 --nosafe-auto-increment參數(shù)。這一度被認(rèn)為是個(gè) bug。
1、原子性:在整個(gè)操作的事務(wù)中,要么全部成功,要么全部失敗。
2、隔離性:所謂隔離性,就是每個(gè)事務(wù)執(zhí)行的時(shí)候,相互之間不會(huì)受到影響,都是單獨(dú)的事務(wù)。
3、一致性:也就是說事務(wù)在執(zhí)行之后,必須和之前的數(shù)據(jù)保持一致。
4、持久性:事務(wù)一旦提交,就會(huì)持久化到數(shù)據(jù)庫中,不能回滾。