- 不同角色的性能反馈
客户:你们的网站/APP点了下在那一直转圈圈,一动也不动! 怎么这么慢,这么卡啊!
领导: 这个接口怎么等待这么长时间才会返回数据? 都3秒了!为啥我们网站最大并发量这么少?
运维:你程序报OOM异常了! 你程序干啥了,CPU都100%了!
一开始运行得好好呀,这是咋滴了! 作为程序员的你,是不是一脸懵圈!
- 提取关键性能指标
响应时间、吞吐量(QPS)、系统负载,资源利用率(cpu,内存,磁盘,带宽)
- 如何进行性能分析?
检查请求处理的各个环节的日志,分析哪个环节响应时间不合理,然后检查监控数据,分析影响性能的主要因素是内存、磁盘、网络、还是CPU,是代码问题,还是架构设计不合理,或者系统资源确实不足。
1). 查看代码执行耗时工具:Arthas中的trace命令
2). 查看系统负载,资源利用率; 相关命令:w/top,free,df
- 性能优化策略
Web前端性能优化
- 减少HTTP请求数, 主要手段: css/js文件合并,多张矢量图合并
- 使用浏览器缓存,主要手段:设置HTTP头中的Cache-Control和Expires的属性
- 启用压缩,主要手段:Nginx启用Gzip
# 开启gzip
gzip on;
# 启用gzip压缩的最小文件;小于设置值的文件将不会被压缩
gzip_min_length 1k;
# gzip 压缩级别 1-10
gzip_comp_level 2;
# 进行压缩的文件类型。
gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
# 是否在http header中添加Vary: Accept-Encoding,建议开启
gzip_vary on;
- CSS放在页面最上面、JS放在页面最下面
- 减少Cookie传输,主要手段:对于某些静态资源的访问根本不需要cookie,可以考虑使用独立域名访问
- 静态资源使用CDN加速
应用服务器性能优化
- 优先考虑使用缓存,需要注意如何保证缓存数据一致性?能删缓存时不要去更新缓存。
- 异步处理,一些非核心业务逻辑,可以使用消息队列,线程池进行异步操作。
- 集群化部署,当一台服务器负载压力过大响应慢时,可考虑集群化部署提高性能。
存储性能优化
- 数据库:建立索引,读写分离,分库分表
- 缓存:读操作走slave节点,写操作走master节点。字典数据可以做预热处理。
- 性能检测方法
- 最简单最常用的方法:postman请求一把,看看响应是不是快了。
- 性能测试: 用jmeter对系统不断施加压力,验证系统在资源可接受范围内,是否能达到性能预期。
- 总结
性能优化,不是出现问题才去做的,而是实时想着去做。既能提高技术,又能解决问题,何乐不为!