-
Mysql多实例的概念:
- MySql多实例就是在一台机器上开启多个不同的服务端口,运行多个MySql服务进程,通过不同的socket监听不同的服务端口来提供各自的服务。
- 这些Mysql多实例共用一套MySql安装程序,使用不同的my.cnf(也可以相同)配置文件、启动程序(也可以相同)和数据文件。
-
MySql多实例的特点:
- 有效利用服务器资源,当单个服务器资源有剩余是,可以充分利用剩余的资源提供更多的服务
- 节约服务器资源
- 缺点:资源互相抢占问题,当某个服务实例,服务并发很高时或者开启慢查询时,会消耗更多的内存,cpu,磁盘IO资源,导致服务器上的其他实例提供服务的质量下降
-
部署mysql多实例的两种方式:
- 第一种:是使用多个配置文件启动不同的进程来实现多实例,这种方式的优势逻辑简单,配置简单,缺点是管理起来不太方便
- 第二种:通过官方自带的mysqld_multi使用单独的配置文件来实现多实例,优点是管理起来很方便,集中管理
-
多实例的部署:
- 创建各实例数据存放的目录:
- mkdir -p /data/330{7,8,9}/data
-
初始化三套数据:
- mysqld --initialize-insecure --user=mysql --datadir=/data/3307/data --basedir=/usr/local/mysql
- mysqld --initialize-insecure --user=mysql --datadir=/data/3308/data --basedir=/usr/local/mysql
- mysqld --initialize-insecure --user=mysql --datadir=/data/3309/data --basedir=/usr/local/mysql
-
配置systemd管理多实例:
- cd /etc/systemd/system
- cp mysqld.service mysqld3307.service
- cp mysqld.service mysqld3308.service
- cp mysqld.service mysqld3309.service
- vim mysqld3307.service
- 修改为:ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/data/3307/my.cnf
- vim mysqld3308.service
- 修改为:ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/data/3308/my.cnf
- vim mysqld3309.service
- 修改为:ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/data/3309/my.cnf
- 授权:chown -R mysql:mysql /data/*
-
启动:
- systemctl start mysqld3307.service
- systemctl start mysqld3308.service
- systemctl start mysqld3309.service
-
查看各个实例的端口是否启动:
- netstat -anpt | grep 330
- 登录多实例的方法:
- mysql -uroot -p -S /data/3307/mysql.sock
- 创建各实例数据存放的目录:
2.Mysql 多实例的部署和应用
努力转型的IT小王2024-04-12 12:32
相关推荐
curd_boy1 天前
【数据库】分布式事务篇笃行客从不躺平1 天前
SQL 注入复习爬山算法1 天前
Redis(115)Redis的性能优化有哪些方法?腾讯云数据库1 天前
「腾讯云NoSQL」技术之Redis篇:精准围剿rehash时延毛刺实践方案揭秘ZhengEnCi1 天前
S2B-SQL UPDATE 更新数据完全指南-99%的人忘记WHERE子句,SQL高手却这样写:从基础语法到多表关联的数据修改利器xcLeigh1 天前
融合数据库时代:金仓 “五个一体化” 架构重塑数据管理新范式byte轻骑兵1 天前
数据库迁移革命:金仓KReplay如何用真实负载回放技术缩短3周测试周期腾讯云数据库1 天前
「腾讯云NoSQL」技术之向量数据库篇:自研分布式向量数据库,实现毫秒级时序一致备份的挑战和实践敲上瘾1 天前
C++ ODB ORM 完全指南:从入门到实战应用终生成长者1 天前
MongoDB 操作命令