一、什么是java优化
我们的java程序运行在计算机上面,影响计算机性能的主要因素有:硬盘,内存,cpu,网络,而如何高效的运用这些关键性因素就是java程序优化的方向。
二、关键性因素在技术工具上的应用
1、硬盘——>mysql索引,mysql调优
mysql索引本质上是通过硬盘io快速查找到我们需要的值的一种数据结构,其底层是b+树,详细文章
2、内存——>redis特性,jvm调优
redis是于内存上面运行的一种缓存中间件,其目的就是减少对mysql的查找,也就是减少磁盘io,一般存储一些热点数据
jvm则通过基本的jvm参数设置jvm各部分的大小以及查看其情况,或者用第三方dump文件查看具体信息,详细文章
3、cpu多核——>多线程,线程池的使用
多线程的本质就是提高cpu的利用率,通过多核多线程处理大批量数据
4、网络——>bio,nio,aio的使用
网络传输也属于一种io,如何高效利用io就涉及到bio,nio,aio 详细文章
5、中间件思想 MQ
异步:例如下单有订单消息通知,这个通知可以放到MQ里面,由客户端后面再消费
削峰:将大批量下单消息放入MQ中,按顺序消费
解耦:将应用处理结果丢到MQ中,其他应用只需要进MQ消费即可,不用再在A应用中写B应用代码