【掌握Kubernetes,轻松部署MySQL数据库】高效、稳定、一步到位

作者:用户MGSC 更新时间:2025-05-29 07:47:47 阅读时间: 2分钟

引言

随着云计算和容器技术的快速发展,Kubernetes(简称K8s)已成为容器编排领域的首选工具。MySQL作为一款广泛使用的关系型数据库,其稳定性和可靠性在众多场景中得到了验证。本文将介绍如何在Kubernetes环境中高效、稳定地部署MySQL数据库,帮助您快速上手并应用。

准备工作

在开始部署之前,请确保您已经:

  1. 安装并配置了Kubernetes集群。
  2. 安装了kubectl命令行工具,用于与Kubernetes集群交互。
  3. 准备了MySQL数据库镜像,例如官方的mysql:8.0镜像。

部署步骤

1. 创建ConfigMap

首先,创建一个ConfigMap来存储MySQL的配置文件。

apiVersion: v1
kind: ConfigMap
metadata:
  name: mysql-config
  namespace: dev
data:
  my.cnf: |
    [client]
    default-character-set=utf8mb4
    [mysql]
    default-character-set=utf8mb4
    [mysqld]
    max_connections=2000
    secure_file_priv=/var/lib/mysql
    sql_mode=STRICT_TRANS_TABLES

2. 创建PersistentVolumeClaim(PVC)

接下来,创建一个PVC来持久化MySQL数据。

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-pvc
  namespace: dev
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 10Gi
  storageClassName: hpe-san
  volumeMode: Filesystem

3. 创建Deployment

创建一个Deployment来部署MySQL应用。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
  namespace: dev
spec:
  replicas: 1
  selector:
    matchLabels:
      app: mysql
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
      - name: mysql
        image: mysql:8.0
        ports:
        - containerPort: 3306
        env:
        - name: MYSQL_ROOT_PASSWORD
          valueFrom:
            secretKeyRef:
              name: mysql-secret
              key: root-password
        volumeMounts:
        - name: mysql-pvc
          mountPath: /var/lib/mysql
      volumes:
      - name: mysql-pvc
        persistentVolumeClaim:
          claimName: mysql-pvc
      - name: mysql-config
        configMap:
          name: mysql-config

4. 创建Service

创建一个Service来暴露MySQL服务的端口。

apiVersion: v1
kind: Service
metadata:
  name: mysql
  namespace: dev
spec:
  selector:
    app: mysql
  ports:
    - protocol: TCP
      port: 3306
      targetPort: 3306
  type: ClusterIP

5. 创建Secret

创建一个Secret来存储MySQL的root密码。

apiVersion: v1
kind: Secret
metadata:
  name: mysql-secret
  namespace: dev
type: Opaque
data:
  root-password: <password_hash>

验证部署

使用以下命令验证MySQL服务的状态:

kubectl get pods -n dev
kubectl get svc -n dev

如果一切正常,您应该能看到一个正在运行的MySQL pod和一个名为mysql的Service。

总结

通过以上步骤,您可以在Kubernetes环境中高效、稳定地部署MySQL数据库。在实际应用中,您可以根据需求调整配置,例如增加副本数、配置持久化存储等。希望本文能帮助您快速上手Kubernetes和MySQL的部署。

大家都在看
发布时间:2024-12-14 01:28
新乡高铁站在新乡东站,即石武铁路客运专线、京港高铁的国家一级客运站。 107国道东京珠高速西金穗大道北约2KM 车站位于河南省新乡市平原路东,107国道(东环路)东侧,京港澳高速公路西侧,车站性质定位为中间站。。
发布时间:2024-10-30 10:05
在生活中,男性朋友偶尔会感觉到睾丸存在不适感,特别是长期穿紧身裤的男性,睾丸长期受到压迫,血液无法流通,会引起睾丸疼痛以及不适,而且睾丸炎以及附睾炎等也会导。
发布时间:2024-11-02 05:53
大家都知道生病的人会有很多奇怪的要求,有的会想要去尝试自己曾经没有做过的事情,有些就是想要吃一些刺激挑剔的食物,像是有的腺肌症患者想要吃榴莲,其实很多时候这。
发布时间:2024-10-30 09:01
痤疮在生活中是很常见的青春期的一种皮肤类的疾病,痤疮通常是发病于人的脸上,引起痤疮发病的原因也是很多的,不过患上痤疮我们一定要重视起来,痤疮的治疗通常是和人。
发布时间:2024-12-14 04:43
1997年10月,铁道部第四工程局南京工程处(以下简称“南京工程处”)获悉南京国武实业有限公司(以下简称“国武公司”)将综合开发江苏溧水县石臼湖,经协商,当月与国武公司签定了一份《工程施工承包协议》和《关于“进场保证金”的协议》南京工程处。
发布时间:2024-11-11 12:01
1、斗山DX260LC挖掘机气门间隙1.2/1.2/0.93(方),发动机型号斗山 DE08TIS,额定功率(Kw/rpm):180/1900最大扭矩(N.m/rpm):78/1400,最小离地间隙(mm )450,最大挖掘半径(mm)1。
发布时间:2024-10-31 06:07
意思就是用强力破坏;使毁掉。读音[cuī huǐ]例句猛烈的炮火摧毁了敌人的前沿阵地。近义捣毁 毁灭 消灭 摧残 破坏 毁坏反义缔造 建造 创建 修建 保护摧毁是什么意思啊摧毁的意思:(1).彻底破坏。《周书·韦孝宽传。
发布时间:2024-11-28 11:39
只要游客拿着退税单,在海关盖章后,游客都可回国退税。只要是在“PREMIER TAX FREE”、“INNOVA TAXFREE”、“WORLDWIDE TAX FREE”、“TAX REFUND SERVICE SRL”等合作的商户购物达。
发布时间:2024-12-09 22:56
好个屁,骗我青春骗我金钱,学历就是扯淡,这学校领导真的不配当中国人,骗了不知道多少人了。
发布时间:2024-10-29 20:35
自吸离心泵的基本构造是由六部分组成的分别是叶轮,泵体,泵轴,轴承,密封环,填料函。1、叶轮是自吸离心泵的核心部分,它转速高出力大,叶轮上的叶片又起到主要作用,叶轮在装配前要通过静平衡实验。叶轮上的内外表面要求光滑,以减少水流的摩擦损失。。