mysql状态监听_Mysql数据状态监听探讨(攒人品)_MySQL
bitsCN.com
年会前攒人品,你懂得!
应用场景:
长时间运行程序,需要几乎整表查询Mysql,还得在可容忍范围内响应数据变化。
方案一:通过Mysql自带的表更新时间
查询方案:SELECT TABLE_NAME,UPDATE_TIME FROM INFORMATION_SCHEMA.tables WHERE TABLE_SCHEMA='Palas_V4';
存在问题:innodb 不支持,需要更换数据库引擎;只支持表级判断(可以接受)。
优点:查询速度快。
变种解决方案:1、创建触发器,在表执行update/insert/delete 时更新UPDATE_TIME为当前时间戳;2、在数据库访问接口处增加程序逻辑来更新该时间戳。
方案二:在所有行增加更新时间戳字段
查询方案:判断是否修改只需查询该表最大的updatetime,增量更新仅需要查询大于上次查询时间的数据。
存在问题:表每行会增加4bytes的空间消耗,更新时间戳问题可通过mysql自身解决;不支持delete操作,如要删除需要增加是否有效字段来改变状态。
优点:可以做到行级的更新。
方案三:读取Mysql文件的系统修改时间
查询方案:获取E:/SqlData/data/Palas_V4/ Media.frm 的系统修改时间
存在问题:需要在Mysql所在服务器操作,或者需要远程访问它的权限,可能导致安全问题;只支持表级判断。
优点:速度快,不需要额外表空间或增加mysql负载。
变种解决方案:1、在Mysql所在服务器创建监控服务提供数据库状态信息。
方案选型:
优缺点分析:
方案一与二均需对数据库做出相应修改,一所做修改对业务逻辑不会有影响,但对Mysql的操作会增加一倍(实际修改需要8(可能是4)个字节每次的数据量)无网络传输;程序实现逻辑简单;在数据修改量不大的情况话对性能几乎没有影响,但修改后查询开销大。方案二对表空间的增长会变大,对业务逻辑会有较小的影响(不再支持删除),部分表还需要增加字段判断状态,修改后查询开销较小。方案三性能与一相差不大,但需要额外编程提供状态查询,时间和硬盘IO会增大(不显著)。
选型:
根据实际情况,排除暂时不会遇到的问题,优先级排列如下:
方案三 -> 方案二 –> 方案一 (方案一排最后是由于太多触发器会导致表维护困难,更新引擎将使数据库性能降低)
Mysql 开启独立表空间:
1. 停掉mysql: /etc/init.d/mysqld stop
2. 改my.cnf的配置文件: innodb-file-per-table=1
3. 备份使用innodb引擎的数据库: mysqldump -u tg -p tg >/home/6fan/tg.sql;
4. 删除使用innodb的数据库,以及日志文件 。如果不删除使用innodb的数据库文件夹,启动不了innodb引擎。
5. 启动mysql : /etc/init.d/mysqld start
6. 导入数据库: mysql -u root -p < /home/6fan/tg.sql
有图形化管理工具的在修改配置文件后直接备份需要监听的数据库,然后删除后恢复也是可以的。
构建文件监听与数据提供服务:
1、 在mysql服务器开启文件监听服务,提供get put方法(仅提供状态,数据需要自己查)
2、 Get方法在全局数据提供服务启动时调用,Put方法为主动向接受者声明哪些需要同步
构建全局数据提供服务:(Web Api 支持json和xml格式)
1、 启动时使用get获取所有文件状态;
2、 接受put的数据以启用数据更新(可改为查询时主动get);
3、 有调用者时返回数据;
4、 对数据进行压缩处理;保存以便传输
本文来自 NewIdea 的博客,作者 ziyunhx 。
mysql状态监听_Mysql数据状态监听探讨(攒人品)_MySQL相关推荐
- 【Android 电量优化】电量优化 ( 充电状态获取 | 主动获取充电状态 | 广播接受者监听充电状态 | 被动获取充电状态 | 注册空广播接受者获取历史广播 )
文章目录 一.获取充电状态 二.被动获取充电状态 三.主动获取充电状态 参考 Google 官方文档 : 优化电池续航时间 一.获取充电状态 在应用中执行某些操作 , 如软件云端备份 , 从服务器端获 ...
- Windows Phone 8 获取与监听网络连接状态
现在的只能手机对网络的依赖程度都很高,尤其是新闻.微博.音乐.视频.VOIP通话.游戏等 事实性高的信息类应用,但是目前国内的信息费仍然高居不下,更多的用户只有在 WIFI 的环境下才愿意进行大数据量 ...
- 基于腾讯 x5 开源库,提高 webView 开发效率,大概要节约你百分之六十的时间成本。该案例支持处理 js 的交互逻辑且无耦合、同时暴露进度条加载进度、可以监听异常 error 状态、支持视频播放
YCWebView 项目地址:yangchong211/YCWebView 简介: 基于腾讯 x5 开源库,提高 webView 开发效率,大概要节约你百分之六十的时间成本.该案例支持处理 js 的交 ...
- telegraf监控mysql数据库_influxdb+grafana+telegraf 监听性能数据 (完整详细版)
转载自 https://testerhome.com/topics/21113 概述 关于influxdb+grafana的文章,谷歌百度一大把,但是99.9%不知所云,不是这边漏一点就是那边漏一点. ...
- Android 监听 WiFi 开关状态
Android 监听 WiFi 开关状态 转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/70854309 本文出自[赵彦军的博客] ...
- java wifi监听_Android 监听 WiFi 开关状态
Android 监听 WiFi 开关状态 WifiSwitch_Presenter 源码: package com.yiba.wifi.sdk.lib.presenter; import androi ...
- android 软键盘 状态,Android监听软键盘状态
监听软键盘隐藏或显示,代码如下: /** * 监听软键盘状态 */ private void listenerInput() { final LinearLayout ll_main = (Linea ...
- android监听卡1电话,Android 监听 SIM 卡状态
判断是否包含 SIM 卡 /** * 判断是否包含SIM卡 * * @return 状态 */ public static boolean hasSimCard(Context context) { ...
- Android 监听来去电状态的实现
本文授权发布公众号[刘桂林],星球[Hi Android] 在Android中我们想要实现监听电话状态一般都会通过TelephonyManager来监听,他提供了一个PhoneStateListene ...
最新文章
- Dojo学习13 dijit.Tree 动态添加节点之一
- Github无法加载或不显示图片问题
- 使用selenium爬取某东的手机商品信息
- VS2010中C#添加图片(资源)
- oracle财务软件凭证打印,金算盘财务软件后台数据库为Oracle
- Linux内核里的“智能指针” (续)
- [css] 你是怎样对css文件进行压缩合并的?
- 创建oracle 数据库表空间,角色,用户的sql语句
- centos 下安装 mysql 5.6
- 【PostgreSQL-9.6.3】触发器概述(普通触发器)
- Mac M1运行matlab卡,解决办法
- Java、JSP宾馆入住管理系统的设计与实现
- uniapp 生成 海报
- 区块链安全保卫战:三分技术,七分管理
- MediaSession原理以及使用
- 如何写好技术简历 —— 实例、模板及工具
- 计算机图形学VC 配置,计算机图形学(VC++实现)(第2版)
- 计算机课联网,老师上网课需要什么设备
- SpringBoot中shiro 添加sessionManager和cacheManager
- C#串口通讯+BigEndian+Little-Endian(大端和小端方案)