2.3 master主节点配置修改配置文件
vim /etc/my.cnf..........[mysqld]#数据库唯一ID,主从的标识号绝对不能重复 。server-id=1#开启bin-log,并指定文件目录和文件名前缀log-bin=mysql-bin#同步test数据库 。如果同时同步多个库,就以此格式另写几行即可 。如果不指定某个库同步,删除此行,表示同步所有库(除了ignore忽略的库)binlog-do-db=test#不同步mysql系统数据库 。如果是多个不同步库,就以此格式另写几行;也可以在一行,中间逗号隔开 。binlog-ignore-db=mysql#设置二进制日志自动删除/过期的天数,避免占用磁盘空间 。默认值为0,表示不自动删除 。expire_logs_days=7#确保binlog日志写入后与硬盘同步sync_binlog=1#bin-log日志文件格式binlog_format=ROW
温馨提示:在主服务器上最重要的二进制日志设置是sync_binlog,这使得mysql在每次提交事务的时候把二进制日志的内容同步到磁盘上,即使服务器崩溃也会把事件写入日志中 。
sync_binlog这个参数是对于MySQL系统来说是至关重要的,他不仅影响到Binlog对MySQL所带来的性能损耗,而且还影响到MySQL中数据的完整性 。对于"sync_binlog"参数的各种设置的说明如下:
sync_binlog=0,当事务提交之后,MySQL不做fsync之类的磁盘同步指令刷新binlog_cache中的信息到磁盘,而让Filesystem自行决定什么时候来做同步,或者cache满了之后才同步到磁盘 。
sync_binlog=n,当每进行n次事务提交之后,MySQL将进行一次fsync之类的磁盘同步指令来将binlog_cache中的数据强制写入磁盘 。
在MySQL中系统默认的设置是sync_binlog=0,也就是不做任何强制性的磁盘刷新指令,这时候的性能是最好的,但是风险也是最大的 。因为一旦系统Crash,在binlog_cache中的所有binlog信息都会被丢失 。而当设置为“1”的时候,是最安全但是性能损耗最大的设置 。因为当设置为1的时候,即使系统Crash,也最多丢失binlog_cache中未完成的一个事务,对实际数据没有任何实质性影响 。
从以往经验和相关测试来看,对于高并发事务的系统来说,“sync_binlog”设置为0和设置为1的系统写入性能差距可能高达5倍甚至更多 。2.4 数据一致性在同步前保证master和slave中的数据一致,新环境忽略本步骤
导出数据库之前先锁定数据库
#数据库只读锁定命令,防止导出数据库的时候有数据写入,unlock tables命令解除锁定mysql> flush tables with read lock;导出master数据库中需要同步的库#导出需要同步的库[root@master ~]#mysqldump -uroot test -p123456 >/opt/test.sql#如不指定,则导出所有库mysqldump -uroot -p123456 --all-databases>/opt/all.sql将导出数据导入salve中#传到slavescp /opt/all slave:/opt#在slave导入数据库mysql> source /opt/all.sql2.5 创建数据同步账号登录主数据库创建一个用于从数据库复制的账号mysql> create user 'rep'@'192.168.150.25' identified with mysql_native_password by 'repl123';grant replication slave on *.* to 'rep'@'192.168.150.25';mysql> flush privileges;查看主服务器master状态(注意File与Position项,从服务器需要这两项参数)mysql> show master status;+-----------+-----------+--------------+------------------+-------------------+| File| Position| Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |+-----------+-----------+--------------+------------------+-------------------+| mysql-bin.000065 | 186607472 ||||+-----------+-----------+--------------+------------------+-------------------+1 row in set (0.00 sec)2.6 配置slave修改my.cnf配置文件
经验总结扩展阅读
- Dubbo2.7详解
- 属鸡2023年多大年龄了 属鸡人2023全年运势详解
- 华为手环6怎么样_华为手环6功能详解
- logback.xml详解
- iptables使用详解
- RAID5 IO处理之条带读代码详解
- RAID5 IO处理之写请求代码详解
- RAID5 IO处理之重构代码详解
- RAID5 IO处理之replace代码详解
- 二 kafka详解--kafka为什么快
