本镜像专为配合 https://github.com/mariadb-operator/mariadb-operator 使用而设计,提供在 Kubernetes 环境中部署和管理 MariaDB 数据库的容器化支持。作为 MariaDB Operator 的核心组件之一,该镜像实现了与 Operator 的无缝集成,支持自动化数据库生命周期管理、配置同步及高可用部署,适用于云原生环境下的 MariaDB 集群构建与运维。
kubectl apply 提交配置,Operator 将自动调用本镜像创建数据库实例。kubectl get pods 检查 Pod 状态,通过 kubectl logs 查看日志确认启动正常。4.3.1 环境变量配置
| 环境变量名 | 说明 | 默认值 | 是否必填 |
|---|---|---|---|
MARIADB_ROOT_PASSWORD | MariaDB root 用户密码,需通过 Kubernetes Secret 注入 | 无 | 是 |
MARIADB_DATABASE | 初始化时创建的默认数据库名称 | 无 | 否 |
MARIADB_USER | 初始化时创建的普通用户名(非 root) | 无 | 否 |
MARIADB_PASSWORD | 普通用户对应的密码,需通过 Kubernetes Secret 注入 | 无 | 否 |
MARIADB_CHARSET | 数据库默认字符集 | utf8mb4 | 否 |
MARIADB_COLLATION | 数据库默认排序规则 | utf8mb4_general_ci | 否 |
MARIADB_MAX_CONNECTIONS | 最大连接数限制 | 151 | 否 |
4.3.2 卷挂载配置
| 挂载路径 | 说明 | 推荐配置方式 |
|---|---|---|
/var/lib/mysql | 数据库数据持久化目录 | 使用 PersistentVolumeClaim |
/etc/mysql/conf.d | 自定义配置文件目录(覆盖默认配置) | 通过 ConfigMap 挂载 |
4.4.1 Kubernetes YAML 配置示例(MariaDB CR)
yaml# mariadb-instance.yaml apiVersion: mariadb.mmontes.io/v1alpha1 kind: MariaDB metadata: name: mariadb-example namespace: default spec: replicas: 1 # 单节点;多节点需配置 replication image: <镜像名称>:<版本> # 替换为实际镜像名和版本 imagePullPolicy: IfNotPresent rootPasswordSecretKeyRef: name: mariadb-secrets key: root-password # 从 Secret 中读取 root 密码 database: myappdb # 初始化数据库名称 username: myappuser # 初始化普通用户名 passwordSecretKeyRef: name: mariadb-secrets key: user-password # 从 Secret 中读取普通用户密码 storage: size: 10Gi # 数据存储大小 storageClass: standard # 替换为集群内可用的 StorageClass resources: requests: cpu: 200m memory: 256Mi limits: cpu: 1000m memory: 1Gi livenessProbe: initialDelaySeconds: 30 periodSeconds: 10 readinessProbe: initialDelaySeconds: 5 periodSeconds: 5
创建 Secret(用于存储密码):
yaml# mariadb-secrets.yaml apiVersion: v1 kind: Secret metadata: name: mariadb-secrets namespace: default type: Opaque data: root-password: <base64编码的root密码> # 例如:echo -n "mypassword" | base64 user-password: <base64编码的用户密码>
应用配置:
bashkubectl apply -f mariadb-secrets.yaml kubectl apply -f mariadb-instance.yaml
4.4.2 本地测试(docker-compose 配置)
适用于本地验证镜像功能(非生产环境):
yaml# docker-compose.yml version: '3.8' services: mariadb: image: <镜像名称>:<版本> # 替换为实际镜像名和版本 environment: - MARIADB_ROOT_PASSWORD=rootpass123 - MARIADB_DATABASE=testdb - MARIADB_USER=testuser - MARIADB_PASSWORD=userpass123 ports: - "3306:3306" volumes: - ./mariadb-data:/var/lib/mysql # 本地目录持久化数据 healthcheck: test: ["CMD", "mysqladmin", "ping", "-h", "localhost", "-u root", "-p$MARIADB_ROOT_PASSWORD"] interval: 10s timeout: 5s retries: 5
启动容器:
bashdocker-compose up -d
4.4.3 本地单容器测试(docker run)
bashdocker run -d \ --name mariadb-test \ -p 3306:3306 \ -e MARIADB_ROOT_PASSWORD=rootpass123 \ -e MARIADB_DATABASE=testdb \ -e MARIADB_USER=testuser \ -e MARIADB_PASSWORD=userpass123 \ -v ./mariadb-data:/var/lib/mysql \ <镜像名称>:<版本> # 替换为实际镜像名和版本
resources 中的 CPU/内存限制,避免资源不足导致数据库性能下降或 Pod 被驱逐。kubectl logs <pod-name> 查看具体错误日志。kubectl describe pvc <pvc-name> 排查存储问题。如需进一步支持,可参考 https://github.com/mariadb-operator/mariadb-operator 或提交 Issue 至镜像维护仓库。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务