zoukankan      html  css  js  c++  java
  • 接口性能分析与优化

    接口为何如此慢?

    “闲”来无事,发现创单接口好慢,很不爽。。。

    本地启动VS性能分析器,模拟非第一次调用,生成性能分析报告。

    1.CacheCommon.GetCommonDest方法被调用两次,合计耗时占接口耗时的一半。

    查看代码,缓存的存取逻辑有问题,每次都从db读取。

     

    2.从db读取的时候,耗时点主要有两个:

    1)获取查询结果的耗时主要在Fill结果集
    2)填充实体类的耗时主要在对属性赋值

     

    优化方案

    1.在CommAPI中增加接口获取指定的机场信息,数据缓存到Redis,相关代码中调整(耗时减少50%左右)。

    1.考虑改进系统默认的填充结果集方法(现有场景下改进有限)。

    2.考虑采用强类型委托对属性赋值(比现有填充方式耗时大幅减少)。

    So Now

    让负责该接口的同学修改后,创单在秒级别实现了。

    不过N久后重新看这个接口,有些地方又被写坏了。。。

  • 相关阅读:
    with异常
    内建函数的重写
    布尔测试函数重写
    函数重写
    类中的对象属性管理函数
    类中的迭代器__iter__
    多继承
    多态
    封装
    深入理解Java:类加载机制及反射
  • 原文地址:https://www.cnblogs.com/LoveOfPrince/p/6323116.html
Copyright © 2011-2022 走看看