<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
MySQL
是一個關係型資料庫管理系統,由瑞典MySQL AB 公司開發,屬於 Oracle 旗下產品。MySQL 是最流行的關係型資料庫管理系統之一,在 WEB 應用方面,MySQL是最好的 RDBMS (Relational Database Management System,關聯式資料庫管理系統) 應用軟體之一。這裡主要講mysql部署在k8s上,mysql部署在k8s上的優勢主要有以下幾點:
官方檔案:docs.oracle.com/en-us/iaas/… MySQL 原理介紹也可以參考我這篇文章:MySQL原理介紹
helm repo add bitnami https://charts.bitnami.com/bitnami helm pull bitnami/mysql tar -xf mysql-9.3.3.tgz
mysql/values.yaml
... image: registry: myharbor.com repository: bigdata/mysql tag: 8.0.30-debian-11-r15 ... architecture: replication ... primary: persistence: enabled: true size: 10Gi storageClass: "mysql-local-storage" # 目錄需要提前在宿主機上建立 local: - name: mysql-0 host: "local-168-182-110" path: "/opt/bigdata/servers/mysql/data/data1" service: type: NodePort nodePorts: mysql: "30306" secondary: replicaCount: 2 persistence: enabled: true size: 10Gi storageClass: "mysql-local-storage" # 目錄需要提前在宿主機上建立 local: - name: mysql-1 host: "local-168-182-111" path: "/opt/bigdata/servers/mysql/data/data1" - name: mysql-2 host: "local-168-182-112" path: "/opt/bigdata/servers/mysql/data/data1" service: type: NodePort nodePorts: mysql: "30307" ... metrics: ## @param metrics.enabled Start a side-car prometheus exporter ## enabled: true image: registry: myharbor.com repository: bigdata/mysqld-exporter tag: 0.14.0-debian-11-r33
mysql/templates/pv.yaml
{{- range .Values.primary.persistence.local }} --- apiVersion: v1 kind: PersistentVolume metadata: name: {{ .name }} labels: name: {{ .name }} spec: storageClassName: {{ $.Values.primary.persistence.storageClass }} capacity: storage: {{ $.Values.primary.persistence.size }} accessModes: - ReadWriteOnce local: path: {{ .path }} nodeAffinity: required: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/hostname operator: In values: - {{ .host }} --- {{- end }} {{- range .Values.secondary.persistence.local }} --- apiVersion: v1 kind: PersistentVolume metadata: name: {{ .name }} labels: name: {{ .name }} spec: storageClassName: {{ $.Values.secondary.persistence.storageClass }} capacity: storage: {{ $.Values.secondary.persistence.size }} accessModes: - ReadWriteOnce local: path: {{ .path }} nodeAffinity: required: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/hostname operator: In values: - {{ .host }} --- {{- end }}
mysql/templates/storage-class.yaml
kind: StorageClass apiVersion: storage.k8s.io/v1 metadata: name: {{ .Values.primary.persistence.storageClass }} provisioner: kubernetes.io/no-provisioner
# 建立持久化目錄 mkdir -p /opt/bigdata/servers/mysql/data/data1 # 先準備好映象 docker pull docker.io/bitnami/mysql:8.0.30-debian-11-r15 docker tag docker.io/bitnami/mysql:8.0.30-debian-11-r15 myharbor.com/bigdata/mysql:8.0.30-debian-11-r15 docker push myharbor.com/bigdata/mysql:8.0.30-debian-11-r15 # mysqld-exporter docker pull docker.io/bitnami/mysqld-exporter:0.14.0-debian-11-r33 docker tag docker.io/bitnami/mysqld-exporter:0.14.0-debian-11-r33 myharbor.com/bigdata/mysqld-exporter:0.14.0-debian-11-r33 docker push myharbor.com/bigdata/mysqld-exporter:0.14.0-debian-11-r33 # 開始安裝 helm install mysql ./mysql -n mysql --create-namespace
NOTES
NAME: mysql LAST DEPLOYED: Mon Sep 19 23:57:18 2022 NAMESPACE: mysql STATUS: deployed REVISION: 1 TEST SUITE: None NOTES: CHART NAME: mysql CHART VERSION: 9.3.3 APP VERSION: 8.0.30 ** Please be patient while the chart is being deployed ** Tip: Watch the deployment status using the command: kubectl get pods -w --namespace mysql Services: echo Primary: mysql-primary.mysql.svc.cluster.local:3306 echo Secondary: mysql-secondary.mysql.svc.cluster.local:3306 Execute the following to get the administrator credentials: echo Username: root MYSQL_ROOT_PASSWORD=$(kubectl get secret --namespace mysql mysql -o jsonpath="{.data.mysql-root-password}" | base64 -d) To connect to your database: 1. Run a pod that you can use as a client: kubectl run mysql-client --rm --tty -i --restart='Never' --image myharbor.com/bigdata/mysql:8.0.30-debian-11-r15 --namespace mysql --env MYSQL_ROOT_PASSWORD=$MYSQL_ROOT_PASSWORD --command -- bash 2. To connect to primary service (read/write): mysql -h mysql-primary.mysql.svc.cluster.local -uroot -p"$MYSQL_ROOT_PASSWORD" 3. To connect to secondary service (read-only): mysql -h mysql-secondary.mysql.svc.cluster.local -uroot -p"$MYSQL_ROOT_PASSWORD" To access the MySQL Prometheus metrics from outside the cluster execute the following commands: kubectl port-forward --namespace mysql svc/mysql-metrics 9104:9104 & curl http://127.0.0.1:9104/metrics
檢視pod狀態
kubectl get pods,svc -n mysql -owide
【溫馨提示】從庫(slave)是唯讀的。就是簡單的讀寫測試,還有就是pod掛了,能否正常拉起等等。這個測試驗證比較簡單。這裡就不一步步的演示了。
Prometheus:
可以通過命令檢視採集資料
kubectl get --raw http://10.244.0.74:9104/metrics kubectl get --raw http://10.244.1.125:9104/metrics kubectl get --raw http://10.244.2.178:9104/metrics
Grafana 賬號:admin
,密碼通過下面命令獲取
kubectl get secret --namespace grafana grafana -o jsonpath="{.data.admin-password}" | base64 --decode ; echo
匯入grafana模板,叢集資源監控:7362
官方模組下載地址:grafana.com/grafana/das…
helm uninstall mysql -n mysql kubectl delete pod -n mysql `kubectl get pod -n mysql |awk 'NR>1{print $1}'` --force kubectl patch ns mysql -p '{"metadata":{"finalizers":null}}' kubectl delete ns mysql --force
這裡只是實現了mysql 的主從,沒有實現高可用,官方目前沒有出mysql ok k8s高可用的實現方案,雖然網上也有高可用的實現方案,但是我們公司沒真正去落地使用,所以不予評價網上的高可用的方案,有興趣的小夥伴可以去試試,其實mysql在巨量資料領域一般只是作為後設資料儲存,主掛了,影響不是很大。目前也在研究mysql on k8s 的高可用實現方案,如果後期有mysql on k8s高可用真正落地到生產環境中使用,到時候再來分享一下。
MySQL on k8s 環境部署就先這裡了,更多關於MySQL k8s 環境部署的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45