vitess/mysqlctldvitess/mysqlctld是Vitess开源分布式MySQL集群系统的官方组件镜像,专注于MySQL实例的生命周期管理。Vitess旨在提供MySQL的水平扩展能力、高可用性及简化的集群管理,而mysqlctld作为核心组件,承担着协调MySQL实例与Vitess集群的关键职责,确保MySQL节点按集群要求运行。
bashdocker run -d \ --name=vitess-mysqlctld \ --network=vitess-cluster-net \ -v /host/path/mysql-data:/var/lib/mysql \ -v /host/path/vitess-config:/etc/vitess \ -e MYSQL_PORT=3306 \ -e TOPOLOGY_FLAGS="--topo_implementation=etcd2 --topo_global_server_address=etcd-node:2379" \ -e LOG_LEVEL=info \ vitess/mysqlctld:latest
| 参数/环境变量 | 描述 | 默认值 |
|---|---|---|
--network | 连接至Vitess集群专用网络 | - |
-v /var/lib/mysql | 挂载MySQL数据持久化目录 | 容器内临时目录(不推荐) |
-v /etc/vitess | 挂载Vitess配置文件目录 | 内置默认配置 |
MYSQL_PORT | MySQL实例监听端口 | 3306 |
TOPOLOGY_FLAGS | 拓扑服务连接参数(含实现类型与地址) | --topo_implementation=etcd2 |
LOG_LEVEL | 日志输出级别(debug/info/warn/error) | info |
mysqlctld支持通过挂载配置文件自定义行为,核心配置路径:
/etc/vitess/mysqlctld.conf:组件主配置文件,定义实例管理策略/etc/vitess/mycnf-template.cnf:MySQL配置模板,用于生成实例my.cnfTOPOLOGY_FLAGS正确指定拓扑服务类型及地址,确保集群元数据同步/var/lib/mysql,避免容器重启导致数据丢失manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务