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

前言

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


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

1、排查问题的方法

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

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

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

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

2、最佳方案

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

相关推荐
dualven_in_csdn9 小时前
【数据库损坏】关于一次现场数据库损坏
数据库·mysql
锦衣夜行?10 小时前
oracle 未知长度从左到右截取某个字符串
数据库·oracle
han_hanker10 小时前
@JsonIgnore,@JsonProperty, @JsonInclude,@JsonFormat
数据库·oracle
hanyi_qwe10 小时前
MySQL事务基础
数据库·mysql
l1t10 小时前
三种用SQL解决Advent of Code 2022第8题 树顶木屋 的比较和分析
数据库·sql·oracle·duckdb·advent of code
如果未来,10 小时前
Oracle的Redo log和Undo log的区别
数据库·oracle
koping_wu10 小时前
【方案设计】Mysql相关场景
数据库·mysql
杨云龙UP10 小时前
SQL Server小技巧:用 SSMS 重置登录密码,不影响正在运行的系统
运维·服务器·数据库·sql·sqlserver
洁洁!10 小时前
openEuler多样性算力支持实践:容器化多架构应用部署与调度
服务器·数据库·科技·语言模型·数据分析
白露与泡影11 小时前
MySQL整体设计与存储引擎深度剖析:从架构哲学到引擎选型(了解)
数据库·mysql·架构