mysql互为主从失效,重新同步

一、分别登录服务器A和服务器B的mysql

复制代码
mysql -u root -p 123456789

二、分别查看数据库状态信息,下边两项参数有一项为NO就表示同步异常

Slave_IO_Running:从服务器(Slave)中的 I/O 线程的运行状态

Slave_SQL_Running:从服务器上的 SQL 线程是否正在运行

复制代码
mysql> show slave status\G                                                
Slave_IO_Running: Yes
Slave_SQL_Running: No

三、修复异常,重新同步

数据库A

1、停止同步操作

复制代码
mysql> stop slave;

2、进行锁表,防止数据写入

复制代码
mysql> flush tables with read lock;

3、备份数据库数据、同步数据库数据

4、查看log日志的同步点位

复制代码
mysql> show master status;
+-------------------+----------+--------------+-------------------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB              |
+-------------------+----------+--------------+-------------------------------+
| mysqld-bin.000001 |     3260 |              | mysql,test,information_schema |
+-------------------+----------+--------------+-------------------------------+
1 row in set (0.00 sec)

数据库B

5、停止同步操作

复制代码
mysql> stop slave;

6、备份数据库数据、同步数据库数据

7、设置从库同步,注意该处的同步点,就是数据库Ashow master status信息里的| File| Position两项

复制代码
mysql> change master to master_host = '192.168.128.100', master_user = 'rsync',  master_port=3306, master_password='', master_log_file =  'mysqld-bin.000001', master_log_pos=3260;

8、打开数据库同步状态

复制代码
mysql> start slave;

9、参看同步状态信息

Slave_IO_Running、Slave_SQL_Running数据都为yes表示同步成功,为no时可能为7中的File| Position两项配置不正确

复制代码
mysql> show slave status\G  

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

10、查看log日志的同步点位,供数据库A使用

复制代码
mysql> show master status;
+-------------------+----------+--------------+-------------------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB              |
+-------------------+----------+--------------+-------------------------------+
| mysqld-bin.000001 |     3260 |              | mysql,test,information_schema |
+-------------------+----------+--------------+-------------------------------+
1 row in set (0.00 sec)

数据库A

11、数据库A同步B

复制代码
mysql> change master to master_host = '192.168.128.100', master_user = 'rsync',  master_port=3306, master_password='', master_log_file =  'mysqld-bin.000001', master_log_pos=3260;

12、打开从库同步状态

复制代码
mysql> start slave;

13、查看同步状态信息

复制代码
mysql> show slave status\G  

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

14、解除表锁定

复制代码
UNLOCK TABLES;

四、crontab定时检查数据库同步状态,发现异常时发送消息到钉钉群,脚本如下

复制代码
<?php

function httpsPost($url = '', $data = []){
	$curl = curl_init();
	
	// 设置请求头
	$headers = array(
			"Content-Type: application/json"
	);
	curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
	
	curl_setopt($curl, CURLOPT_URL, $url);
	if (stripos($url, "https://") !== false) {
			curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
			curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
			curl_setopt($curl, CURLOPT_SSLVERSION, 1); //CURL_SSLVERSION_TLSv1
	}
	if (!empty($data)) {
			curl_setopt($curl, CURLOPT_POST, 1);
			curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data));
	}
	curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
	$output = curl_exec($curl);
	if (curl_error($curl) != 0) {
			curl_error($curl);
			curl_close($curl);
			return false;
	} else {
			curl_close($curl);
			return $output;
	}
}
	
try {
   
	$dsn = 'mysql:host=127.0.0.1;dbname=数据库名';
	$username = '数据库账号';
	$password = '数据库密码';
	
	$pdo = new PDO($dsn, $username, $password);
	$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
	
	$sql = 'show slave status';
	$stmt = $pdo->prepare($sql);
	$id = 1; // 示例值
	$stmt->bindParam(':id', $id); // 绑定参数以防止SQL注入
	$stmt->execute(); // 执行查询
	$result = $stmt->fetch(PDO::FETCH_ASSOC); // 获取单行结果

	
	if($result["Slave_SQL_Running"] != "Yes"){
		$data = [
			'msgtype' => 'text',
			'text'    =>
				[
					'content' => "@所有人 同学快来:数据库同步异常了"
				],
		];
		//监控群
		$url="钉钉监控群消息接口地址";
		//测试环境
		httpsPost($url,$data);
	}
    echo "数据库同步正常";
		
} catch (PDOException $e) {
    die("Query failed: " . $e->getMessage());
}
相关推荐
←か淡定☆ ヾ14 分钟前
SQL Server 2008R2 到 2012 数据库迁移完整指南
数据库·sql server
瀚高PG实验室20 分钟前
Arcgis连接HGDB报错
数据库·arcgis·瀚高数据库
IT小辉同学1 小时前
PostgreSQL 与 MySQL 获取字段注释并转换为驼峰命名教程
数据库·mysql·postgresql
xinghunzhiye20101 小时前
redis升级
数据库·redis·缓存
叁沐1 小时前
MySQL 12 为什么我的MySQL会“抖”一下?
mysql
一只fish2 小时前
MySQL 8.0 OCP 1Z0-908 题目解析(21)
数据库·mysql
涛思数据(TDengine)2 小时前
时序数据库 TDengine × SSRS:专为工业、能源场景打造的报表解决方案
大数据·数据库·物联网·时序数据库·tdengine
打鱼又晒网2 小时前
Lecture #20:Database Logging
数据库
白仑色2 小时前
Oracle 数据库管理与维护实战指南(用户权限、备份恢复、性能调优)
数据库·oracle·数据库管理·性能调优·备份恢复
wx_ywyy67982 小时前
分布式推客系统全栈开发指南:SpringCloud+Neo4j+Redis实战解析
数据库·oracle·推客系统·推客小程序·推客系统开发·推客小程序开发·推客分销系统