Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 452|回复: 0

【MySQL】MySQL主从库配置和主库宕机解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-27 13:32:44 | 显示全部楼层 |阅读模式

    1、转载:https://blog.csdn.net/zfl589778/article/details/51441719/

    2、效果:亲测有效,数据写入成功。

    3、主机宕机后,如果不是长时间宕机,且可手动重启,直接重启即可,【从】数据库数据会进行写入,无需重新配置my.cnf。【这里的主机宕机方案指的是:主机很长时间无法启动】

    4、原理:MySQL从库上有一个IO线程负责从主库取binlog写到本地,另外有一个SQL线程负责执行这些本地值日,实现命令重做

    4.1)如果发生宕机,则主和从都需要重复配置mysql-bin-0000X,change master ,。。。语句,然后start slave; show slave status

    5、步骤:

    一、准备工作
    
    系统:CentOS
    
    软件包:mysql-5.6.22.tar.gz
    
    master服务器:192.168.1.112
    
    slave服务器1:192.168.1.102
    
    slave服务器2:192.168.1.104
    
    
    
    二、修改master服务器配置
    
    vi /etc/my.cnf
    
    [mysqld]
    
    log-bin=mysql-bin #必选项,启用二进制日志,值为日志文件名前缀,该日志文件存储位置为mysql数据库目录
    
    server-id=112 #必选项,服务器唯一ID,默认是1,一般取IP最后一段
    
    binlog-do-db=mydb #可选项,需要同步的数据库,如果没有本行,即表示同步所有的数据库
    
    binlog-ignore-db=mysql #可选项,被忽略的数据库
    
    
    
    三、修改slave服务器1配置
    
    vi /etc/my.cnf
    
    [mysqld]
    
    log-bin=mysql-bin #可选项,启用二进制日志,可是主库宕机后升级从库为主库时仍然需要设置,所以现在一起启用也可以
    
    server-id=102 #必选项,服务器唯一ID
    
    replicate-do-db=mydb #可选项,需要同步的数据库名,不写本行表示同步所有的数据库
    
    
    
    四、重启所有服务器上的mysql服务
    
    建议先手动同步一下主从服务器中要备份的数据库
    
    service mysqld restart #如果mysql没有配置为系统服务,命令为/etc/init.d/mysql restart
    
    
    
    五、在master服务器上建立用于同步的账户并授权slave
    
    mysql -u root -p
    
    Enter password:root
    
    mysql>create user 'mymaster'@'%' identified by 'mymaster';
    
    mysql>grant replication slave on *.* to 'mymaster'@'%' identified by 'mymaster';#一般不用root账号,%表示所有从库都可以连,也可以指定从库IP增强安全性
    
    
    
    六、登录master服务器的mysql,查看master状态
    
    mysql>show master status;
    
       +------------------+----------+--------------+------------------+
       | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
       +------------------+----------+--------------+------------------+
       | mysql-bin.000001 |      120 |              |                  |
       +------------------+----------+--------------+------------------+
    
    
    
    七、配置两台slave服务器
    
    mysql>change master to master_host='192.168.1.112',master_user='mymaster',master_password='mymaster',master_log_file='mysql-bin.000001',master_log_pos=120;#连接master
    
    mysql>start slave; #启动slave的复制功能
    
    
    
    八、登录slave的mysql,查看从库状态
    
    mysql>show slave status\G; #以下是部分结果
    
    *************************** 1. row ***************************
    
    Slave_IO_State: Waiting for master to send event#从库状态,已连上主库
    
    Master_Host: 192.168.1.112#master地址
    
    Master_User: mymaster#master用户
    
    Master_Port: 3306#master端口
    
    Connect_Retry: 60#重试时间,默认是60秒
    
    Master_Log_File: mysql-bin.000001#master的binlog文件名
    
    Read_Master_Log_Pos: 1556#同步读取二进制日志的位置,大于等于Exec_Master_Log_Pos
    
    Slave_IO_Running: Yes#必须为Yes,此线程把master段的日志写到本地
    
    Slave_SQL_Running: Yes#必须为Yes,此线程把写到本地的日志应用于数据库
    
    Replicate_Do_DB:#同步数据库名(如果有)
    
    Replicate_Ignore_DB: #忽略数据库名(如果有)
    
    Exec_Master_Log_Pos: 1556#执行同步命令的位置
    
    Last_IO_Errno: 0#最近IO出错位置
    
    Last_IO_Error: #最近IO出错信息
    
    Last_SQL_Errno: 0#最近SQL出错位置
    
    Last_SQL_Error: #最近SQL出错信息
    
    Master_Server_Id: 112#master服务器ID
    
    Master_Info_File: /data/mysqldb/master.info#master.info文件位置,位于该slave中
    
    1 row in set (0.00 sec)
    
    如果Slave_IO_Running和Slave_SQL_Running均为Yes,则slave配置完成
    
    
    
    九、主从服务器测试
    
    在master中创建数据库,创建表,进行增删改操作都会被同步到所有slave中
    
    
    
    十、主库宕机解决方案
    
    假设发生了突发事件,master宕机,现在的需求是要将192.168.1.102提升为主库,另外一个为从库
    
    步骤:
    
    1.确保所有的relay log全部更新完毕,在每个从库上执行stop slave io_thread; show processlist;直到看到Has read all relay log,则表
    
    示从库更新都执行完毕了
    
    2.登陆所有从库,查看master.info文件,对比选择pos最大的作为新的主库,这里我们选择192.168.1.102为新的主库
    
    3.登陆192.168.1.102,执行stop slave; 并进入数据库目录,删除master.info和relay-log.info文件, 配置my.cnf文件,开启log-bin,如果有
    
    log-slaves-updates和read-only则要注释掉,执行reset master
    
    4.创建用于同步的用户并授权slave,同第五大步骤
    
    5.登录另外一台从库,执行stop slave停止同步
    
    6.根据第七大步骤连接到新的主库
    
    7.执行start slave;
    
    8.修改新的master数据,测试slave是否同步更新
    
    
    
    十一、其他
    
    1.如果修改了主服务器的配置,记得删除从服务器上的master.info文件。否则从服务器使用的还是老配置,可能会导致错误。
    
    2.如果你想使用复制数据文件的方式来备份数据库,只要在从服务器上的mysql命令行先键入stop slave;然后复制数据库文件,复制
    
    好了,再 在mysql命令行键入start slave;启动从服务器,这样就即备份了数据有保证了数据完整性,而且整个过程中主服务器的
    
    mysql无需停止。并且如果在此期间master的数据有改动,在下次start slave时数据也会同步更新过来
    
    3.Slave_IO_State的取值
    
    空 //复制没有启动
    
    Connecting to master//没有连接上master
    
    Waiting for master to send event//已经连上
    
    4.双机互备则是两个mysql同时配置为master及slave
    
    5.主服务器上的相关命令:
    
    show master status
    
    show slave hosts
    
    show {master|binary} logs
    
    show binlog events
    
    purge {master|binary} logs to 'log_name'
    
    purge {master|binary} logs before 'date'
    
    reset master(老版本flush master)
    
    set sql_log_bin={0|1}
    
    6.从服务器上的相关命令
    
    start slave
    
    stop slave
    
    stop slave io_thread
    
    start slave is_thread
    
    stop slave sql_thread
    
    start slave sql_thread
    
    reset slave
    
    SET GLOBAL SQL_SLAVE_SKIP_COUNTER
    
    load data from master
    
    show slave status(SUPER,REPLICATION CLIENT)
    
    CHANGE MASTER TO MASTER_HOST=, MASTER_PORT=,MASTER_USER=, MASTER_PASSWORD= #动态改变master信息
    
    PURGE MASTER [before 'date'] #删除master端已同步过的日志

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 20:52 , Processed in 0.065463 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表