情境还原:

公司一项目新上线,刚上线的第2天,在后台发现数据库服务器与IIS服务器的网络IO出现瓶颈,1GB的网络带宽,占用了70%-100%,也就是每秒传输数据700MB-1GB,数据库使用内存高达21GB。

IIS服务器CPU使用率时常爆至80%-90%,导致网站频频出现连接超时。

原因:晚上只好暂时关闭网站,进行服务器维护,作全面的检查跟踪,发现是一句Select语句导致:
Select * From Table1
这条语句,语法是没问题的,但在应用上出了问题。Table1存储的是10多万行数据,表数据每天都会上万的增长。
为了统计总行数,频频调用这语句,每秒刷新不低于1000次。
也因此导致网络出现瓶颈。

解决:后面把Select语句改成

复制代码 代码如下:
Select Count(*) from Table1


即可解决问题,网络 IO数据马上降至10MB以下,数据库使用内存也保持在预计范围12GB。

看似非常简单的问题,其实不然。解决这问题,所花的时间周期是6小时,检查问题使用1小时,修改代码使用5小时。

更多相关文章

  1. Android(安卓)-- Android(安卓)JUint 与 Sqlite
  2. android 当系统存在多个Launcher时,如何设置开机自动进入默认的La
  3. Android(安卓)SQLiteDatabase的使用
  4. android 通话记录次数
  5. Android(安卓)SQLiteDatabase的使用
  6. android实现关键字搜索功能
  7. 我的android 第14天 - 使用SQLiteDatabase操作SQLite数据库
  8. Android(安卓)编码规范
  9. android contentProvider例子

随机推荐

  1. android fragment执行流程
  2. 如何在Android真机上检测是否有Google Ma
  3. Android layout xml总结(2)
  4. 整理 酷炫 Android、Flutter 开源UI框架
  5. Android---Menu
  6. android 2D教程精华集合贴
  7. android各种广播简介
  8. 【转】每个Android开发者都应该了解的资
  9. android设置全屏以及解决设置全屏无效的
  10. android 权限配置和测试环境配置