一、分析
1、调用方法调用中具体执行耗时、可以用Spring.util.StopWatch.
2、分析具体耗时方法的实现
3、在重构一个方法时:
a、首先分清并列举该方法乃至功能涉及的功能点
b、列举重构后针对功能点的测试用例。
c、重构后对功能点进行测试
二、处理
1、数据库相关
a、方法中包含多次与数据库交互的
b、循环中与数据库交互、这会造成耗时线性增长。
2、两个需要内容同步的方法(使用监听或观察者的),可以采取异步执行
3、循环中的任务执行耗时的,可以采用多线程执行
4、在一个请求中多次用到的数据可以用threadlocal保存起来
5、使用某类实例较多(且每次都要new)则可以考虑使用对象池。
6、减少不必要的查询结果。
三、处理
1、业务相关的优先级可以往后排
四、多线程提升程序的处理能力
1、多线程是要注意threadlocal变量的使用,尤其是spring中autowired的都是隐形的threadlocal修饰。
2、在执行过程中新建线程或异步时,这些是无法使用的其他线程的公用变量的。
五、缓存技术减少程序的处理任务
缓存:threadlocal线程缓存,对象缓存,类缓存(static),上下文(整个系统),分布式(redis等中间件)
六、总结来说
1、优化有很多个方面和层次:数据库层>JVM层>代码层(多线程>缓存)>分布式缓存>分布式框架
如何优化一个系统(方法篇)
最新推荐文章于 2024-09-03 19:53:31 发布