zoukankan      html  css  js  c++  java
  • AX2012 ERP “系统慢”调优---跟踪SQL执行,优化代码

    对于用户来说,系统是:慢的,难用的。你看xxx,多好用,多快,多人性化。

    对于AX ERP系统也不例外,调优是必须的,调优一般分为几种:

    1. 系统性监测针对瓶劲环节提升,如:用户--应用服务器--DB--存储,整条链下来,网络慢就提升网络,存储慢就改用SSD,内存不足就加内存。这类问题通常最好解决,花最少的钱就能得到最快的效果,比蚁力神还管用。
    2. 应用程序监测,数据库监测,需要调整系统配置等,如AX有DynamicsPerf,系统有性能监视器,观察系统资源不足发生的时间以及现象,分析具体原因,找出对策。应用程序增加缓存、分布式服务,数据库分区,索引优化,数据预读等,此项工作难度系数较高。
    3. 应用程序代码层级调优,通常用户反馈说我打开XX订单、XX报表非常慢,采用此办法解决比较高效。代码调优的思路很简单,减少数据库IO,给用户必需的数据而不是全部。优秀的程序员与一般程序员的差别,这时就体现。

    对于ERP类以数据库为基础的应用系统,最重要的就是减少SQL 磁盘IO,必要的时候用空间去换时间(例如,临时表、冗余字段)。有过开发二层CS结构MIS系统经验的程序员,对此比较有体会,无经验的建议看看《代码大全》。数据库调优,通常是跟踪长查询与常用数据,长查询进行SQL plan等优化,常用数据放入cache,Oracle横行的年代,数据库调优最高大上。

    这里介绍一个案例,优化第3种,也是最常见的小优化,对用户来说也是最需要的:

    用户反馈表单打开速度非常慢,几乎无法工作。现场看了下,很简单的一个界面,应该是程序设计时逻辑问题,造成多次SQL读IO。验证方法如下:

    1. 配置AX 数据库跟踪
    2. 打开用户界面模拟用户操作
    3. 分析收集的SQL数据

    用Excel导出透视分析下,发现执行2000次的SQL读。根据提示,打开代码查看,

     

    在表行中使用了大量的getxxx,查数据库表返回值。此类字段若有10个,1000行数据,那么就需要执行10000次SQL IO。SQL读同样多的数据,一次IO1000条与每次IO读取一条记录1000次,速度是量级的区别。

    找到问题,修改代码完成。

  • 相关阅读:
    成都的收藏品市场
    微信小程序 如何定义全局函数?
    Linux下 安装VMware Tools工具
    小程序圆角进度条实现方法
    Excel 将换行符替换为空
    再次学习mysql优化
    Subl 命令
    时间见证着—eternal life
    大巧不工web前端设计修炼之道—笔记
    批量更新某字段内容
  • 原文地址:https://www.cnblogs.com/owenwong/p/8666345.html
Copyright © 2011-2022 走看看