当前位置: 首页 > news >正文

MySQL多实例管理

在 MySQL 中配置和管理多实例(如 3 个实例)时,每个实例需要独立的配置文件、数据目录、端口和 socket 文件。以下是基于你提供的 3307 实例配置,扩展的 3 实例完整配置方案:

1. 多实例目录规划

首先创建 3 个实例的目录结构(以 3307、3308、3309 端口为例):

# 创建基础目录
mkdir -p /data/{3307,3308,3309}/{data,logs}
chown -R mysql:mysql /data

2. 各实例配置文件(my.cnf)

3307 实例配置
cat > /data/3307/my.cnf << EOF
[mysqld]
user=mysql
basedir=/application/mysql
datadir=/data/3307/data
socket=/data/3307/mysql.sock
port=3307
server_id=7  # 每个实例的 server_id 必须唯一
log_error=/data/3307/logs/mysql-error.log
log_bin=/data/3307/logs/mysql-bin  # 二进制日志(如需要主从复制)
binlog_format=row  # 推荐行级复制
expire_logs_days=7  # 日志保留7天
max_connections=100  # 最大连接数
EOF
3308 实例配置
cat > /data/3308/my.cnf << EOF
[mysqld]
user=mysql
basedir=/application/mysql
datadir=/data/3308/data
socket=/data/3308/mysql.sock
port=3308
server_id=8  # 唯一ID
log_error=/data/3308/logs/mysql-error.log
log_bin=/data/3308/logs/mysql-bin
binlog_format=row
expire_logs_days=7
max_connections=100
EOF
3309 实例配置
cat > /data/3309/my.cnf << EOF
[mysqld]
user=mysql
basedir=/application/mysql
datadir=/data/3309/data
socket=/data/3309/mysql.sock
port=3309
server_id=9  # 唯一ID
log_error=/data/3309/logs/mysql-error.log
log_bin=/data/3309/logs/mysql-bin
binlog_format=row
expire_logs_days=7
max_connections=100
EOF

3. 初始化各实例

# 初始化 3307 实例(生成初始数据文件)
/application/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/application/mysql --datadir=/data/3307/data# 初始化 3308 实例
/application/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/application/mysql --datadir=/data/3308/data# 初始化 3309 实例
/application/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/application/mysql --datadir=/data/3309/data

--initialize-insecure 表示初始密码为空,方便首次登录

4. 启动/停止多实例(推荐直接用第6步)

启动实例
# 启动 3307
/application/mysql/bin/mysqld_safe --defaults-file=/data/3307/my.cnf &# 启动 3308
/application/mysql/bin/mysqld_safe --defaults-file=/data/3308/my.cnf &# 启动 3309
/application/mysql/bin/mysqld_safe --defaults-file=/data/3309/my.cnf &
停止实例
# 停止 3307(通过 socket 文件)
/application/mysql/bin/mysqladmin -S /data/3307/mysql.sock shutdown -u root -p# 停止 3308
/application/mysql/bin/mysqladmin -S /data/3308/mysql.sock shutdown -u root -p# 停止 3309
/application/mysql/bin/mysqladmin -S /data/3309/mysql.sock shutdown -u root -p

5. 登录多实例

# 登录 3307 实例(首次登录无密码,直接回车)
/application/mysql/bin/mysql -S /data/3307/mysql.sock -u root -p# 登录 3308 实例
/application/mysql/bin/mysql -S /data/3308/mysql.sock -u root -p# 登录 3309 实例(也可通过端口登录)
/application/mysql/bin/mysql -h 127.0.0.1 -P 3309 -u root -p

6. 配置系统服务(便捷管理)

为每个实例创建 systemd 服务文件,方便通过 systemctl 管理:

3307 服务文件
cat > /usr/lib/systemd/system/mysqld3307.service << EOF
[Unit]
Description=MySQL 3307 Instance
After=network.target[Service]
User=mysql
Group=mysql
ExecStart=/application/mysql/bin/mysqld_safe --defaults-file=/data/3307/my.cnf
ExecStop=/application/mysql/bin/mysqladmin -S /data/3307/mysql.sock shutdown -u root -p
Restart=on-failure[Install]
WantedBy=multi-user.target
EOF
3308 和 3309 服务文件

同理创建 mysqld3308.servicemysqld3309.service,只需修改文件中 3307 为对应端口即可。

服务管理
# 启动 3307 并设置开机自启
systemctl start mysqld3307
systemctl enable mysqld3307# 查看状态
systemctl status mysqld3307

关键注意事项

  1. 唯一性:每个实例的 portserver_idsocketdatadir 必须唯一,避免冲突。
  2. 权限:所有目录需属 mysql:mysql 权限,否则启动失败。
  3. 安全加固:首次登录后立即修改 root 密码:
    ALTER USER 'root'@'localhost' IDENTIFIED BY 'NewPassword123!';
    
  4. 资源隔离:如需限制实例资源(如内存、CPU),可在配置文件中添加 innodb_buffer_pool_sizemax_connections 等参数。

通过以上配置,即可实现 MySQL 多实例的独立管理和运行。

http://www.dtcms.com/a/406501.html

相关文章:

  • 用dpdk实现udp、tcp数据包收发,tcp协议栈相关原理
  • 3D气象数据可视化:使用前端框架实现动态天气展示
  • 学习日记19:GRAPH-BERT
  • shell编程:sed - 流编辑器(5)
  • 网站制作地点中山网站建设公司哪家好
  • 关于【机器人小脑】的快速入门介绍
  • 无线收发模块保障砂芯库桁架机器人稳定无线通信实践
  • 北京有哪些网站建设国家企业信用信息系统(全国)
  • LabVIEW 动态信号分析
  • 腾讯云容器服务
  • 怎么做网站推广电话广西网站建设哪家有
  • 实战:基于 BRPC+Etcd 打造轻量级 RPC 服务——高级特性与生产环境深度实践
  • 蓝耘MaaS驱动PandaWiki:零基础搭建AI智能知识库完整指南
  • C语言,结构体
  • [创业之路-599]:193nm、266nm、355nm深紫外激光器的上下游产业链和相应的国产化公司
  • 安溪住房和城乡规划建设局网站wordpress+左侧菜单
  • Ubuntu 系统中防火墙
  • 摄像头-激光雷达在线标定相机脚本(ROS 版)
  • 做网站建设需要多少钱手机营销软件
  • 360官方网站餐饮网站开发毕业设计模板
  • 从0到1玩转BurpSuite:Web安全测试进阶之路
  • Go-Zero API Handler 自动化生成与参数验证集成
  • Choosing the Number of Clusters|选择聚类的个数
  • golang基础语法(五)切片
  • Golang学习笔记:标准库sync包
  • 【Git】Git 简介及基本操作
  • 网站模版怎么做wordpress 图片 二级域名
  • 点击EDGE浏览器下载的PDF文件总在EDGE中打开
  • 用MATLAB画一只可爱的小熊
  • Matlab通过GUI实现点云的半径滤波(Radius Outlier Removal)