Java性能调优实战-刘超-极客时间-返现24元

极客时间专栏 2019-05-22 15:10:06 阅读(5492) 评论(0)

极客时间出品的《Java性能调优实战》由刘超所作,刘超是金山软件西山居技术经理,本门课覆盖80%以上Java应用调优场景。

Java性能调优实战 作者刘超

订阅形式

限时 ¥68原价 ¥99已有2825人购买,该专栏以音频和文字形式进行,共43讲 。可在极客时间APP/小程序/网站上观看。

Java性能调优实战 返现

用我的邀请购买,还会额外返现24元。购买的朋友请加我微信号 dismissmewp ,备注:返现。

专栏简介

你好,我是刘超,目前在金山西山居担任技术经理,很高兴通过这个专栏,跟你一起讨论 Java 性能调优这个话题。

先给你讲个故事吧。多年前我加入了一家大型互联网公司,刚进入就以 996 标准,参与新品研发。公司业务发展急需互联网产品,因此我们的时间很紧张,4 个月新产品就上线了。

开始还算顺利,但不久后的一天晚上,系统突然就瘫痪了,重启之后,问题仍然无规律地重现。当时运维同事马上写了一个重启脚本,定时排队重启各个服务,但也只能做到“治标不治本”。

作为主力开发,我和公司的系统架构师一起排查问题。架构师轻车熟路地通过各种 Linux 命令在线上环境查看性能指标,也 dump 出日志文件,走查代码,最后定位到了问题,后面就是分析原因、制定解决方案、更新版本等一系列操作。那是我第一次深刻感受到性能调优的重要性。

后来的几年里,我又陆续参与过物流、电商、游戏支付系统的研发,这些项目都存在一个共性,就是经常会运营一些大促以及抢购类活动。活动期间,系统不仅要保证处理请求业务的严谨性,还要历经短时间内高并发的考验。我也一直处于性能调优的一线。

正所谓“实践出真知“。这些年在生产环境中遇到的事故不少,很多坑一点点踩平,就走出了一条路,这个过程中我收获了很多实打实的经验,希望能分享给更多的人,我们一起学习、交流和探讨。

关于性能调优,我先来说说的我的感受。Java 性能调优不像是学一门编程语言,无法通过直线式的思维来掌握和应用,它对于工程师的技术广度和深度都有着较高的要求。

互联网时代,一个简单的系统就囊括了应用程序、数据库、容器、操作系统、网络等技术,线上一旦出现性能问题,就可能要你协调多方面组件去进行优化,这就是技术广度;而很多性能问题呢,又隐藏得很深,可能因为一个小小的代码,也可能因为线程池的类型选择错误…可归根结底考验的还是我们对这项技术的了解程度,这就是技术深度。

显然,性能调优不是一件容易的事。但有没有什么方法能把这件事情做好呢?接下来跟你分享几点我的心得。

Java性能调优实战专栏作者

刘超,现任金山软件西山居(国内最早的游戏开发工作室)技术经理,主导游戏支付系统的研发工作,2018 年开始带领技术团队转型微服务架构。曾就职于魅族、平安银行等公司,负责过电商、物流、支付系统的搭建工作,主攻后端架构研发,在高并发业务系统方面,具有丰富的实战经验。

Java性能调优实战 作者刘超

在他看来,Java 性能调优和学一门编程语言不同,前者无法通过直线式的思维来掌握和应用。他认为,扎实的计算机基础,透过源码看技术本质的良好习惯,善于追问和总结才是做好性能调优的大前提。

因此,在这个专栏里,他将结合自己多年的从业经验,从 Java 应用服务的每一层优化实战出发,精选高频性能问题,透过 Java 底层源码,提炼出优化思路和它背后的实现原理,最后形成一套“学完就能用的调优方法论”,帮助你快速进阶。

《Java性能调优实战》专栏模块

专栏共 43 期,分为七大模块。

模块一,概述。这个模块将为你建立两个标准。一个是性能调优标准,另一个是调优过程标准,为性能调优实战做好准备。

模块二,Java 编程性能调优。这个模块将从基础的数据类型讲起,涉及容器在实际应用场景中的调优,还有现在互联网系统架构中比较重要的网络通信调优。

模块三,多线程性能调优。如何做锁优化?如何优化多线程上下文切换?如何用协程来优化多线程业务?这些问题都会在这个模块重点讲解。

模块四,JVM 性能监测及调优。Java 应用程序是运行在 JVM 之上的,对 JVM 进行调优可以提升系统性能。这个模块将重点讲解 Java 对象的创建和回收、内存分配等问题。

模块五,设计模式调优。设计模式可以优化架构设计,这个模块将结合一些复杂的应用场景,解析设计优化案例。

模块六,数据库性能调优。数据库最容易成为整个系统的性能瓶颈,这个模块会重点解析一些数据库的常用调优方法。

模块七,实战演练场。这个模块将带你进入综合性能问题高频出现的应用场景,综合应用前面六大模块的内容,学习整体调优方法。

《Java性能调优实战》专栏详细目录

《Java性能调优实战》课程目录

开篇词丨怎样才能做好性能调优?

模块一 •概述

如何制定性能调优标准?

如何制定性能调优策略?

模块二• Java编程性能调优

字符串性能优化不容小觑,百M内存轻松存储几十G数据

慎重使用正则表达式

AtrayList还是LinkList?使用不当性能差千倍

Stream如何提高遍历集合效率?

深入浅出HashMap的设计与优化

网络通信优化之I/O模型:如何解决高并发下I/O瓶颈?

网络通信优化之序列化:避免使用Java序列化

网络通信优化之通信协议:如何优化RPC网络通信?

答疑课堂

模块三•多线程性能调优

多线程之锁优化(上):深入了解同步锁的优化方法

多线程之锁优化(下):使用乐观锁优化并行操作

多线程调优(上):哪些操作导致了上下文切换?

多线程调优(下):如何优化多线程上下文切换?

并发容器的使用:识别不同场景下最优容器

如何设置线程池大小?

如何用协程来优化多线程业务?

答疑课堂

模块四• JVM性能监测及调优

深入JVM即时编译器JIT,优化Java编译

磨刀不误砍柴工:欲知JVM调优先了解JVM

如何优化垃圾回收机制?

如何优化JVM内存分配?

内存持续上升,我该如何排查问题?

答疑课堂

模块五•设计模式调优

单例模式:如何创建单一对象优化系统性能?

原型设计与享元模式:提升系统性能的利器

如何使用设计模式优化并发编程?

生产者消费者模式:电商库存设计优化

装饰器模式:如何优化电商系統中复杂的商品价格策略?

答疑课堂

模块六•数据库性能调优

MySQL调优之SQL语句:如何写出高性能SQL语句?

MySQL调优之事务:高并发场景下的数据庠事务调优

MySQL调优之索引:索弓|的失效与优化

记一次线上SQL死锁事故:读写分离的必要性

什么时候需要分表分库?

电商系统表设计优化案例分析

数据库参数设置优化,失之毫厘差之千里

答疑课堂

模块七•实战演练场

如何设计更优的分布式锁?

电商系统的分布式事务调优

如何使用缓存优化系统性能?

记一次双十一抢购性能瓶颈调优

结束语 学做自己的伯乐

 

猿人学banner宣传图

我的公众号:猿人学 Python 上会分享更多心得体会,敬请关注。

***版权申明:若没有特殊说明,文章皆是猿人学 yuanrenxue.con 原创,没有猿人学授权,请勿以任何形式转载。***

说点什么吧...