当前位置: 首页 > news >正文

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

前言

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


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

  • 前言

1、排查问题的方法

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

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

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

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

2、最佳方案

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

http://www.dtcms.com/a/306180.html

相关文章:

  • Python处理JSON和Excel文件的转换
  • 2025年6月电子学会青少年软件编程(C语言)等级考试试卷(一级)
  • Elasticsearch 8.19.0 和 9.1.0 中 LogsDB 和 TSDS 的性能与存储改进
  • 分布式搜索和分析引擎Elasticsearch实战指南
  • Expected one result (or null) to be returned by selectOne(), but found: 2
  • 《从 Vim 新手到“键圣”:我的手指进化史》
  • ISO 26262功能安全软硬件接口定义方法
  • java web jsp 静态页面和动态页面对比。动态页面实现分页效果
  • 不同环境安装配置redis
  • 基于 Hadoop 生态圈的数据仓库实践 —— OLAP 与数据可视化(四)
  • 第2课:几何数学
  • spring学习笔记一
  • 如何理解时间复杂度
  • 【世纪龙科技】比亚迪电动汽车技术仿真教学软件-助力人才培养
  • idea 集成飞算Java AI 教程
  • Mac下的Homebrew
  • 《Sentinel服务保护实战:控制台部署与SpringCloud集成指南》
  • Docker-01.Docker课程介绍
  • 【异世界历险之数据结构世界(冒泡、选择、快速排序)】
  • OpenCV图像缩放:resize
  • 【c++】leetcode763 划分字母区间
  • Ganttable 时间仪表盘
  • java~单例设计模式
  • 小架构step系列30:多个校验注解
  • 「Linux命令基础」压缩文件
  • ica1靶机攻略
  • iOS电池寿命与App能耗监测实战 构建完整性能监控系统
  • MSVC编译KDChart过程
  • IFCVF驱动+vhost-vfio提高虚拟机网络性能
  • BWCTAKC11X64G佰维/BIWIN存储容量为64GB