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

前言

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


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

1、排查问题的方法

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

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

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

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

2、最佳方案

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

相关推荐
越甲八千9 小时前
async 和 await 详细解析
网络·数据库·tcp/ip
buddieofcugb10 小时前
记一次MySQL数据表误操作修复
mysql
·云扬·10 小时前
MySQL高可用方案全解析:6种主流方案的原理、优缺点与选型指南
数据库·mysql
only-qi10 小时前
深入理解MySQL中的MVCC:多版本并发控制的实现原理
java·数据库·mysql
G皮T10 小时前
【Elasticsearch】查询性能调优(六):track_total_hits 影响返回结果的相关性排序吗
大数据·数据库·elasticsearch·搜索引擎·全文检索·性能·opensearch
夜光小兔纸10 小时前
Oracle 表新增 ID RAW(16) 字段并填充历史数据
数据库·sql·oracle
寂寞恋上夜10 小时前
PRD权限矩阵怎么写:RBAC模型+5个真实案例
数据库·人工智能·矩阵·deepseek ai·markdown转xmind·ai思维导图生成器
科技块儿10 小时前
【离线环境部署】在内网系统中搭建与维护IP离线数据库的完整方案
数据库·网络协议·tcp/ip
秋饼10 小时前
【深度剖析MySQL五大核心模块:从架构到实践】
数据库·mysql·架构
雄鸡三声天下白10 小时前
js复制文本到剪贴板,以及navigator.clipboard 会提示 is undefined
前端·javascript·数据库