之前有朋友说,“我们公司的系统从来都没有经过性能调优,集成测试没问题后就上线了,上线后也几乎没出现过性能问题。”
其实没遇到性能问题不代表程序不存在性能问题,只能说明系统的访问量有点小。微博瘫痪不就是因为短时间内访问量暴增后,系统扛不住,就出现性能瓶颈了嘛。
大部分的性能问题都是由于访问量过大导致的,618、双11就不说了,每逢节假日放假出游抢票,12306网站最有发言权,这要是挂了,可是要被全国人民骂的。
还有一部分性能问题是随着时间积累爆发的,如果运行一段时间后没有重启,到了某个时间节点内存就会突然爆掉。反正我司一些项目就遇到过这方面的尴尬,一开始的解决方案就是写个脚本,在夜深人静的时候,偷偷地重启释放一下内存。
性能调优其实是每个合格的工程师必备的技能,JVM调优,Mysql调优,各种分布式中间件的调优是绕不过的,来看下一线互联网公司的这些题目:
京东:说下JVM内存模型与Java线程内存模型的区别?
腾讯:JVM的GC执行时机是任何时候都可以吗?安全点知道吗?
美团:CMS垃圾收集器的并发更新失败是怎么回事?如何优化?
阿里:高并发系统为何建议选择G1垃圾收集器?
拼多多:线上系统GC问题如何快速定位与分析?
阿里:阿里巴巴Arthas实现原理能大概说下吗?
百度:单机几十万并发的系统JVM如何优化?
阿里:解释下JVM垃圾收集底层的三色标记算法?
美团:Volatile底层的内存屏障是如何实现的?
滴滴:能说说Mysql索引底层B+树结构与算法吗?
滴滴:聚集索引与覆盖索引与索引下推到底是什么?
阿里:能说说Mysql并发支撑底层Buffer Pool机制吗?
拼多多:能说下Mysql事务底层实现原理吗?
唯品会:MVCC机制是如何保证事务的隔离性的?
京东:超高并发下使用事务时如何避免死锁?
京东:对线上千万级大表加字段时,性能极慢问题如何处理?
看完你能解决几个?
大多数人碰到这些性能问题总是一脸蒙圈,很多同学试着网上翻博客或看书,但是发现几乎很难找到合适的解决方案。
当然有的同学做的系统规模不大,并没有碰到过类似问题,但是在跳槽面试时又被问到类似实战型的问题,只能双手一摊了。。
其实Java 性能调优不是一门编程语言,无法通过直线式的思维来掌握和应用。不是学不会,而是你没有摸透底层原理,缺乏实战经验!
页面更新:2024-05-30
本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828
© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号