首页 技术 正文
技术 2022年11月17日
0 收藏 356 点赞 3,882 浏览 3953 个字

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.gzmaster服务器:192.168.1.112slave服务器1:192.168.1.102slave服务器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 #必选项,服务器唯一IDreplicate-do-db=mydb #可选项,需要同步的数据库名,不写本行表示同步所有的数据库四、重启所有服务器上的mysql服务建议先手动同步一下主从服务器中要备份的数据库service mysqld restart #如果mysql没有配置为系统服务,命令为/etc/init.d/mysql restart五、在master服务器上建立用于同步的账户并授权slavemysql -u root -pEnter password:rootmysql>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;#连接mastermysql>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_PosSlave_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服务器IDMaster_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 master4.创建用于同步的用户并授权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//没有连接上masterWaiting for master to send event//已经连上4.双机互备则是两个mysql同时配置为master及slave5.主服务器上的相关命令:show master statusshow slave hostsshow {master|binary} logsshow binlog eventspurge {master|binary} logs to 'log_name'purge {master|binary} logs before 'date'reset master(老版本flush master)set sql_log_bin={0|1}6.从服务器上的相关命令start slavestop slavestop slave io_threadstart slave is_threadstop slave sql_threadstart slave sql_threadreset slaveSET GLOBAL SQL_SLAVE_SKIP_COUNTERload data from mastershow slave status(SUPER,REPLICATION CLIENT)CHANGE MASTER TO MASTER_HOST=, MASTER_PORT=,MASTER_USER=, MASTER_PASSWORD= #动态改变master信息PURGE MASTER [before 'date'] #删除master端已同步过的日志
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,075
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,551
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,399
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,176
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,811
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,893