MySQL 8 在一台机器上运行多个MySQL实例

时间:2023-03-08 20:52:27

可以为每个实例使用一个MySQL Server二进制程序,也可以为不同实例使用同一个MySQL Server二进制程序。

不管哪一种选择,部分参数可能需要不同配置,以避免多个实例之间的冲突。

可能需要为每个实例分别配置的参数包括:

--datadir=dir_name

--port=port_num

注:如果机器上有多个网络地址,可以通过bind_address系统变量使得每个Server监听不同的地址。

--socket=file_name

--pid-file=file_name

如果使用了下面的日志选项,这些参数也是需要配置:

--general_log_file=file_name

--log-bin[=file_name]
--slow_query_log_file=file_name
--log-error[=file_name]

为了更好的性能,分散物理磁盘的负载,可以为每个Server配置下面的参数:

--tmpdir=dir_name

注:在Slave Server中,slave_load_tmpdir 系统变量默认取值与tmpdir相同,由于slave_load_tmpdir指定的临时目录用于将复制的LOAD DATA语句存储在该临时目录下。所有如果tmpdir指定的临时目录如果是基于内存或者重启机器后自动删除的位置,可以将slave_load_tmpdir指定到一个永久性存储位置。

补充:

如果如果有多个MySQL Installations安装到不同的位置,可以指定basedir 系统变量。这样会使得每个Instance自动使用不同的数据目录、日志文件、PID文件,因为这些参数默认是与basedir关联的。在这种情况下,仅需要指定socket、port即可。

设置多个数据目录

通过 datadir 系统变量指定数据目录位置。

有两种方法为新的Instance设置数据目录:

生成新的数据目录

拷贝现有的数据目录

生成新的数据目录的方法:

操作同数据库安装中的数据目录初始化一样。

拷贝现有的数据目录的方法:

通过这样的方法,会将现有的用户账号以及用户数据拷贝到新的Instance中。

步骤1、停掉现有的MySQL Instance。必须使用clean shutdown,这样Instance会将pending changes刷新到磁盘上。比如:

mysql> set global innodb_fast_shutdown=0;

mysql> shutdown;

步骤2:拷贝现有的数据目录到新的位置。有时候,仅拷贝datadir目录下文件是不够的,因为有些文件可能被定义到非默认位置。

步骤3:拷贝my.cnf配置文件

步骤4:修改my.cnf配置文件

步骤5:启动新的数据库实例

通过如下脚本可以快速搭建一个测试实例:

shell> MYSQL_UNIX_PORT=/tmp/mysqld-new.sock

shell> MYSQL_TCP_PORT=3307

shell> export MYSQL_UNIX_PORT MYSQL_TCP_PORT

shell> bin/mysqld --initialize --user=mysql

shell> mysqld_safe --datadir=/path/to/datadir &