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 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
2301_769340679 小时前
怎样导出用于负载测试的样本数据_LIMIT限制数据量提取2401_850491659 小时前
c++如何通过文件映射mmap在多进程间实现高性能数据共享【进阶】iuvtsrt9 小时前
PHP 中高效查找 CSV 行并获取前后指定偏移行的数据m0_463672209 小时前
MySQL从库出现大量锁等待怎么办_分析从库执行计划与锁日志2301_809204709 小时前
为 Go 语言 WaitGroup.Wait() 添加超时机制的实用方案是桃萌萌鸭~10 小时前
oracle的隐藏虚拟列详解2301_7796224110 小时前
SQL分组聚合优化_GROUP BY索引与优化方案m0_7407963610 小时前
golang如何使用sync.WaitGroup_golang sync.WaitGroup并发等待使用方法DianSan_ERP10 小时前
抖店订单接口同步中如何解决订单漏单与数据一致性难题?2401_8242226910 小时前
c++如何通过重定向rdbuf来捕获第三方库的日志输出到文件【详解】