【深度挖掘Java性能调优】「底层技术原理体系」深入挖掘和分析如何提升服务的性能以及执行效率(引导篇)

深入挖掘和分析如何提升服务的性能以及执行效率

  • 前提介绍
    • 知识要点
  • 性能概述
    • 教你看懂程序的性能
      • 案例介绍
      • 性能指标
      • 性能的参考指标
      • 性能瓶颈(木桶原理)
  • 性能分析三大定律
    • Amdahl定律
      • 计算公式
        • 参数解释
        • 案例分析
        • 定律总结
    • Gustafson定律
      • 与Amdahl定律相对立
      • Gustafson的逻辑公式
    • Sun-Ni定律
      • 深入分析Sun-Ni
        • Sun-Ni定律还强调尽量增大问题规模
      • 定律总结
  • 课外知识普及

前提介绍

本篇文章全面介绍了性能优化技术,旨在帮助读者了解性能概念以及性能优化的基本思路和方法。通过掌握这些内容,读者将能够对性能问题进行系统分析,提升应用程序的性能。

知识要点

  • 评价性能的主要指标
  • 木桶原理的概念及其在性能优化中的应用
  • Amdahl定律的含义
  • 性能调优的层次
  • 系统优化的一般步骤和注意事

性能概述

许多人经常会抱怨程序为什么总是那么慢,它到底在干什么?时间都花到哪里去了?这些问题常常让人困扰。如果你也有类似的经历,那么很可能你的程序存在性能问题。相比功能性问题,性能问题有时可能被忽视或将就过去。然而,严重的性能问题有可能导致程序瘫痪、假死甚至崩溃。因此,了解性能的各种表现和指标非常重要。

教你看懂程序的性能

对于客户端程序而言,低劣的性能将严重影响用户体验。用户会不断抱怨界面停顿、抖动、响应迟钝等问题。

案例介绍

  • 一个典型的例子是Eclipse IDE,在执行Full GC时会导致程序假死,这一问题被许多开发人员所诟病。对于服务器程序来说,性能问题更加重要,许多后台服务器软件都有自己的性能目标。
  • 以Web服务器为例,服务器的响应时间和吞吐量是两个重要的性能指标。当服务器面临巨大的访问压力时,可能会出现响应时间延长、吞吐量下降甚至内存溢出导致崩溃等问题。

上述这两个案例这些都是性能调优需要解决的问题。

性能指标

一般来说,程序的性能可以从以下几个方面来评估:
在这里插入图片描述

  • 执行速度:程序的反应是否迅速,响应时间是否足够短。
  • 内存分配:内存分配是否合理,是否过多消耗内存或存在内存泄漏。
  • 启动时间:程序从启动到正常处理业务所需的时间。
  • 负载承受能力:当系统承受压力增加时,系统的执行速度和响应时间是否能平稳上升。

性能的参考指标

为了进行科学的性能分析,对性能指标进行定量评估是非常重要的。目前,可以用于定量评估的性能指标包括:
在这里插入图片描述

  • 执行时间:代码从开始运行到结束所使用的时间。
  • CPU占用时间:函数或线程占用CPU的时间。
  • 内存分配:程序在运行时所使用的内存空间。
  • 磁盘吞吐量:描述磁盘的使用情况。
  • 网络吞吐量:描述网络的使用情况。
  • 响应时间:系统对某个用户行为或事件做出响应的时间。响应时间越短,性能越好。

处理器(CPU):在需要大量计算的应用中,CPU的处理能力可能成为系统的瓶颈。

内存(RAM):在需要大量数据处理和存储的应用中,内存的容量和速度可能成为系统的瓶颈。

磁盘(硬盘或固态硬盘):在需要频繁进行数据读写的应用中,磁盘的读写速度可能成为系统的瓶颈。

网络带宽:在需要大量数据传输的分布式系统中,网络带宽的限制可能成为系统的瓶颈。

性能瓶颈(木桶原理)

木桶原理又称“短板理论”,其核心思想是:—一只木桶盛水的多少,并不取职决于桶壁上最高的那块木块,而是取决于桶壁上最短的那块,如下图所示:
在这里插入图片描述
根据木桶原理,一个系统的最终性能受限于其性能最差的组件因此,为了提升系统整体的性能,需要集中精力对性能最差的组件进行优化,而不是将注意力放在性能良好的组件上。这意味着系统的整体性能会受到性能最差组件的制约,只有通过改进和优化这些性能最差的组件,我们才能最大程度地提升系统的性能。因此,在进行性能优化时,我们需要聚焦于系统中最薄弱的环节,以实现整体性能的最大化优化。
在这里插入图片描述
即使系统具有丰富的内存资源和CPU资源,但如果磁盘IO性能低下,那么系统的整体性能将取决于当前最慢的磁盘IO速度,而不是当前最优的CPU或内存。在这种情况下,优化内存或CPU资源是无用的,只有通过提高磁盘IO性能才能对系统的整体性能进行优化。因此,磁盘IO成为系统的性能瓶颈。

性能分析三大定律

在这里插入图片描述

Amdahl定律

Amdahl定律以计算机架构师 Gene Amdahl 命名,是并行计算中的一个基本原理,它量化了程序在多个处理器上执行时的潜在速度提升。它有助于深入了解并行化的局限性,并帮助优化并行计算系统的性能。

它主要讨论了加速比(speedup)的问题,推算初整个系统的最大预期改进的最大预期改进。
在这里插入图片描述

计算公式

Amdahl指出,程序的加速受限于程序中无法并行化的部分。其数学表达式为:

Speedup  = 1 / [(1 - P) + (P / N)]
参数解释
  • Speedup:是程序并行化后性能的提升。
  • P:是可并行化的程序比例。
  • N:是用于并行执行的处理器或线程数。

根据Amdahl定律,可实现的最大速度提升与程序中不可并行化的部分成反比。即使有无限多的处理器,速度提升也会受到程序顺序部分的限制。

Amdahl定律强调了识别和优化程序关键顺序部分以实现显著提速的重要性。如果程序中不可并行的部分较多,那么只关注程序的并行化可能不会带来实质性的性能提升

案例分析

例如,假设一个程序 80% 的代码可以并行化(P = 0.8),如果我们在 10 个处理器(N = 10)上执行这个程序,应用阿姆达尔定律,我们可以计算出最大加速度如下:

加速度 = 1 / [(1 - 0.8) + (0.8 / 10)] 。
= 1 / (0.2 + 0.08)
= 1 / 0.28 ≈ 3.57

上面的结果意味着,即使使用 10 个处理器,我们所能达到的最大速度也比顺序执行快约 3.57 倍。

定律总结

Amdahl定律的重要性在于它提醒我们,如果程序中存在大量的顺序执行部分,即不可并行化的部分,那么即使将其余部分并行化,也无法获得线性的性能提升。

Gustafson定律

Gustafson定律认为随着处理器个数的增加,计算总量可以同时增加,从而实现更高的性能。如果现实情况符合Gustafson定律的假设前提,那么软件的性能将可以随着处理器个数的增加而增加。
在这里插入图片描述

与Amdahl定律相对立

Gustafson假设是与阿姆达尔定律相对的一种观点,它认为随着处理器个数的增加,计算总量可以同时增加,从而实现更高的性能。与阿姆达尔定律关注固定问题规模下的性能提升不同,Gustafson定律关注的是在可扩展问题上的性能提升。

Gustafson的逻辑公式

根据Gustafson定律,加速系数(Speedup)几乎与处理器个数成正比,而不是受到不可并行化部分的限制。这意味着,随着处理器个数的增加,计算总量可以线性地增加,而不是受到串行部分的限制。

speedUp = N * C * M
  • N:物理内核数
  • C:主频数值
  • M:逻辑内核数

一般而言,在实际应用中,需要综合考虑问题的特性和并行化策略,以确定最佳的性能优化方法。

Sun-Ni定律

Sun-Ni定律是一种关于计算资源利用和问题规模的原则,它强调充分利用存储空间等计算资源,并尽量增大问题规模以产生更好和更精确的解决方案。
在这里插入图片描述

深入分析Sun-Ni

根据Sun-Ni定律,通过充分利用计算资源,特别是存储空间,可以提高问题求解的质量和准确性。存储空间在计算中起着重要的作用,可以用于存储中间结果、数据结构和算法所需的信息等。通过充分利用存储空间,可以提供更多的计算资源来处理问题,从而产生更好的解决方案。
在这里插入图片描述

Sun-Ni定律还强调尽量增大问题规模

通过增大问题规模,可以更全面地考虑问题的各个方面,并提供更准确的解决方案。较大的问题规模可以提供更多的数据和信息,使得算法和模型能够更好地捕捉问题的复杂性和细节,从而得到更精确的结果。

定律总结

Sun-Ni定律指出了充分利用存储空间等计算资源,并尽量增大问题规模以产生更好和更精确的解决方案的重要性。通过充分利用计算资源和增大问题规模,可以提高问题求解的质量、准确性和全面性。

课外知识普及

谈到并发技术,不可避免地要提及Doug Lea,他是当今世界上并发程序设计领域的先驱和知名学者。Doug Lea是util.concurrent包的作者,他为并发编程领域做出了突出的贡献,并参与制定了JSR166规范。他的工作对于推动并发编程的发展和实践起到了重要的推动作用。
在这里插入图片描述
图书著作《Concurrent Programming in Java: Design Principles and Patterns》以及其两篇论文《A Scalable Elimination-based Exchange Channel》和《Scalable Synchronous Queues》是非阻塞同步算法领域的经典文章。其中,《A Scalable Elimination-based Exchange Channel》和《Scalable Synchronous Queues》论文被公认为非阻塞同步算法的重要篇章。

此外,该著作还有另一个重要影响,即A fork/join framework,这一架构对Java 7的发展产生了深远的影响

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/134036.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Panda3d 场景管理

Panda3d 场景管理 文章目录 Panda3d 场景管理有关分层场景图的重要信息NodePathNodePath 以及 Node 的函数调用模型文件文件格式加载模型文件将模型放置在场景图中模型缓存压缩模型异步加载模型通过回调函数进行 常见的状态变化修改节点的位置和姿态改变父级节点改变颜色隐藏和…

【多线程 - 01、概述】

进程 几乎所有的操作系统都支持进程概念,进程是处于运行过程中的程序,进程是操作系统中进行资源分配的基本单位。 三个基本特征 独立性:指进程实体是一个能独立运行、独立获得资源和独立接受调度的基本单位。而对于未建立任何进程的程序&…

深度学习模型基于Python+TensorFlow+Django的垃圾识别系统

欢迎大家点赞、收藏、关注、评论啦 ,由于篇幅有限,只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 要使用Python、TensorFlow和Django构建一个垃圾识别系统,您可以按照以下步骤进行操作: 安装…

android studio 修改图标

Android Studio 修改图标 简介 Android Studio 是一款由谷歌推出的用于开发 Android 应用程序的集成开发环境(IDE)。在开发过程中,我们可以根据自己的需求修改 Android Studio 的图标,以个性化我们的开发环境。 本文将介绍如何在…

魔搭社区LLM模型部署实践, 以ChatGLM3为例(一)

魔搭社区LLM模型部署实践, 以ChatGLM3为 例 本文以ChatGLM3-6B为例, 主要介绍在魔搭社区如何部署LLM, 主要包括如下内容: ● SwingDeploy - 云端部署, 实现零代码一键部署 ● 多端部署 - MAC个人笔记本,…

[PHP]Kodexplorer可道云 v4.47

KodExplorer可道云,原名芒果云,是基于Web技术的私有云和在线文件管理系统,由上海岱牧网络有限公司开发,发布于2012年6月。致力于为用户提供安全可控、可靠易用、高扩展性的私有云解决方案。 用户只需通过简单环境搭建,…

【m98】webrtc vs2017构建带符号的debug库

调试有符号 调试 无符号 试试exe不输出到独立的文件? -】 直接输出到sln下面

vscode因为大文件而无限崩溃的问题,窗口意外终止(原因:“oom“,代码:“-536870904“

复制了一大堆的代码(好几兆)到一个文件里,然后就导致 vscode 卡死, 之后就算把该文件删掉了,打开vscode还是会默认打开该文件而卡死 解决办法: win R 输入 %appdata%/code/ 删除该文件夹下的 backups/ 文件…

封装

文章目录 概念优点访问限定符封装的必要性代码块普通代码块构造块静态块 概念 在面向对象中,封装是指对于某个对象,Java隐藏对象的属性和方法的实现细节,仅对外公开接口,控制在程序中属性的读取和修改的访问级别。适当的封装可以…

Lenovo联想小新Air-14笔记本2021款AMD锐龙ALC版(82LM)原装出厂Win10镜像和Windows11预装OEM系统

下载链接:https://pan.baidu.com/s/1akLkXM2HIg3eO76jqM-LVA?pwdxvo6 提取码:xvo6 系统自带所有驱动、出厂主题壁纸、系统属性专属LOGO标志、Office办公软件、联想电脑管家等预装程序 所需要工具:16G或以上的U盘 文件格式:…

C语言概述

目录 ​编辑 1. C语言发展史 2. C语言特点 3. C语言标准 4. C语言编程机制 4.1 预处理(Preprocessing) 4.2 编译(Compilation) 4.3 汇编(Assemble) 4.4 链接(Linking) 结语 1. C语言发展史 C语言是由美国贝尔实验室的Dennis Ritchie于1972年设计开发的一种编…

考研分享第1期 | 末9生物跨专业考研北京大学电子信息404分经验分享

全文概览 一、个人信息 二、关于考研的经验分享 三、最后的小Tips 一、个人信息 姓名:Jackson 本科院校:某末流985生物专业 报考院校:北京大学电子信息专业 择校意向:北航计算机、人大高瓴、复旦软院、清华大学深研院、北…

【探索Linux】—— 强大的命令行工具 P.14(进程间通信 | 匿名管道 | |进程池 | pipe() 函数 | mkfifo() 函数)

阅读导航 引言一、进程间通信概念二、进程间通信目的三、进程间通信分类四、管道1. 什么是管道2. 匿名管道(1)创建和关闭⭕pipe() 函数⭕创建匿名管道⭕关闭匿名管道 (2)通信方式(3)用法示例(4&…

Oracle Unifier 22.12 ~ 23.10 功能改进清单表

序言 时隔近一年,Oracle Unifier 22还没握熟,新版本23便已迭代到23.10,根据甲骨文常规的发布规律,相信不久之后便会正式迎来正式本地版V23,了解Unfier的朋友或许知晓,本地版是云版迭代一年后的版本&#x…

vite基础学习笔记:14.路由跳转(二)携带query参数

说明:自学做的笔记和记录,如有错误请指正 1. 路由跳转(携带query参数) (1)第一层路由(点击卡片路由跳转至新页面-携带query参数) 知识点: query传参对应的是path和qu…

【CASS精品教程】cass3d加载点云(.ilas和.las)并处理应用

本文讲解cass11.0 3d中将las点云转为ilas加载并进行后续处理。(cass11.0下载与安装) 一、ilas点云格式介绍 点云ilas格式是现今数字化三维模型建模的--种普遍被使用的数据格式,也被称作点云、点集或聚集点。它把地球表面上的物体,比如森林、海洋、河流、山脉等自然物体,以…

【vue】vue项目批量下载二维码,且打包成压缩包.

一. 先看效果演示 二. 下插件 npm i vue-qr -S // 二维码显示插件 我的版本^4.0.9 npm i html2canvas -S // 将二维码转为图片 我的版本^1.4.1 npm i file-saver -S // 下载图片 我的版本^2.0.5 npm i jszip -S // 打包成压缩包 我的版本^3.10.1 // 一次性下载 npm i vue-qr h…

2.HTML中常用浏览器

2.常用浏览器 2.1 什么是浏览器 浏览器是网页显示,运行的平台。常用的浏览器有IE,火狐,谷歌,Safari和Opera等 平时成为五大浏览器 2.2 浏览器内核 浏览器内核(渲染引擎):负责读取网页内容&…

【vue3/echarts】vue3中使用echarts/饼图/双轴双数据柱状图

npm下载echarts 引入使用 <script> import Box from "/components/box.vue"; import { onMounted } from vue; import { init } from echarts; export default {components: {Box: Box},setup() {onMounted(() > {// 饼图const charEle document.getElem…

华为校招机试 - 九宫格(20220529)

题目描述 九宫格是一款广为流传的游戏,起源于河图洛书。游戏规则是:1到9九个数字放在33的格子中,要求每行、每列以及两个对角线上的三数之和都等于15。 在金庸名著《射雕英雄传》中黃蓉曾给九宫格的一种解法,口诀:戴九恩一,左三右七,二四有肩,八六为足,五居中央。解…