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
安装MongoDB 开发环境PyMongoOracle中经典的问题解决方案相关资讯 MySQL数据库教程
- MySQL 处理非法数据 (04/09/2013 08:06:28)
- MySQL关于timestamp和mysqldump的 (12/16/2012 13:25:41)
- MySQL保证数据完整性 (12/16/2012 12:00:35)
| - ERROR 1130: mysql 1130连接错误的 (12/16/2012 13:29:08)
- MySQL数据库教程:管理数据库和表( (12/16/2012 12:47:02)
- MySQL快速插入大批量数据存储过程 (11/05/2012 19:04:04)
|
本文评论 查看全部评论 (0)