• MySQL 5.5主从同步设置教程


    先修改Master(10.1.123.197)的 my.cnf 配置
    
    在 [mysqld] 中新增以下内容
    
    log-bin=mysql-bin
    log-bin-index=mysql-bin.index
    server-id = 1
    sync_binlog=1
    binlog_format=mixed
    
    然后指定要做同步的数据库,并忽略掉不需要做同步的数据库
    
    binlog-do-db = testdb
    binlog-ignore-db = mysql
    binlog-ignore-db = performance_schema
    binlog-ignore-db = information_schema
    
    在 [mysqldump] 中修改内容为              
    max_allowed_packet = 32M
    
    注意:确保 max_allowed_packet 有比较大的值,比如 max_allowed_packet = 100M
    
    重启 mysql
    service mysql restart
    
    在Master上创建一个复制用户
    CREATE USER funsion;
    GRANT REPLICATION SLAVE ON *.* TO funsion IDENTIFIED BY 'ifunsion.com';
    # 测试环境密码是  xyzzy
    
    + ---------------------------------------------------------- +
    
    再修改 Slave(10.1.123.160)的配置,修改 my.cnf
    
    在 [mysqld] 中新增以下内容
    
    server-id=2
    log-bin = mysql-bin
    relay-log-index = slave-relay-bin.index
    relay-log = slave-relay-bin
    
    sync_master_info = 1
    sync_relay_log = 1
    sync_relay_log_info = 1
    
    # 以上三行话只使用于MySQL 5.5
    
    输入 mysql -u root -p
    进入mysql命令行,输入
    
    CHANGE MASTER TO MASTER_HOST = '10.1.123.233', MASTER_USER = 'funsion', MASTER_PORT = 3306, MASTER_PASSWORD = 'ifunsion.com';
    
    CHANGE MASTER TO MASTER_CONNECT_RETRY=30;
    
    在输入 START SLAVE;
    
    + ----------------------- 如果发生错误无法启动 ------------------- +
    
    进入Master 的数据库
    输入 show master statusG
    记录下当前使用的 log-bin文件,以及position (比如现在日志是 mysql-bin.000001 ,位置是 107)
    
    然后进入Slave 的数据库
    输入 stop slave;
    change master to master_log_file='mysql-bin.000001',master_log_pos=107;
    最后输入  start slave;
    
    最后在服务器上执行
    yum -y install ntpdate
    ntpdate cn.pool.ntp.org
    clock -w
    把几台服务器的时间同步
    
    + ---------------------------- 一些可能用到的命令 ------------------------- +
    
    执行锁表:
    flush tables with read lock;
    这一步的目的是使我们在制作主从的过程中,主库中不会有新的数据,否则会给我们的同步设置带来麻烦
    
    主库执行解锁:
    unlock tables;
    
    reset master    命令删除了所有的二进制日志文件并清空了二进制日志索引文件。
    reset slave        命令删除了Slave复制所用的所有文件,重新开始。
    
    + ----------------------- 其它参考文档(未验证)-------------------------- +
    
    库业务不能停的情况下为从库制作镜像:
    案例:
    服务器1号:主
    服务器2号:从
    现在由于负载问题需要上架服务器3号同样为1号的从服务器。
    但是1号库不能停,2号也不能停,主从同步进程也不能停(要求苛刻)。
    可以这样做:
    在主:
    mysqldump -uroot -pxxxx -h127.0.0.1 --databases db1 db2 db3 --master-data=1 > bak.sql
    3号服务器slave stop;
    之后将bak.sql导入3号从服务器
    slave start;
    3号服务器会自动从导出的那一刻的节点更新。
    因为--master-data=1 这个参数在导出sql文件后会在最下方加上change语句。如果--master-data=0,则不会带有。
    非常的方便,但仅适合库不是太大的情况,该案例导出的库一共6G。
  • 相关阅读:
    yum 安装包的用法
    php session文件修改路径
    apache性能测试工具ab使用详解
    shell exit 0 exit 1
    网站架构(页面静态化,图片服务器分离,负载均衡)方案全解析
    【转载】新手如何快速打造高流量网站
    高并发处理方案
    HTML静态化技术
    在项目中学习.NET的json(二)之运费计算器
    在项目中学习.NET的json(一)
  • 原文地址:https://www.cnblogs.com/funsion/p/4003488.html
Copyright © 2020-2023  润新知