我的编程空间,编程开发者的网络收藏夹
学习永远不晚

常用的性能优化手段有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

常用的性能优化手段有哪些

这篇文章主要介绍“常用的性能优化手段有哪些”,在日常操作中,相信很多人在常用的性能优化手段有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”常用的性能优化手段有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

SQL 优化

当你开发的接口响应时间超过了 200ms 的时候就得优化了,当然 200ms 不是绝对值,具体还是看应用场景。以 App 举例,进一个页面调用 5  个接口(题外话:也可以做聚合),那么总共就是 1s 的时间,对用户来说体验还算可以,当然是越快响应越好。

接口耗时 200ms,其中占大头的还是对数据库的操作,一个接口中会有 N 次数据库操作。所以优化 SQL 的速度优先级是最高的,大量的慢 SQL  会拖垮整个系统。

关于 SQL 的优化不是本文的重点,大部分慢 SQL 还是跟各位平时开发时的习惯有关系。大部分在写 SQL  的时候不太会去考虑性能,只要写出来就可以了,join 随手就来,也不梳理查询字段,不加索引,刚开始上线没问题,等到并发量,数据量起来的时候就凉凉了。

关于数据库的使用规范大家可以参考下这篇文章:老大让我整理下公司内部mysql使用规范,分享给大家

当数据量大了后肯定要做读写分离和分库分表的,这也是优化的必经之路。

  • 读写分离

  • 分库分表

减少重复调用

性能不好的另一个致命问题就是重复调用,相同的逻辑在不同的方法中重复对数据库查询,重复调用 RPC 服务等。

比如下面的代码:

skuDao.querySkus(productId).stream().map(sku -> {    skuDao.getById(sku.getId()); })

明明数据已经查询出来了,又根据 ID  重新去查询了一次,数量越多,浪费的时间越多。这里只是举例,我相信在真实的项目中大量存在重复查询的情况,之前我还写过一篇文章,讲解如何解决这种重复查询问题,感兴趣的可以查看这篇文章:简直骚操作,ThreadLocal还能当缓存用

按需查询

很多业务逻辑不复杂的功能,却响应很慢。往往都是写代码的时候没有思考,随便就调用一些已经存在的方法,导致整体响应变慢,总结起来就是:性能问题大部分都是代码写出来的。

说个场景,大家肯定都见到过。参数是一个商品 ID,  功能是上架商品,需要进行状态的判断,符合条件才能上架。这个场景下只需要获取商品的状态进行判断即可,有的时候你看到的代码往往都是下面的方式:

GoodsDetail goods = goodsService.detail(id); if (goods.getStatus() == GoodsStatusEnum.XXXX) {  }

detail 中有大量的逻辑,除了基本的商品信息,还有很多其他的内容,这就是慢的原因。

并行调用

针对一个接口,如果设计到多个内部 RPC 服务或者多个外部接口,在接口之间没有关联关系的情况下,我们可以采用并行调用的方式来提高性能。

CompletableFuture 就非常适合并行调用的场景,关于 CompletableFuture 的使用本文不做详细说明,做 Java  的都要会用。

除了 CompletableFuture 之外,对于集合类的处理,可以用 parallelStream 来实现并行调用。

在微服务中有一层专门用于聚合 API,  聚合层就非常适合并行调用,一个功能或者一个页面展示会涉及到多个接口,通过聚合层在后端进行接口的聚合和数据的裁剪,一起响应给前端。

上缓存

缓存也是优化中最常用的,效果提升最明显的,成本也不大。对于缓存,也不要滥用,不是所有场景都可以靠堆缓存来提高性能的。

首先对于实时性要求不高的业务场景可以优先使用缓存,也不用太考虑更新的问题,自然过期就行。

实时性要求高的业务场景,用缓存一定要有完整的缓存更新机制,否则很容易造成业务数据和缓存数据不一致的情况。

建议的做法是订阅 binlog  来统一更新缓存,不要在代码中去更新或者失效缓存,简单的场景还好,入口就那几个,问题不大。有些数据在多个场景下使用,需要更新的入口太多了,

异步处理

有些逻辑,不需要实时反馈给用户那就可以采用异步的方式在后台进行处理。

异步处理的方式最常见的就是将任务加到线程池中进行处理,线程池需要考虑容量以及对一些指标的监控,相关的文章可以查看我的这篇:一时技痒,撸了个动态线程池,源码放Github了

除了一些指标的监控,线程池的使用另一个需要关注的问题就是任务的持久化。如果你的数据本来就是存储好了的,然后读取出来通过线程池去执行是没问题的。如果是没有持久化直接丢入线程池中进行执行,就有可能出现丢失的情况,比如服务重启之类的场景。

关于持久化,无论是线程池还是 EventBus 这种,都会遇到,所以针对异步的场景我建议大家使用消息队列比较好。

消息队列可以存储任务信息,保证不会丢失。单独消费队列的消息进行逻辑处理,如果想提高消费速度,也可以在队列的消费方使用线程池进行多线程消费,多线程消费也要避免消息丢失的情况,可以查看我的这篇文章:嘘!异步事件这样用真的好么?

JVM 参数调整

JVM 参数的调整,一般情况下我们都不用怎么去调整。偶尔有些代码写的不好,导致内存溢出了,这个时候会去做一些调整和优化代码。

参数调整主要是去降低 GC 的导致的停顿问题,如果你的程序一直在 GC, 一直在停顿,你的接口自然就慢了。

只要没有频繁的 Full GC,在优化这块 JVM 的参数调整可以最后再做,优先以 SQL 优化这些为主。

加机器

加机器是最后的终极大招了,并发量上去的时候,你在怎么优化单机器和单数据库抗并发能力也是有限的,这个时候只能水平扩展了。

如果是创业初期,并且在快速发展,加机器是最直接的优化方式了,虽然说成本上去了,但是开发资源也是成本,节约下来可以实现更多的业务需求。等到中期稳定了再考虑架构,性能方面整体的优化和重构。

就像玩游戏一样,有装备的玩家才能所向睥睨啊,对于后端应用来说也是一样,高配的机器,高配的数据库配置,高配的缓存等。

到此,关于“常用的性能优化手段有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

常用的性能优化手段有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

常用的Android性能优化工具有哪些

常用的Android性能优化工具有:1. Android Profiler:Android Studio自带的性能分析工具,可以监测应用的CPU、内存和网络等性能指标,帮助开发者分析性能瓶颈并进行优化。2. LeakCanary:用于检测内
2023-10-12

程序性能优化有哪些常见的方法?

程序性能优化方法包括:算法优化:选择时间复杂度更低的算法,减少循环和条件语句。数据结构选择:根据数据访问模式选择合适的数据结构,如查找树和哈希表。内存优化:避免创建不必要对象,释放不再使用的内存,使用内存池技术。线程优化:识别可并行化任务,
程序性能优化有哪些常见的方法?
2024-05-09

PHP7有哪些性能优化

这篇文章主要介绍“PHP7有哪些性能优化”,在日常操作中,相信很多人在PHP7有哪些性能优化问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP7有哪些性能优化”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-06-17

Golang 技术性能优化中的常见陷阱有哪些?

避免 go 语言性能优化中的陷阱:过早优化:在基准测试确定瓶颈前避免优化。过度使用 goroutine:明智地使用 goroutine,考虑替代的并发机制。不正确的内存分配:避免重复分配,考虑使用内存池。不恰当的同步:仅同步必要的代码块,使
Golang 技术性能优化中的常见陷阱有哪些?
2024-05-11

Python性能优化的建议有哪些

这篇文章主要介绍“Python性能优化的建议有哪些”,在日常操作中,相信很多人在Python性能优化的建议有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python性能优化的建议有哪些”的疑惑有所帮助!
2023-06-02

jQuery性能优化的方法有哪些

今天小编给大家分享一下jQuery性能优化的方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、选择器性能优化建议1
2023-07-04

php性能优化的方法有哪些

有以下几种常用的 PHP 性能优化方法:1. 使用缓存:通过使用缓存技术,将一些常用的计算结果或数据库查询结果缓存起来,减少重复的计算和数据库查询,从而提高性能。2. 优化数据库查询:尽量减少数据库查询次数,可以通过合并多个查询、使用索引、
2023-09-26

docker优化性能的技巧有哪些

以下是一些优化Docker性能的技巧:使用多阶段构建:多阶段构建可以减小镜像的大小,从而提高构建和部署的性能。使用合适的基础镜像:选择一个适合你的应用程序的基础镜像,这样可以减少不必要的依赖和组件,从而提高性能。优化Dockerfile:在
2023-10-25

mongodb性能优化的技巧有哪些

以下是一些MongoDB性能优化的技巧:索引优化:使用合适的索引可以大大提高查询性能。使用explain()命令来分析查询性能,并使用适当的索引来优化查询。适当的数据建模:正确的数据建模可以提高查询性能。根据查询需求和数据访问模式来设计数据
2023-10-25

laravel性能优化的方法有哪些

使用缓存:Laravel提供了多种缓存驱动,如Redis、Memcached等,可以将经常访问的数据进行缓存,减少数据库的查询次数,提高性能。使用数据库索引:合理地创建索引可以加快查询速度,减少数据库的负载。避免频繁的数据库查询:可以通
laravel性能优化的方法有哪些
2023-10-28

uniapp性能优化的方法有哪些

减少页面 DOM 元素数量:避免页面中存在过多的 DOM 元素,可以减少页面渲染的复杂度,提高页面加载和渲染的速度。使用合适的图片格式和大小:在加载图片时,尽量选择合适的图片格式(如 WebP 格式)和适当的图片大小,以减少图片加载所占用的
uniapp性能优化的方法有哪些
2024-03-15

centos性能优化的方法有哪些

使用最新的稳定版本的CentOS操作系统,以获得最新的性能优化和修复。硬件优化:确保硬件设备(CPU、内存、硬盘)能够满足系统的需求,并通过升级硬件来提升性能。关闭不必要的服务和进程:通过禁用不需要的服务和进程,可以释放系统资源,提高性能。
2023-10-23

java性能优化常见的垃圾收集器有哪些

本文小编为大家详细介绍“java性能优化常见的垃圾收集器有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“java性能优化常见的垃圾收集器有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。常见的垃圾回收器和
2023-07-02

编程热搜

目录