论系统的木桶理论与性能瓶颈

简介: 论系统的木桶理论与性能瓶颈

在我们实际开发环境中,根据木桶理论,系统的最终性能取决于系统中性能表现最差的组件,因此为了提高整体系统性能,必须对系统中表现最差的组件进行优化,而不是对表现良好的组件进行优化。

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

  • ロ磁盘 IO :由于磁盘 I O 读写的速度要比内存慢很多,程序在运行过程中,如果需 要等待做盘 I O 完成,那么低效的 I O 操作会拖累整个系统。
  • 网络操作:对 网络络数据进行读写的情况与磁盘1/O类似。由于网络环境的不确定性,尤其是对互联网上数据的读写,网络操作的速度可能比本地磁盘 I / O 更慢。因此, 如不加特殊处理,也极可能成为系统瓶颈。
  • CPU :对计算资源要求较高的应用,由于其长时间、不间断地大量占用 CPU 资源,那么对 CPU
    的争夺将导致性能问题。如科学计算、3D渲染等对 CPU 需求旺盛的应用。
  • 异常:对 Java 应用来说,异常的捕获和处理是非常消耗资源的。如果程序高频率 地进行异常处理,则整体性能便会有明显下降。
  • 数据库:大部分应用程序都离不开数据库,而海量数据的读写操作可能是相当费时的。而应用程序可能需要等待数据库操作完成或者返回请求的结果集,那么缓慢的同步操作将成为系统瓶颈。
  • 锁竞争:对高并发程序来说,如果存在激烈的锁竞争,无疑是对性能极大的打。 锁竞争将会明显增加线程上下文切换的开销。而且,这些开销都是与应用需求尤关的系统开销,日自占用宝贵的 CPU 资源,却不带来任何好处。
  • 内存:一般来说,只要应用程序设计合理,内存在读写速度上不太可能成为性能瓶颈。除非应用程序进行了高频率的内存交换和扫描,但这些情况比较少见。便内存制约系统性能的最可能的情况是内存大小不足。与磁盘相比,内存的大小似乎小的可怜,这意味着应用软件只能尽可能将常用的核心数据读入内存,这在一定程度上降低了系统性能。
相关文章
|
小程序 容器 JavaScript
探索uni-app:构建跨平台应用的神奇工具
探索uni-app:构建跨平台应用的神奇工具
|
网络协议 Java 关系型数据库
【Eureka】java.net.ConnectException: Connection refused: connect
【Eureka】java.net.ConnectException: Connection refused: connect
3022 0
|
8月前
|
敏捷开发 存储 SQL
Quick BI × 宜搭:低代码敏捷开发与专业数据分析的完美融合,驱动企业数字化转型新范式
钉钉低代码平台宜搭与瓴羊QuickBI深度融合,提供前端敏捷构建+后端智能决策的解决方案。通过无缝对接的数据收集与分析、一站式数据分析及报表嵌入等功能,实现业务与数据双重赋能。
560 3
replaceAll 的用法总结
replaceAll 的用法总结
|
11月前
|
机器学习/深度学习
 GHSL: 全球1975 年到 2030 年以 5 年间隔建成面积的分布情况(100m)
全球人类住区图层(GHSL)项目提供了1975年至2030年建成面积的分布数据,以每100米网格单元为单位,涵盖建筑总面积及非住宅用途面积。该数据集由欧盟委员会联合研究中心(EC JRC)提供,时间间隔为5年,支持时空分析与预测。详情参见[GHSL 数据包 2023](https://ghsl.jrc.ec.europa.eu/documents/GHSL_Data_Package_2023.pdf?t=1683540422)。
324 7
|
SQL 存储 缓存
SQL Server 内存占用较高 - 清除缓存 或 设置内存最大占用值
SQL Server 内存占用较高 - 清除缓存 或 设置内存最大占用值
1075 0
|
设计模式 前端开发 调度
中介者模式--设计模式
中介者模式--设计模式
185 0
中介者模式--设计模式
|
消息中间件 缓存 NoSQL
Spring Boot+MyBatis+Redis+ActiveMQ+MySQL+Thymeleaf实现简单的高并发点赞功能(下)
Spring Boot+MyBatis+Redis+ActiveMQ+MySQL+Thymeleaf实现简单的高并发点赞功能(下)
653 0
Spring Boot+MyBatis+Redis+ActiveMQ+MySQL+Thymeleaf实现简单的高并发点赞功能(下)
|
人工智能 云计算
易点天下入驻阿里云合作伙伴
易点天下入驻阿里云云代理合作伙伴,与阿里云展开深度全面合作
|
存储 SQL 数据库
sqlserver触发器的使用以及inserted和deleted详解
sqlserver触发器的使用以及inserted和deleted详解
1126 0