极客时间出品的《Java性能调优实战》由刘超所作,刘超是金山软件西山居技术经理,本门课覆盖80%以上Java应用调优场景。
订阅形式
限时 ¥68
原价 ¥99。已有2825人购买,该专栏以音频和文字形式进行,共43讲 。可在极客时间APP/小程序/网站上观看。
用我的邀请购买,还会额外返现24元。购买的朋友请加我微信号 dismissmewp ,备注:返现。
专栏简介
你好,我是刘超,目前在金山西山居担任技术经理,很高兴通过这个专栏,跟你一起讨论 Java 性能调优这个话题。
先给你讲个故事吧。多年前我加入了一家大型互联网公司,刚进入就以 996 标准,参与新品研发。公司业务发展急需互联网产品,因此我们的时间很紧张,4 个月新产品就上线了。
开始还算顺利,但不久后的一天晚上,系统突然就瘫痪了,重启之后,问题仍然无规律地重现。当时运维同事马上写了一个重启脚本,定时排队重启各个服务,但也只能做到“治标不治本”。
作为主力开发,我和公司的系统架构师一起排查问题。架构师轻车熟路地通过各种 Linux 命令在线上环境查看性能指标,也 dump 出日志文件,走查代码,最后定位到了问题,后面就是分析原因、制定解决方案、更新版本等一系列操作。那是我第一次深刻感受到性能调优的重要性。
后来的几年里,我又陆续参与过物流、电商、游戏支付系统的研发,这些项目都存在一个共性,就是经常会运营一些大促以及抢购类活动。活动期间,系统不仅要保证处理请求业务的严谨性,还要历经短时间内高并发的考验。我也一直处于性能调优的一线。
正所谓“实践出真知“。这些年在生产环境中遇到的事故不少,很多坑一点点踩平,就走出了一条路,这个过程中我收获了很多实打实的经验,希望能分享给更多的人,我们一起学习、交流和探讨。
关于性能调优,我先来说说的我的感受。Java 性能调优不像是学一门编程语言,无法通过直线式的思维来掌握和应用,它对于工程师的技术广度和深度都有着较高的要求。
互联网时代,一个简单的系统就囊括了应用程序、数据库、容器、操作系统、网络等技术,线上一旦出现性能问题,就可能要你协调多方面组件去进行优化,这就是技术广度;而很多性能问题呢,又隐藏得很深,可能因为一个小小的代码,也可能因为线程池的类型选择错误…可归根结底考验的还是我们对这项技术的了解程度,这就是技术深度。
显然,性能调优不是一件容易的事。但有没有什么方法能把这件事情做好呢?接下来跟你分享几点我的心得。
Java性能调优实战专栏作者
刘超,现任金山软件西山居(国内最早的游戏开发工作室)技术经理,主导游戏支付系统的研发工作,2018 年开始带领技术团队转型微服务架构。曾就职于魅族、平安银行等公司,负责过电商、物流、支付系统的搭建工作,主攻后端架构研发,在高并发业务系统方面,具有丰富的实战经验。
在他看来,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死锁事故:读写分离的必要性
什么时候需要分表分库?
电商系统表设计优化案例分析
数据库参数设置优化,失之毫厘差之千里
答疑课堂
模块七•实战演练场
如何设计更优的分布式锁?
电商系统的分布式事务调优
如何使用缓存优化系统性能?
记一次双十一抢购性能瓶颈调优
结束语 学做自己的伯乐

我的公众号:猿人学 Python 上会分享更多心得体会,敬请关注。
***版权申明:若没有特殊说明,文章皆是猿人学 yuanrenxue.con 原创,没有猿人学授权,请勿以任何形式转载。***
说点什么吧...