mysql主从配置和mysql-proxy读写分离踩过的坑

参考网上的配置,本人亲测,踩到三个大坑,以下为配置笔记:

 

 

以下为VM中实现Mysql主从分离。

mysql root / bin456

scp -r [email protected]:/usr/local/mysql /usr/local/

scp -r [email protected]:/etc/my.cnf /etc/my.cnf

/etc/my.cnf

set password=password('bin456');

 

./mysqld --initialize --user=root --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

 

 

grep -l bind-address ~/*.*

grep -r "bind-address" *

bind-address = 0.0.0.0

 

 

10.开启mysql服务,命令如下:

./support-files/mysql.server start

11.mysql进程放入系统进程中,命令如下:

cp support-files/mysql.server /etc/init.d/mysqld

12.重新启动mysql服务,命令如下:

service mysqld restart

13.使用随机密码登录mysql数据库,命令如下:

mysql -u root -p

等待系统提示,输入随机密码,即可登录

14.进入mysql操作行,为root用户设置新密码(小编设为rootroot):

alter user 'root'@'localhost' identified by 'rootroot';

15.设置允许远程连接数据库,命令如下:

update user set user.Host='%' where user.User='root';

16.刷新权限,命令如下:

flush privileges;

 

重启命令:/etc/init.d/mysql restart

 

vi etc/my.cnf

log_bin=mysql-bin //主库修改

server_id =1

 

主库开通从库同步权限:

grant replication slave on *.* to 'root'@'%' identified by 'bin456';

 

进入客户端:

[root@MiWiFi-R3-srv bin]# ./mysql -uroot -p

 

show master status;

 

mysql> show master status;

+------------------+----------+--------------+------------------+-------------------+

| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |

+------------------+----------+--------------+------------------+-------------------+

| mysql-bin.000001 |      589 |              |                  |                   |

 

 

从库中执行一下命令(master_log_file & master_log_pos是从上面主库查询获取)

mysql> CHANGE MASTER TO MASTER_HOST = '192.168.0.9', MASTER_USER = 'root', MASTER_PASSWORD = 'bin456', MASTER_PORT = 3306,master_log_file=' mysql-bin.000001',master_log_pos= 757;

 

flush privileges;

 

start slave;
 

show slave status \G

报错:Starting MySQL. ERROR! The server quit without updating PID file (/usr/local/mysql/data/hadoopServer.pid:

 

chown -R mysql:mysql /usr/local/mysql/data

chmod -R 755  /usr/local/mysql/data

 

./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

 

source那边,执行:

 

flush logs;

show master status;

 

记下File, Position

 

target端,执行:

 

CHANGE MASTER TO MASTER_LOG_FILE=' bin-log.000002',MASTER_LOG_POS=154;

stop slave;

 

start slave;

show slave status \G

 

一切正常。

 

以下为最大坑,网上说什么刷新主库日志,试了N次并重启还是报错,结果下面三句搞定:

Got fatal error 1236 from master when reading data from binary log: 'Could not find first log file name in binary log index file' 解决办法:

stop slave;

reset slave;

start slave;

 

-------------------------------mysql -proxy 0.8.5/0.8.3

mysql 版本:Server version: 5.7.1,已经实现了主从,如上

以下通过Mysql-proxy实现主从分离,参考:https://www.cnblogs.com/lin3615/p/5684891.html

vi /etc/mysql-proxy.cnf 

 

 

[mysql-proxy]

user=root

admin-username=root

admin-password=bin456

proxy-address=192.168.0.11:4040 //一定要记得修改为mysql-proxyIP,这是我踩过的坑

proxy-read-only-backend-addresses=192.168.0.10:3306

proxy-backend-addresses=192.168.0.9:3306

proxy-lua-script=/usr/local/mysql-proxy/lua/rw-splitting.lua

admin-lua-script=/usr/local/mysql-proxy/lua/admin-sql.lua

log-file=/usr/local/mysql-proxy/logs/mysql-proxy.log

log-level=info

daemon=true   

keepalive=true

 

 

 

 

grant all on *.* to 'root'@'192.168.0.11' identified by 'bin456';

 

mysql -u root -pbin456 -h192.168.0.11 --port=4040

 

启动mysql-proxy

/usr/local/mysql-proxy/bin/mysql-proxy --defaults-file=/usr/local/mysql-proxy/conf/mysql-proxy.conf 

 

netstat -anltp

 

 

第二坑:

mysql主从配置和mysql-proxy读写分离踩过的坑_第1张图片

通过mysql-proxy连上了,但是没有下一步,不像网上说的那样,折腾好久,又不报错,无从下手,后来用mysql客户端验证,原来实现了,如下图:

mysql主从配置和mysql-proxy读写分离踩过的坑_第2张图片

你可能感兴趣的:(mysql主从配置和mysql-proxy读写分离踩过的坑)