MySQL多实例必须使用不同端口、数据目录、socket文件、PID文件和日志路径;推荐用mysqld_multi统一管理,每个实例需独立配置文件并显式指定各项路径与端口,连接时注意区分TCP与socket模式。mysql多实例必须用不同端口和数据目录一个 MySQL 实例本质是独立的 mysqld 进程,共享同一套二进制文件但不能共用端口、socket 文件或 datadir。否则启动时直接报错:Can't start server: Bind on TCP/IP port. Got error: 98: Address already in use 或 Another MySQL daemon already running with the same unix socket。实操建议:每个实例分配唯一 port(如 3307、3308),避免与默认 3306 冲突datadir 必须指向互不重叠的路径,例如 /var/lib/mysql3307、/var/lib/mysql3308,且需提前初始化:mysqld --initialize --datadir=/var/lib/mysql3307 --user=mysqlsocket 文件路径也要区分,比如 /tmp/mysql3307.sock,否则客户端连错实例不要复用主实例的 my.cnf,每个实例应有独立配置文件(如 /etc/my3307.cnf)用 mysqld_multi 管理多个实例最省事mysqld_multi 是 MySQL 自带的多实例启停工具,比写一堆 systemd service 文件或 shell 脚本更可靠,尤其适合需要统一管理启停、查看状态的场景。实操建议:在 /etc/my.cnf 中用 [mysqld_multi] 段声明配置文件位置:mysqld = /usr/bin/mysqld,mysqladmin = /usr/bin/mysqladmin为每个实例建独立段,如 [mysqld3307],里面必须包含 port、datadir、socket、pid-file 和 log-error启动单个实例:mysqld_multi start 3307;启动全部:mysqld_multi start验证是否运行:mysqld_multi report,它会检查每个实例的 pid-file 是否存在、端口是否监听systemd 启动多实例要注意进程隔离如果不用 mysqld_multi,改用 systemd 管理,必须确保每个服务单元(.service 文件)定义了独立的 ExecStart、PIDFile 和 RuntimeDirectory,否则 systemctl 会误判进程状态,导致 start 成功但 status 显示 inactive。 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
_ku_ku_7 分钟前
数据库系统原理 · 事务管理与恢复 · 自学总结lifewange2 小时前
Redis 集合(Set)运算完全指南TDengine (老段)2 小时前
TDengine RAFT共识协议 — 选举、日志复制、快照与仲裁浪里行舟2 小时前
你的品牌正在被AI“遗忘”?用BuildSOM找回搜索的下一个风口Full Stack Developme3 小时前
Spring Boot 事务管理完整教程码界筑梦坊3 小时前
120-基于Python的食品营养特征数据可视化分析系统logo_283 小时前
Xpath语法规则的学习和使用快乐江湖3 小时前
「层层包装」—— 装饰器模式m0_702036534 小时前
mysql如何通过索引减少行锁范围_mysql索引与加锁逻辑用户0332126663674 小时前
使用 Python 设置 Word 文档文本的颜色