如何判断一个数据库是不是出问题了?

前言

数据库一般是一主多从的情况,以及如何保证一致性,出现问题就切库。那么如何判断出现问题了呢?


如何判断一个数据库是不是出问题了?

1、排查问题的方法

通过selcet 1 ,这种方法只能检查mysql服务器上是否有mysql的进程,并不能给出一定可以响应

通过读查询,创建一个表health_check,然后每次去读一下这个数据。这种方式不涉及到写操作,则不会写入到binlog,如果系统磁盘写满,则仍然可以查询但是无法写入到binlog,这种方式就会有写的问题无法被发现

通过更新语句,mysql里面有一个health_check表,每次记录下更新的service_id 和更新时间。这样生成binlog之后,binlog在从库上也记录下检测的时间。而不是同时修改同一行导致写入失败。这种检测方式也有一个问题:如果cpu运行达到100%,响应已经很慢了,需要切库,但是这个检测的更新刚好有获取到cpu执行了,就会认为没问题。

从内部统计mysql里面有一个表统计了所有请求的耗时等信息,但是如果全部开启。那么大概会损失10%的性能,可以根据里面的响应时间设置阈值。

2、最佳方案

建议使用3update的方法+部分的统计4

相关推荐
老邓计算机毕设3 分钟前
SSM智慧社区家政服务系统80q7o(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架
松涛和鸣1 小时前
72、IMX6ULL驱动实战:设备树(DTS/DTB)+ GPIO子系统+Platform总线
linux·服务器·arm开发·数据库·单片机
likangbinlxa1 小时前
【Oracle11g SQL详解】UPDATE 和 DELETE 操作的正确使用
数据库·sql
r i c k2 小时前
数据库系统学习笔记
数据库·笔记·学习
野犬寒鸦2 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习
IvorySQL3 小时前
PostgreSQL 分区表的 ALTER TABLE 语句执行机制解析
数据库·postgresql·开源
·云扬·3 小时前
MySQL 8.0 Redo Log 归档与禁用实战指南
android·数据库·mysql
IT邦德3 小时前
Oracle 26ai DataGuard 搭建(RAC到单机)
数据库·oracle
惊讶的猫3 小时前
redis分片集群
数据库·redis·缓存·分片集群·海量数据存储·高并发写
不爱缺氧i4 小时前
完全卸载MariaDB
数据库·mariadb