java 异步缓存_Java常用的后台性能优化六种方式:缓存化+服务化+异步化等

e4d97f5c3eedac104335223391b6cc3e.png常用的后台性能优化六大方式

01. 缓存化

缓存可以称的上是性能优化的利器,使用缓存时需要考虑缓存命中率、缓存升级、数据一致性、缓存穿透及雪崩、Value过大等问题,可以通过mutiGet将屡次请求合并一次、异步访问等方式来提升缓存读取的性能。

02. 硬件更新

硬件问题对性能的影响不容忽视。

举一个例子:一个DB集群经常有慢SQL报警,业务排查下来发现SQL都很简单,该做的索引优化也都做了。后来DBA同学帮忙定位到问题是硬件过旧导致,将机械硬盘更新成固态硬盘之后报警立马消失了,效果立竿见影!

03. 业务逻辑优化

业务逻辑优化经常会容易被忽略,但效果却往往比数据库调优、JVM调优之类的来的更显著。

举一个例子,12306春运抢火车票的场景,因为访问的人多,客户点击“查票”之后系统会非常卡,进度条非常慢,作为客户,我们会习惯性的再去点“查票”,可能会连续点个好几次。假设平均一个客户点5次,则后台系统负载就添加了5倍!而其中80%的请求是重复请求。这个时候我们可以通过产品逻辑的方式来优化,比方,在客户点击查询之后将“按钮置灰”,或者者通过JS控制xx秒只能只能提交一次请求等,有效的阻拦了80%的无效流量。

04. 服务化

做服务化最基础的是按业务做服务拆分,避免跨业务间的互相影响,数据和服务同时拆分。同一个业务内部我们还按计算密集型/IO密集型的服务拆分、C端/B端服务拆分、核心/非核心服务拆分、高频服务单独部署等准则做拆分。

05. 异步化

异步化可以利用线程池、消息队列等方式实现。

使用线程池的时候肯定要注意核心参数的设置,可以通过监控工具去观测实际创立、活跃、空闲的线程数,结合CPU、内存的使用率情况来做线程池调优。

另一种是通过NIO实现异步化,一切网络IO皆可异步:RPC框架、Servlet 3.0提供的异步技术、Apache HttpAsyncClient、缓存异步接口等等。

06. 利用搜索引擎

复杂查询以及少量聚合计算不适合在数据库中做,可以利用搜索引擎来实现,另外搜索引擎还可以帮我们很好的处理跨库、跨数据源检索的场景。

-end-

假如觉得不错,记得点赞,关注,之后小编会不断升级~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值