博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
性能瓶颈的分类
阅读量:5918 次
发布时间:2019-06-19

本文共 820 字,大约阅读时间需要 2 分钟。

hot3.png

根据木桶原理,系统的最终性能取决于系统中性能表现最差的组件。因此,为了提升系统整体性能,必须对系统中表现最差的组件进行优化,而不是对系统中表现良好的组件进行优化。

根据应用的特点不同,任何计算机资源都有可能成为系统瓶颈。其中,最有可能成为系统瓶颈的计算资源如下。

磁盘I/O:由于磁盘I/O读写的速度要比内存慢很多,程序在运行过程中,如果需要等待磁盘I/O完成,那么低效的I/O操作会拖累整个系统。

网络操作:对网络数据进行读写的情况与磁盘I/O类似。由于网络环境的不确定性,尤其是对互联网上数据的读写,网络操作的速度可能比本地磁盘I/O更慢。因此,如不加特殊处理,也极可能成为系统瓶颈。

CPU:对计算资源要求较高的应用,由于其长时间、不间断地大量占用CPU资源,那么对CPU的争夺将导致性能问题。如科学计算、3D渲染等对CPU需求旺盛的应用。

异常:对Java应用来说,异常的捕获和处理是非常消耗资源的。如果程序高频率地进行异常处理,则整体性能便会有明显下降。

数据库:大部分应用程序都离不开数据库,而海量数据的读写操作可能是相当费时的。而应用程序可能需要等待数据库操作完成或者返回请求的结果集,那么缓慢的同步操作将成为系统瓶颈。

锁竞争:对高并发程序来说,如果存在激烈的锁竞争,无疑是对性能极大的打击。锁竞争将会明显增加线程上下文切换的开销。而且,这些开销都是与应用需求无关的系统开销,白白占用宝贵的CPU资源,却不带来任何好处。

内存:一般来说,只要应用程序设计合理,内存在读写速度上不太可能成为性能瓶颈。除非应用程序进行了高频率的内存交换和扫描,但这些情况比较少见。使内存制约系统性能的最可能的情况是内存大小不足。与磁盘相比,内存的大小似乎小的可怜,这意味着应用软件只能尽可能将常用的核心数据读入内存,这在一定程度上降低了系统性能。

转载于:https://my.oschina.net/henrydong/blog/134582

你可能感兴趣的文章
统计之 - 相关性(Correlation)分析
查看>>
node环境下配置ES6在WebStorm中的执行环境
查看>>
2011年网络营销总结 缺少让人尖叫的案例
查看>>
Solaris 10u11 安装python2.7.10
查看>>
Office Web Apps证书的申请步骤讲解
查看>>
Global Azure上创建、配置、管理SQL Server信息
查看>>
常用端口号大全(详细)
查看>>
MySQL 8.0新特性--Descending Indexes(六)
查看>>
我的Android进阶之旅------>Android 关于arm64-v8a、armeabi-v7a、armeabi、x86下的so文件兼容问题...
查看>>
我的友情链接
查看>>
前端面试大全(四)
查看>>
IT人为什么难以拿到高薪?【转帖】
查看>>
工欲善其事必先利其器SecureCRT+VMware® Workstation_学习笔记
查看>>
Mac系统Git生成ssh公钥
查看>>
Runtime&json->model
查看>>
vim命令用法
查看>>
文件和目录权限chmod,更改所有者和所属组chown,umask,隐藏权限lsattr/chattr
查看>>
IOS精品源码,仿探探UIButton封装iOS提示弹框迅速引导页自定义导航栏
查看>>
阿里PB级Kubernetes日志平台建设实践
查看>>
springboot+redis项目实战
查看>>