返回顶部
首页 > 资讯 > 精选 >怎么制定Java性能调优标准
  • 526
分享到

怎么制定Java性能调优标准

2023-06-05 04:06:53 526人浏览 安东尼
摘要

这篇文章主要为大家展示了“怎么制定Java性能调优标准”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么制定Java性能调优标准”这篇文章吧。为什么要做性能调优?一款线上产品如果没有经过性能测试

这篇文章主要为大家展示了“怎么制定Java性能调优标准”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么制定Java性能调优标准”这篇文章吧。

为什么要做性能调优?

一款线上产品如果没有经过性能测试,那它就好比是一颗定时 什么时候开始介入调优?

解决了为什么要做性能优化的问题,那么新的问题就来了:如果需要对系统做一次全面的性能监测和优化,我们从什么时候开始介入性能调优呢?是不是越早介入越好?

其实,在项目开发的初期,我们没有必要过于在意性能优化,这样反而会让我们疲于性能优化,不仅不会给系统性能带来提升,还会影响到开发进度,甚至获得相反的效果,给系统带来新的问题。

我们只需要在代码层面保证有效的编码,比如,减少磁盘 I/O 操作、降低竞争的使用以及使用高效的算法等等。遇到比较复杂的业务,我们可以充分利用设计模式来优化业务代码。例如,设计商品价格的时候,往往会有很多折扣活动、红包活动,我们可以用装饰模式去设计这个业务。

在系统编码完成之后,我们就可以对系统进行性能测试了。这时候,产品经理一般会提供线上预期数据,我们在提供的参考平台上进行压测,通过性能分析、统计工具来统计各项性能指标,看是否在预期范围之内。

在项目成功上线后,我们还需要根据线上的实际情况,依照日志监控以及性能统计日志,来观测系统性能问题,一旦发现问题,就要对日志进行分析并及时修复问题。

有哪些参考因素可以体现系统的性能?

上面我们讲到了在项目研发的各个阶段性能调优是如何介入的,其中多次讲到了性能指标,那么性能指标到底有哪些呢?

在我们了解性能指标之前,我们先来了解下哪些计算机资源会成为系统的性能瓶颈。

CPU:有的应用需要大量计算,他们会长时间、不间断地占用 CPU 资源,导致其他资源无法争夺到 CPU 而响应缓慢,从而带来系统性能问题。例如,代码递归导致的无限循环,正则表达式引起的回溯,JVM 频繁的 FULL GC,以及多线程编程造成的大量上下文切换等,这些都有可能导致 CPU 资源繁忙。

内存:Java 程序一般通过 JVM 对内存进行分配管理,主要是用 JVM 中的堆内存来存储 Java 创建的对象。系统堆内存的读写速度非常快,所以基本不存在读写性能瓶颈。但是由于内存成本要比磁盘高,相比磁盘,内存的存储空间又非常有限。所以当内存空间被占满,对象无法回收时,就会导致内存溢出、内存泄露等问题。

磁盘 I/O:磁盘相比内存来说,存储空间要大很多,但磁盘 I/O 读写的速度要比内存慢,虽然目前引入的 SSD 固态硬盘已经有所优化,但仍然无法与内存的读写速度相提并论。网络:网络对于系统性能来说,也起着至关重要的作用。如果你购买过云服务,一定经历过,选择网络带宽大小这一环节。带宽过低的话,对于传输数据比较大,或者是并发量比较大的系统,网络就很容易成为性能瓶颈。

异常:Java 应用中,抛出异常需要构建异常栈,对异常进行捕获和处理,这个过程非常消耗系统性能。如果在高并发的情况下引发异常,持续地进行异常处理,那么系统的性能就会明显地受到影响。

数据库:大部分系统都会用到数据库,而数据库的操作往往是涉及到磁盘 I/O 的读写。大量的数据库读写操作,会导致磁盘 I/O 性能瓶颈,进而导致数据库操作的延迟性。对于有大量数据库读写操作的系统来说,数据库的性能优化是整个系统的核心。

锁竞争:在并发编程中,我们经常会需要多个线程,共享读写操作同一个资源,这个时候为了保持数据的原子性(即保证这个共享资源在一个线程写的时候,不被另一个线程修改),我们就会用到锁。锁的使用可能会带来上下文切换,从而给系统带来性能开销。jdk1.6 之后,Java 为了降低锁竞争带来的上下文切换,对 JVM 内部锁已经做了多次优化,例如,新增了偏向锁、自旋锁、轻量级锁、锁粗化、锁消除等。而如何合理地使用锁资源,优化锁资源,就需要你了解更多的操作系统知识、Java 多线程编程基础,积累项目经验,并结合实际场景去处理相关问题。

了解了上面这些基本内容,我们可以得到下面几个指标,来衡量一般系统的性能。

响应时间

响应时间是衡量系统性能的重要指标之一,响应时间越短,性能越好,一般一个接口的响应时间是在毫秒级。在系统中,我们可以把响应时间自下而上细分为以下几种:

怎么制定Java性能调优标准

数据库响应时间:数据库操作所消耗的时间,往往是整个请求链中最耗时的;

服务端响应时间:服务端包括 Nginx 分发的请求所消耗的时间以及服务端程序执行所消耗的时间;

网络响应时间:这是网络传输时,网络硬件需要对传输的请求进行解析等操作所消耗的时间;

客户端响应时间:对于普通的 WEB、App 客户端来说,消耗时间是可以忽略不计的,但如果你的客户端嵌入了大量的逻辑处理,消耗的时间就有可能变长,从而成为系统的瓶颈。

吞吐量

在测试中,我们往往会比较注重系统接口的 TPS(每秒事务处理量),因为 TPS 体现了接口的性能,TPS 越大,性能越好。在系统中,我们也可以把吞吐量自下而上地分为两种:磁盘吞吐量和网络吞吐量。我们先来看磁盘吞吐量,磁盘性能有两个关键衡量指标。

接下来看网络吞吐量,这个是指网络传输时没有帧丢失的情况下,设备能够接受的最大数据速率。网络吞吐量不仅仅跟带宽有关系,还跟 CPU 的处理能力、网卡、防火墙、外部接口以及 I/O 等等紧密关联。而吞吐量的大小主要由网卡的处理能力、内部程序算法以及带宽大小决定。

计算机资源分配使用率

通常由 CPU 占用率、内存使用率、磁盘 I/O、网络 I/O 来表示资源使用率。这几个参数好比一个木桶,如果其中任何一块木板出现短板,任何一项分配不合理,对整个系统性能的影响都是毁灭性的。

负载承受能力

当系统压力上升时,你可以观察,系统响应时间的上升曲线是否平缓。这项指标能直观地反馈给你,系统所能承受的负载压力极限。例如,当你对系统进行压测时,系统的响应时间会随着系统并发数的增加而延长,直到系统无法处理这么多请求,抛出大量错误时,就到了极限。

以上是“怎么制定Java性能调优标准”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: 怎么制定Java性能调优标准

本文链接: https://lsjlt.com/news/241288.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么制定Java性能调优标准
    这篇文章主要为大家展示了“怎么制定Java性能调优标准”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么制定Java性能调优标准”这篇文章吧。为什么要做性能调优?一款线上产品如果没有经过性能测试...
    99+
    2023-06-05
  • 性能调优的标准是什么
    这篇文章主要讲解了“性能调优的标准是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“性能调优的标准是什么”吧!前几天,和一个同学瞎聊,他说,“我们公司的系...
    99+
    2024-04-02
  • 性能调优的通用准则
    一句话: 多加一层,就好了。 比如...
    99+
    2024-04-02
  • 怎么进行Java EE性能测试与调优
    这篇文章主要讲解了“怎么进行Java EE性能测试与调优”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么进行Java EE性能测试与调优”吧!性能测试的目标性能测试不同于功能测试,不是对与...
    99+
    2023-06-17
  • 怎么理解MySQL性能调优
    本篇内容介绍了“怎么理解MySQL性能调优”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!MySQL性能调优...
    99+
    2024-04-02
  • springboot性能调优怎么实现
    要对Spring Boot应用进行性能调优,可以从以下几个方面入手:1. 数据库优化:优化数据库查询语句、创建索引、合理使用缓存、合...
    99+
    2023-09-14
    springboot
  • MongoDB的性能基准测试与调优方法是什么
    MongoDB的性能基准测试与调优方法如下: 性能基准测试: 使用工具如YCSB(Yahoo! Cloud Serving B...
    99+
    2024-05-07
    MongoDB
  • 性能调优之java服务器容器调优详解
    目录1.为什么要进行项目性能调优2.服务容器的性能调优2.1对SpringBoot中切入式的Tomcat调优:优化最大线程数调优说明:调优设置2.2网络IO模型调优调优设置2.3容器...
    99+
    2023-05-16
    Java性能调优 Java服务器 Java服务器容器调优
  • 怎么进行Spark的性能调优
    怎么进行Spark的性能调优,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。0、背景集群部分 spark 任务执行很慢,且经常出错,参数改来改去怎么都无法优化其性能和解决频繁随机...
    99+
    2023-06-19
  • SQLite中怎么进行性能调优
    在SQLite中进行性能调优可以采取以下几种方式: 使用索引:创建合适的索引可以大大提高查询的性能。确保为经常被用于查询条件的列...
    99+
    2024-03-11
    SQLite
  • java equalsignorecase性能怎么优化
    在Java中,可以使用以下方法来优化equalsIgnoreCase的性能:1. 尽量避免在循环中使用equalsIgnoreCas...
    99+
    2023-09-23
    java
  • 优质粘性定位效果:详解标准设计要素
    粘性定位是指网页设计中一种类似于固定导航栏的效果,使得页面在滚动时,导航栏能够始终固定在页面的某个位置上,提供用户快速导航的功能。在现代的网页设计中,粘性定位已经成为一个非常流行的设计趋势,可以提升网站的可用性和用户体验。本文将...
    99+
    2024-01-29
    效果优化 粘性定位 优质设计
  • Couchbase中怎么进行性能调优和优化
    Couchbase是一个高性能的NoSQL数据库,但是在特定情况下可能需要进行性能调优和优化。以下是一些常见的优化和调优方法: ...
    99+
    2024-03-08
    Couchbase
  • 如何监控和调优Oracle的性能指标
    监控和调优Oracle性能指标是保障数据库系统正常运行的重要工作。以下是一些常用的方法: 监控工具:Oracle提供了多种监控工...
    99+
    2024-04-09
    Oracle
  • TFLearn怎么调参优化模型性能
    调参是优化模型性能的重要步骤,可以通过调整不同的超参数来找到最佳的模型配置。在TFLearn中,可以通过以下几种方法来调参优化模型性...
    99+
    2024-04-02
  • Java多线程异步调用性能如何调优
    这篇文章主要介绍“Java多线程异步调用性能如何调优”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java多线程异步调用性能如何调优”文章能帮助大家解决问题。概述大型电商公司的支付聚合服务都有这类的...
    99+
    2023-06-29
  • Word字间距怎么调整为标准
    这篇文章主要讲解了“Word字间距怎么调整为标准”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Word字间距怎么调整为标准”吧!字间距调整为标准的方法:首先打开文本编辑软件,选中想要调节字间...
    99+
    2023-07-02
  • Golang中同步机制的性能表现与性能调优方法
    在Golang中,同步机制的性能表现和调优方法与其它编程语言有所不同。Golang提供了一些原生的同步机制,如互斥锁(Mutex)、...
    99+
    2023-10-08
    Golang
  • 浅谈AIX环境下的Java性能调优
    from IBMJava 性能准则 在编写Java应用程序时,以下是基本的准则: 使用字符串缓冲区而不是字符串连接,当进行连续字符串操作时要避免不必要地创建那些最终必须经过垃圾回收的对象。 避免连续写入 Java 控制...
    99+
    2023-06-03
  • 怎么解析SparkSQL+SequoiaDB 性能调优策略
    这篇文章将为大家详细讲解有关怎么解析SparkSQL+SequoiaDB 性能调优策略,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。下面介绍 Sequoia...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作