转载

经典面试题:在这个场景下,你怎么进行性能调优?

点击上方蓝色“ 程序猿DD ”,选择“设为星标”

经典面试题:在这个场景下,你怎么进行性能调优?

来源 |   https://url.cn/5OrJa7e

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

性能提升与定时炸弹

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

好的系统性能调优不仅可以提高系统性能,还能为公司节省资源。这也是我们做性能调优的最直接的目的。

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

当时我就回答了他一句,如果你们公司做的是 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元

扫码参与,先到先得

经典面试题:在这个场景下,你怎么进行性能调优?

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

原文  http://mp.weixin.qq.com/s?__biz=MzAxODcyNjEzNQ==&mid=2247489360&idx=1&sn=d0d62741a452f499d3c4bf889858d168
正文到此结束
Loading...