当前位置:首页 » 数据仓库 » 数据库突然变慢
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

数据库突然变慢

发布时间: 2022-10-05 01:04:49

Ⅰ oracle数据库执行sql很慢怎么回事

一条sql突然执行变慢,耗时9秒,应用是不能改的,只能从数据库方面下手解决
步骤思路:
1:查看sql是否走索引
2:查看索引是否失效
3:hint 强制走索引(只是用来查看hint状态下,查询是否更改,应用是不能改的)
4:收集该表所有信息(包括索引)
5:分析该表所有信息(包括索引)
6:再次执行并查看
注意:哪个用户执行较慢,就用哪个用户进行操作,这样才准确

Ⅱ 关于MYSQL服务器突然变慢的问题

MySQL 在崩溃恢复时,会遍历打开所有 ibd 文件的 header page 验证数据字典的准确性,如果 MySQL 中包含了大量表,这个校验过程就会比较耗时。MySQL 下崩溃恢复确实和表数量有关,表总数越大,崩溃恢复时间越长。另外磁盘 IOPS 也会影响崩溃恢复时间,像这里开发库的 HDD IOPS 较低,因此面对大量的表空间,校验速度就非常缓慢。另外一个发现,MySQL 8 下正常启用时居然也会进行表空间校验,而故障恢复时则会额外再进行一次表空间校验,等于校验了 2 遍。不过 MySQL 8.0 里多了一个特性,即表数量超过 5W 时,会启用多线程扫描,加快表空间校验过程。

如何跳过校验MySQL 5.7 下有方法可以跳过崩溃恢复时的表空间校验过程嘛?查阅了资料,方法主要有两种:

  1. 配置 innodb_force_recovery可以使 srv_force_recovery != 0,那么 validate = false,即可以跳过表空间校验。实际测试的时候设置 innodb_force_recovery =1,也就是强制恢复跳过坏页,就可以跳过校验,然后重启就是正常启动了。通过这种临时方式可以避免崩溃恢复后非常耗时的表空间校验过程,快速启动 MySQL,个人目前暂时未发现有什么隐患。

2. 使用共享表空间替代独立表空间这样就不需要打开 N 个 ibd 文件了,只需要打开一个 ibdata 文件即可,大大节省了校验时间。自从听了姜老师讲过使用共享表空间替代独立表空间解决 drop 大表时性能抖动的原理后,感觉共享表空间在很多业务环境下,反而更有优势。

临时冒出另外一种解决想法,即用 GDB 调试崩溃恢复,通过临时修改 validate 变量值让 MySQL 跳过表空间验证过程,然后让 MySQL 正常关闭,重新启动就可以正常启动了。但是实际测试发现,如果以 debug 模式运行,确实可以临时修改 validate 变量,跳过表空间验证过程,但是 debug 模式下代码运行效率大打折扣,反而耗时更长。而以非 debug 模式运行,则无法修改 validate 变量,想法破灭。

Ⅲ ASP用ODBC连接Access数据库查询突然变慢

你的数据库链接过多,或者你的数据可比较大!同时加载的东西过多!在与你数据库同目录里会产生一个.ldb后缀的文件!一般情况都会有这个文件,但是这个文件太大就会导致链接过慢,甚至链接不上,你重启后,大量链接关闭,.ldb后缀的文件就没了!所以,又能连接了!
建议数据库不要超过30M ,如果需要的话换成SQL的比较好~

Ⅳ 如果一个linux上的oracle数据库系统突然变慢,你一般从哪里去查找原因

建议10G,linux本身就要2G,oracle4G左右,oracle的联机日志,闪回区增长的很快,所以要为数据文件留足空间
请参考

Ⅳ Access 数据库 运行速度变慢,是什么原因,如何恢复

是什么网络啊 连局域网络的 还是 外部网络 好象是中病毒了 (局域网按理说是中不了病毒的,但是在单位有的人总爱拿U盘等在工作站导资料 就中了)只是电脑慢也说不准有其他毛病,但我建议买本 新出 的〈电脑迷〉等书 用他带的光盘启动电脑在dos下杀毒