作为一名高级工程师,性能调优是必不可少的技能,本篇文章是性能调优系列文章的第一篇
导致性能瓶颈的几点原因
- CPU:如果系统中存在视频分析、3D渲染、大量计算这样的应用时,大量的CPU资源的竞争就会引起性能瓶颈
- 内存:一般来说内存不会成为性能瓶颈,为啥人家redis快,就是因为是基于内存的。但是呢内存资源不够用确实是个很致命的问题,就像Java中的OOM大部分都是因为内存资源不够引起的
- 磁盘:我们都知道买一个256G的硬盘的价钱勉强才可以买一个8G的内存条,它们之间的价格差距如此之大主要就是因为内存的读写速度比磁盘大的多,所以说如果程序中存在大量的读写磁盘的场景那么就很容易成为性能瓶颈
- 网络:曾经有人说过网络环境可能是最复杂的,且最不受程序控制的,一个包发出去在哪丢的都不知道。所以如果程序中需要从第三方获取服务的场景就很容易成为瓶颈
- 数据库:数据库是一个程序必须使用到的组件,所有的数据库都存在连接数量、读写速度、数据合并等因素的制约。再者如果使用关系型数据库且没有利用索引等技术的时候更是一场灾难
- 锁竞争:对于高并发应用来说,使用锁来维护数据的一致性是避免不了的。但是维护了一致性就要承受锁竞争带来的线程上下文切换时带来的开销、甚至还有死锁的发生
哪些指标可以衡量系统的性能
- 响应时间:应用系统从用户发起请求到做出响应的时间,例如我们平时打游戏时如果响应时间大于几百毫秒我们就会说这玩意真卡,这网速不行啊等等。。
- 启动时间:应用系统从开始运行到可以正常处理业务所浠要花费的时间,比如从点击王者荣耀图标到进入系统开始撸的时间
- 吞吐量(TPS):应用程序单位时间内处理的请求数量,例如微信后台服务器一秒可以处理几十万的用户发消息的请求
- 每秒查询率(QPS):相对特殊的TPS,可以理解为查询服务的TPS并发用户数:系统可以同时支撑正常使用功能的用户量,例如某某游戏周年庆时号称1千万人同时在线
- 系统负载:当系统压力上升时,上述的各项指标的变化曲线是否平缓
推荐阅读
- SpringCloud学习系列汇总
- 为什么一线大厂面试必问redis,有啥好问的?
- 多线程面试必备基础知识汇总
- Java集合源码分析汇总-JDK1.8
- Linux常用命令速查-汇总篇
- JVM系列文章汇总
- MySQL系列文章汇总
- RabbitMQ系列文章汇总
博客所有文章首发于公众号《Java学习录》转载请保留
扫码关注公众号即可领取2000GJava学习资源
相关推荐
3 Apache性能调优 4 Tomcat性能调优 让小猫飞奔 5 Tomcat集群 群猫乱舞 6 漫谈基于数据库的权限系统设计 7 漫谈使用ThreadLocal改进你的层次划分 8 weblogic与apache的整合与调优 9 weblogic的集群与配置 10 Axis2...
3、Apache性能调优 4、Tomcat性能调优 - 让小猫飞奔 5、Tomcat集群 - 群猫乱舞 6、漫谈基于数据库的权限系统设计 7、漫谈使用ThreadLocal改进你的层次划分 个人认为内容非常好,所以整理上传,希望能给更多的人带来...
3、Apache性能调优 4、Tomcat性能调优 - 让小猫飞奔 5、Tomcat集群 - 群猫乱舞 6、漫谈基于数据库的权限系统设计 7、漫谈使用ThreadLocal改进你的层次划分 8、weblogic与apache的整合与调优 9、weblogic的集群与...
通向架构师的道路(第三天)之apache性能调优.docx 通向架构师的道路(第四天)之Tomcat性能调优-让小猫飞奔.docx 通向架构师的道路(第五天)之tomcat集群-群猫乱舞.docx 通向架构师的道路(第六天)之漫谈基于数据库的权限...
(第三天)之apache性能调优 (第四天)之Tomcat性能调优-让小猫飞奔 (第五天)之tomcat集群-群猫乱舞 (第六天)之漫谈基于数据库的权限系统的设计 (第七天)之漫谈使用ThreadLocal改进你的层次的划分 (第八天)...
8. **监控和性能调优工具**:Oracle提供了一系列工具,如AWR(Automatic Workload Repository)和ASH(Active Session History),用于收集性能数据,帮助DBA识别瓶颈并制定优化策略。 综上所述,Oracle数据库的...
为了更好地理解和使用Netty,开发者需要了解其事件驱动和异步处理的特性,掌握Netty的架构和组件工作方式,以及如何进行性能调优和安全防护。通过学习和实践,开发者可以利用Netty构建出高效、稳定、可扩展的网络...
《通向架构师的道路》是一份综合性的学习资源包,主要涵盖了成为一名...通过这些文档的学习,读者可以逐步构建对架构设计的整体理解,涵盖从基础框架应用到高级性能调优的各个层面,对提升个人技能和职业发展大有裨益。
6. **Nginx配置连接数** (08.nginx配置连接数.mp4):这节可能涉及Nginx的性能调优,如设置最大并发连接数,以适应不同规模的流量需求。 7. **Nginx虚拟主机** (09.nginx虚拟主机.mp4):Nginx支持通过虚拟主机配置来...
12.Oracle专家调优秘密 13.PL_SQL单行函数和组函数详解 14.PL-SQL 15.PLSQL异常处理初步 16.SQL语句性能调整原则 17.创建和使用分区的表 18.基于成本的优化器一般错误概念和问题 19.Delphi 3_0中连接...
此外还有大量案例:Where In List问题解析,数据库设计和大数据量处理、数据审核、号段选取应用、分析SQL执行计划的关注点、Oracle开发误区探索、提升PL/SQL开发性能漫谈、管道函数的学习与实战应用、巧用锁特性避免...
此外还有大量案例:Where In List问题解析,数据库设计和大数据量处理、数据审核、号段选取应用、分析SQL执行计划的关注点、Oracle开发误区探索、提升PL/SQL开发性能漫谈、管道函数的学习与实战应用、巧用锁特性避免...
此外还有大量案例:Where In List问题解析,数据库设计和大数据量处理、数据审核、号段选取应用、分析SQL执行计划的关注点、Oracle开发误区探索、提升PL/SQL开发性能漫谈、管道函数的学习与实战应用、巧用锁特性避免...
- **比例积分微分综合整定**:提供PID参数整体调优的方法和技巧。 - **自动调节系统的质量指标**:列举评估自动调节系统性能的标准和指标。 - **整定系统需要注意的几个问题**:指出在参数整定过程中可能遇到的...