/windows*******************************************************************************************/
// 拷贝文件
将Mysql原始文件中所有文件拷贝到D:/programfiles/MySqlMuti/MySql_002
处理data文件夹的内容:删除该目录一级目录下ib开头的文件,auto.cnf,ice-PC.err,ice-PC.pid等文件,仅仅保留mysql文件夹和performance_schema文件夹
// 新建my.ini
在D:/programfiles/MySqlMuti/MySql_002中创建my.ini,保证basedir,datadir,port,server_id和原安装的MySql的my.ini里面的参数不同
配置参见MySql主文件配置.txt
// 安装多实例服务
cd D:\programfiles\MySql\bin
mysqld install MySQL_002 --defaults-file=“D:/programfiles/MySqlMuti/MySql_002/my.ini”
// 删除实例服务
mysqld remove MySQL_002
// 启动服务
net start mysql_002
/Linux*********************************************************************************************/
// 添加MySql环境变量
vim /etc/profile最下面加上
export PATH=/D/programfiles/MySql/bin:$PATH
重启
// 把用到的工具添加到/usr/bin目录
ln -s /D/programfiles/MySql/bin/mysqld_multi /usr/bin/mysqld_multi
ln -s /D/programfiles/MySql/scripts/mysql_install_db /usr/bin/mysql_install_db
// 创建目录
mkdir /D/programfiles/MySql/data3306 -p
mkdir /D/programfiles/MySql/data3307 -p
// 初始化数据目录(主要是创建默认的mysql库)
mysql_install_db --basedir=/D/programfiles/MySql --datadir=/D/programfiles/MySql/data3306 --user=mysql
mysql_install_db --basedir=/D/programfiles/MySql --datadir=/D/programfiles/MySql/data3307 --user=mysql
// 查看多配置例子
mysqld_multi --example
用mysqld_multi工具查看该配置文件的模板方法(这是官方提供的例子,具体还要自己修改如:mysqld,mysqladmin,socket,port,pid-file,datadir,user等)
配置参见MySql主文件配置.txt
// 查看多实例是否启动
mysqld_multi report
// 启动多实例
mysqld_multi --defaults-extra-file=/D/programfiles/MySql/my.cnf start 1
mysqld_multi --defaults-extra-file=/D/programfiles/MySql/my.cnf start 2
// 添加防火墙设置(打开需要用到的端口,很重要,不然MySql连接不上)
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3307 -j ACCEPT
// 停止多实例(默认停不了(需要修改mysqld_mutli文件)可以用ps -ef|grep mysqld然后用kill -9 pid来杀掉)
ps -ef|grep mysqld
然后kill -9 pid
mysqld_multi stop 1(无效)
mysqld_multi stop 2(无效)
// 查看指定单个实例的配置信息
my_print_defaults mysqld_multi mysqld1
// 进入端口为3307的数据库(%的用户一定要IP连接,不能用127.0.0.1或localhost连接)
mysql -uroot -p -h115.28.154.106 -P3307
// 通过sock文件登录
mysql -uroot -p -S /D/programfiles/MySql/mysql3307.sock
// 查看socket文件(命令行登录MySql后执行)
SHOW VARIABLES LIKE ‘socket’;
// 查看pid文件(命令行登录MySql后执行)
SHOW VARIABLES LIKE ‘%pid%’;
/其他**********************************************/
// 杀掉单实例,删除单实例的启动方式
pkill mysqld
ps -ef |grep mysql
rm -rf /etc/init.d/mysqld(测试时不要删除,不然还原不了单实例模式)
// 将多实力加入开机启动(需要先删除单实例方式的开机启动)
echo “/D/programfiles/MySql/bin/mysqld_multi --defaults-file=/D/programfiles/MySql/my.cnf start 1,2” >> /etc/rc.local
// 删除主MySql的Log日志
rm -rf /D/programfiles/MySql/logs/mysqld.log
// 查看主MySql的Log日志
vim /D/programfiles/MySql/logs/mysqld.log
/常见错误**********************************************************************************************/
// Can’t start server : Bind on unix socket: Permission denied(不能启动)
解决:chmod 777 /D/programfiles/MySql
// unable to lock ibdata1 error 11
有可能是由于资源不足引起的,就是内存或磁盘空间,我在本地开了3g内存后测试启动每一个实例,日志里都没有再报这个错
// Cannot allocate memory for the buffer pool
无法分配内存,内存不足了需要加内存