性能调优的时候,建议你避开这几个坑!

  • 2019 年 12 月 31 日
  • 筆記

来源:Tuling https://url.cn/5Kf3815

一、前言

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

二、大牛同事的神操作

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

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

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

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