vlambda博客
学习文章列表

性能调优:京东大牛带我实战的经验总结

很多工作两三年的同行都跟我说,认为性能调优没什么用。刚工作的时候我也这样以为,但后来我才知道我当时想法多么的天真。

曾经,我的前前东家系统研发部门来了一位大神,为什么叫他大神?因为在他来公司的一年时间里只做了一件事,就是把服务器的数量缩减到了原来的一半,系统的性能指标,反而还提升了。

我有一个在小厂的朋友,有一次跟我说,他们公司的系统从来没有经过性能调优,功能测试完成后就上线了,线上也没有出现过什么性能问题,为什么还要去做性能调优呢?

当时我就回答了他一句,如果你们公司做的是 12306 网站,不做系统性能优化就上线,试试看会是什么情况。

一款线上产品如果没有经过性能测试,那它就好比是一颗定时炸弹。

现在假设你的系统要做一次活动,产品经理告诉你预计有几十万的用户访问量,询问系统能否承受得住。如果你不清楚自己系统的性能情况,也只能战战兢兢地回答老板,应该没问题吧。

我们再来看看2019百度、京东、腾讯、阿里巴巴等各大厂关于性能调优的面试题。

Java虚拟机底层原理与性能优化

1、Java虚拟机内存模型能说说吗?

2、类加载器的双亲委派模型是什么?

3、JVM垃圾收集算法与收集器有哪些?

4、JVM诊断调优工具用过哪些?

5、每秒几十万并发的秒杀系统为什么会频繁发生GC?

6、日均百万级交易系统如何优化JVM?

7、线上生产系统OOM如何监控及定位与解决?

8、高并发系统如何基于G1垃圾回收器优化性能?

 Mysql索引数据结构与性能优化

1、索引数据结构红黑树,Hash,B+树能说下吗?

2、千万级数据表如何用索引快速查找?

3、如何基于索引B+树精准建立高性能索引?

4、联合索引底层数据结构又是怎样的?

5、覆盖索引与聚集索引到底是什么?

6、Mysql最左前缀优化原则是什么?

7、为什么推荐使用自增主键做索引?

8、说说Mysql索引优化规范?

BIO,NIO,AIO,Netty以及Redis线程模型

1、BIO,NIO,AIO的区别?

2、什么是阻塞IO以及非阻塞IO? 

3、什么是同步IO以及异步IO? 

4、IO模型有几种?分别是什么? 

5、Reactor和Proactor IO设计模式是什么?

6、NIO底层select、poll和epoll实现的区别 ?

7、Java NIO的几个核心组成部分是什么?作用分别是什么?

8、Redis、Netty、Tomcat的线程模型与NIO的联系是什么?

一篇文章,难以说完。

以上面试题,同时也是前唯品会、京东电商架构师诸葛老师的课程内容。

欢迎大家参加腾讯课堂&图灵学院联合推出的《Java性能调优》训练营。

原价99元,限时优惠仅需0.02元

扫码参与,先到先得

点击阅读原文,立即参与课程直播~