ThinkPHP5主从读写分离,MySQL自动同步数据

MySQL 5.7+版本:

TP 配置主从数据库

return [
    'type'            => 'mysql',
    'hostname'        => ['数据库ip地址','数据库ip地址'],
    'database'        => 'cs',
    'username'        => 'root,root',
    'password'        => ['root','root'],
    'charset'         => 'utf8',
    'prefix'          => 'cs_',
    'debug'           => true,
    // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
    'deploy'          => 1,
    // 数据库读写是否分离 主从式有效
    'rw_separate'     => false,
    // 读写分离后 主服务器数量
    'master_num'      => 1,
    // 指定从服务器序号
    'slave_no'        => '',
    // 自动读取主库数据
    'read_master'     => false,
    // 是否严格检查字段是否存在
    'fields_strict'   => true,
    // 数据集返回类型
    'resultset_type'  => 'array',
    // 自动写入时间戳字段
    'auto_timestamp'  => false,
    // 时间字段取出后的默认时间格式
    'datetime_format' => 'Y-m-d H:i:s',
    // 是否需要进行SQL性能分析
    'sql_explain'     => false,
    // Builder类
    'builder'         => '',
    // Query类
    'query'           => '\\think\\db\\Query',
    // 是否需要断线重连
    'break_reconnect' => false,
    // 断线标识字符串
    'break_match_str' => [],
];

继续配置mysql。

1、 主从的各个节点都要安装半自动复制插件,方法是登陆MySQL执行一下脚本:

mysql -uroot -p

回车输入密码(输入密码是不可见) 

主库:
install plugin rpl_semi_sync_master soname 'semisync_master.so';
 
从库:
INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
在主从数据库的/etc/my.cnf文件中加入如下配置:
主数据库
 
[mysqld]
rpl_semi_sync_master_enabled=1
rpl_semi_sync_master_timeout=1000   #此单位是毫秒
log-bin=mysql-bin #打开日志(主机需要打开)
server-id=1 #服务器id
#给从机同步的库,可以多个
binlog-do-db=fbs
binlog-do-db=db2
binlog-do-db=test
expire_logs_days=1 #自动清理1天前的log文件
从数据库
 
[mysqld]
rpl_semi_sync_slave_enabled=1
server-id=2 #服务器id
#要从主机同步的库
replicate-do-db=fbs
replicate-do-db=db2
replicate-do-db=test
3、修改之后,重启MySQL主数据库和MySQL从数据库的服务
service mysqld restart
4、配置主服务器的主数据库
 
GRANT REPLICATION SLAVE ON *.* TO 'root'@'192.168.20.129' IDENTIFIED BY 'pwd'; #主数据库授权同步账户
FLUSH PRIVILEGES; #刷新权限
SHOW MASTER STATUS; #查看主服务状态
 
 
注:SLAVE          => 给从库起个别名
   MASTER         => 主库别名
   192.168.20.129 => 从库ip
   root           => 从库数据库账号
   pwd            => 从库密码

 
5、配置从服务器的从数据库
{配置和改变slave服务器用于连接master服务器的参数【注意,MASTER_LOG_FILE=‘mysql-bin.000001’,MASTER_LOG_POS=601是通过前面的主数据库SHOW MASTER STATUS;得到】}
CHANGE MASTER TO MASTER_HOST='192.168.20.128',MASTER_USER='root', MASTER_PASSWORD='pwd',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=601;

注:
MASTER  =>主库别名
MASTER_HOST =>主库host
192.168.20.128 =>主库ip
root => 主库数据库账号
pwd =>主库密码
MASTER_LOG_FILE => 主日志文件(mysql-bin.000001跟主库查询到的文件名一致)
MASTER_LOG_POS => 主日志位置 (查询到的主库一致 例子:601)


start slave; #开启SLAVE同步

show slave status \G; #查看下slave状态
如果Slave_IO_Running和Slave_SQL_Running都为Yes,说明主从复制配置成功
stop slave; #停止slave同步

GRANT REPLICATION SLAVE ON *.* TO 'root'@'192.168.20.129' IDENTIFIED BY 'XXXXXX';# 撤销已经赋予给MySQL同步账户的权限

REVOKE REPLICATION SLAVE ON *.* FROM 'root'@'192.168.20.129';#revoke 跟 grant 的语法差不多,只需要把关键字 “to”
 
如果出现错误:Slave_SQL_Running: No
解决办法:
mysql>stop slave;#停止复制线程
mysql> set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
mysql> slave start;#再开启复制


 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值