性能调优知多少

性能调优主要涉及这些方面:

1、代码
2、数据库
3、网络
4、硬件
5、系统构架

具体如下:

代码:

1、缓存:缓存是典型的空间换时间,在软件项目中,用的最多的是redis缓存,第一次查询的时候,将查询数据存储到缓存中,后面每次查询,先从缓存中取数据,缓存中没有,再去数据库中取数据。

2、多线程&多进程:使用多线程,缩短任务时间。

3、异步:针对某些客户端的请求,在服务端可能需要针对这些请求做一些附属的事情,这些事情其实用户并不关心或者用户不需要立即拿到这些事情的处理结果,这种情况就比较适合用异步的方式处理这些事情。作用:缩短接口响应时间,使用户的请求快速返回,用户体验更好。

4、批处理:是把一堆基本相同的请求批量处理,这样可以一批数据只写一次数据库,减少数据库的操作次数;

5、简化代码:如:减少循环的层数,减少递归,在循环中少声明变量,少做分配和释放内存的操作,尽量把循环体内的表达式抽到循环外,条件表达的中的多个条件判断的次序,尽量在程序启动时把一些东西准备好,注意函数调用的开销(栈上开销),注意面向对象语言中临时对象的开销,小心使用异常等。

6、前端-减少http 请求次数: 每个http请求从建立到关闭都需要一定的时间,因此减少http请求的数目可有效提高访问性能。网页中的的图片、form、flash等等元素都会发出http请求。

7、前端-减少 DNS 查询次数:DNS 的作用是将 URL 转化为实际服务器主机 IP 地址,实现原理是分级查找,查找过程需要花费 20~100ms 的时间,所以一方面我们要加快单次查找的时间,另一方面也要减少一个页面中资源使用了多个不同域的情况;

8、前端-减少或避免页面跳转:页面跳转相当于又打开一个新的页面,耗费的时间就会比较长,所以要尽量避免使用页面跳转;

9、前端-减少网页大小:网页过大,如果要快速下载,下载网页内容会需要比较大的带宽,带宽就有可能成为瓶颈。

10、表单压缩,减少网络传输数据量,典型的时间换空间,虽然压缩消耗时间,但如果瓶颈在网络,用时间换空间反而能节省时间。

11、使用内容分发网络(CDN):使用 CDN 相当于对静态内容做了缓存,并把缓存内容放在网络供应商(ISP)的机房,用户根据就近原则到 ISP 机房获取这些被缓存了的静态资源,因此可以大幅提高性能;

数据库:

1、添加/修改索引:通过索引查询,缩短查询时间;通过修改联合索引,增加索引命中率。

2、分区分库分表:不同服务或者不同业务的数据配置不同的数据库,这样在进行增删改查时候可减少数据库磁盘的读写频率。 备注:分区并不是生成新的数据表,而是将表的数据均衡分摊到不同的硬盘,系统或是不同服务器存储介

3、数据库读写分离:从主库写入数据,从库读取数据,减少数据库磁盘的繁忙频率。

4、修改数据库连接池:重新定义数据库连接池数,减少任务的排队数量。

5、硬件配置:提高数据库CPU、内存、磁盘等硬件配置,提升处理能力。

3、网络:调整带宽

4、硬件:

1、增加机器数量:对于实现了分布式服务,增加服务器数量
2、提高硬件配置:提高服务器CPU、内存、磁盘等配置,提高单台服务器的处理能力
3、JVM:合理的分配堆与非堆的内存、GC
4、中间件:调整ES、MQ中间件的配置架构,如增加中间件机器配置、单机改为分布式

5、系统架构:单机改为分布式集成、负载均衡

其中:

时间(对于应用服务器而言):软件的响应时间…

空间(对于硬件服务器而言):服务器的磁盘使用率、CPU使用率、内存空闲率…

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值