MySql安装Muti

/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
无法分配内存,内存不足了需要加内存

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2023年Java面试宝典

您的鼓励是对我的肯定,共建希望

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值