接口为何如此慢?
“闲”来无事,发现创单接口好慢,很不爽。。。
本地启动VS性能分析器,模拟非第一次调用,生成性能分析报告。
1.CacheCommon.GetCommonDest方法被调用两次,合计耗时占接口耗时的一半。
查看代码,缓存的存取逻辑有问题,每次都从db读取。
2.从db读取的时候,耗时点主要有两个:
1)获取查询结果的耗时主要在Fill结果集
2)填充实体类的耗时主要在对属性赋值
优化方案
1.在CommAPI中增加接口获取指定的机场信息,数据缓存到Redis,相关代码中调整(耗时减少50%左右)。
1.考虑改进系统默认的填充结果集方法(现有场景下改进有限)。
2.考虑采用强类型委托对属性赋值(比现有填充方式耗时大幅减少)。
So Now
让负责该接口的同学修改后,创单在秒级别实现了。
不过N久后重新看这个接口,有些地方又被写坏了。。。