接口性能分析与优化

接口为何如此慢?

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

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

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

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

 

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

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

 

优化方案

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

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

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

So Now

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

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

原文地址:https://www.cnblogs.com/LoveOfPrince/p/6323116.html