欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

MySQL多实例讲解

程序员文章站 2024-02-20 14:55:58
...

mysql多实例,每个MySQL多实例讲解实例的datadir,pid,port,socket应该是不同的,在Unix中,在你启动客户端之前,设置MYSQL_UNIX_P

mysql多实例,每个实例的datadir,pid,port,socket应该是不同的

一、基础,很重要

每个实例应该在自己的datadir下配置my.cnf文件。
首先说下配置文件的查找顺序
第一搜,首先读取/etc/my.cnf
第二搜,$datadir/my.cnf,在data目录下寻找此配置文件,每个实例应该在自己的datadir下配置my.cnf文件。
第三搜,defaultfile=/path/my.cnf 通常写在命令行上,mysqld_safe defaultfile=/tmp/my.cnf &等执行。
第四搜,~/my.cnf 当前用户下的配置文件。


二、为各个实例配置datadir(例子中利用默认实例数据)

停掉mysql默认的服务(防止出现损坏默认实例数据库的情况):service mysql

stop

复制datadir
[root@localhost lib]# cp -r mysql /var/lib/mysql_3301
[root@localhost lib]# cp -r mysql /var/lib/mysql_3302

把mysql设置为owner
[root@localhost lib]# chown -R mysql.mysql mysql_3301
[root@localhost lib]# chown -R mysql.mysql mysql_3302

把mysql设置为文件夹内文件的owner
[root@localhost lib]# cd mysql_3301
[root@localhost mysql_3301]# chown -R mysql.mysql *
[root@localhost mysql_3301]# cd ../mysql_3302
[root@localhost mysql_3302]# chown -R mysql.mysql *

注释:
开始失败的原因在于mysql_3301与mysql_3302文件夹下的文件没有赋权于mysql用

户,,导致错误
cd mysql_3301
chown -R mysql.mysql *
cd ../mysql_3302
chown -R mysql.mysql *

三、配置文件选项:

[root@localhost mysql_3302]# cd /usr/local
[root@localhost local]# vi my_multi.cnf

[mysqld_multi]
mysqld = /usr/bin/mysqld_safe
mysqladmin = /usr/bin/mysqladmin
user = root

[mysqld1]
socket = /tmp/mysql_3301.sock
port = 3301
pid-file = /var/lib/mysql_3301/hostname.pid
datadir = /var/lib/mysql_3301/
log = /var/lib/mysql_3301/hostname.log
user = mysql


[mysqld2]
socket = /tmp/mysql_3302.sock
port = 3302
pid-file = /var/lib/mysql_3302/hostname.pid
datadir = /var/lib/mysql_3302/
log = /var/lib/mysql_3302/hostname.log
user = mysql

MySQL多实例讲解