Chao Qun
弹一曲高山流水,念一人痴笑暧昧,叹一世往事轮回,人生几回醉,此生待会。

专注后端架构

接口性能分析与优化

接口为何如此慢?

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

 

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

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

 

 

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

 

 

 

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

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

 

 

优化方案

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

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

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

 

So Now

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

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

 

posted @ 2017-01-20 16:02  王子爱公主  阅读(507)  评论(0编辑  收藏  举报
微信打赏