性能优化学习

一、明确优化目标

提升吞吐量还是相应速度。

二、性能优化的指标

1) 平均响应时间

服务接口的平均处理能力。

向某个网站发送n次请求,n次请求相应时间除以n得到的时间。 短时间请求慢,然后又变好,平均响应时间无法反映出性能波动。

2)百分位数

应用接口的整体相应情况

超过 N% 的请求都在 X 时间内返回。比如 TP90 = 50ms,意思是超过 90% 的请求,都在 50ms 内返回。

TP50、TP90、TP95、TP99、TP99.9 等多个段,对高百分位的值要求越高,对系统响应能力的稳定性要求越高。

3)并发量

指的是系统能够同时处理的请求数量,反映的是系统的负载能力。

4)秒开率

前端网页或者APP能够在1秒内很平滑的打开,尤其是首页的加载 超过3秒则用户可能直接退出不在使用,这里强调后端优化的同事,也需要对前端进行优化。

5)正确性

优化后的性能提高后,数据依旧要是正确的。

三、附言

1、除非必要,一开始不要优化(尤其是开发阶段)

2、有些优化准则已经过时,需要考虑当下的软硬件环境(不要墨守成规)

3、不要过分强调某些系统级指标,如cache 命中率,而应该聚焦性能瓶颈点

4、不盲从,测试、找到系统的性能瓶颈,再确定优化手段

5、注意权衡优化的成本和收益(有些优化可能需要现有架构做出调整、增加开发/运维成本)

6、优化的目标是用户体验、降低硬件成本(降低集群规模、不依赖单机高性能)

7、测试环境的优化手段未必对生产环境有效(优化需要针对真实情况)

四、相关实操

1、接口访问时间 qps jmeters接口压测

2、数据库访问时间 执行计划

3、cpu 内存 磁盘使用率 第三方监测工具 arths

相关推荐
奶黄小甜包33 分钟前
C语言零基础第18讲:自定义类型—结构体
c语言·数据结构·笔记·学习
rannn_1113 小时前
【MySQL学习|黑马笔记|Day7】触发器和锁(全局锁、表级锁、行级锁、)
笔记·后端·学习·mysql
喜欢吃燃面4 小时前
C++算法竞赛:位运算
开发语言·c++·学习·算法
传奇开心果编程4 小时前
【传奇开心果系列】Flet框架实现的家庭记账本示例自定义模板
python·学习·ui·前端框架·自动化
_Kayo_10 小时前
node.js 学习笔记3 HTTP
笔记·学习
CCCC131016313 小时前
嵌入式学习(day 28)线程
jvm·学习
星星火柴93614 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
小狗爱吃黄桃罐头14 小时前
正点原子【第四期】Linux之驱动开发篇学习笔记-1.1 Linux驱动开发与裸机开发的区别
linux·驱动开发·学习
艾莉丝努力练剑14 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
武昌库里写JAVA16 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习