18 年技术老兵谈架构师之路及 Java 程序员架构学习路线

架构的是什么?架构师的本质是什么?

架构师的本质是将复杂的业务简单化(大道至简)。将无序变成有序,找出应用边界,再有机结合,具体用什么技术来解决问题,个人推荐小而美的思路,简单明了的解决方案,一切从简。同时,架构师需要一定的技术基础,侧重于产品全局的把控,思考的更多更全面,包括功能、用户群体、适用范围、未来扩展性、规划等。

架构师在整个系统、项目中的地位类似于房屋建造的设计师,需要对项目的整体进行统筹规划、有全局把控的能力,能够在功能、展现、技术选型等方面做决策,在技术攻关的时候还能撸起袖子直接上战场的人。

架构师应该考虑项目未来的发展,现有的架构是否满足项目未来5到10年的性能、存储以及功能变更的规划。做一套系统最关键的是两个方面:第一是性能上的规划,第二是功能上的扩展。个人比较推崇小而美的架构,并进行逐步迭代,不要过度设计,增加系统复杂度。

普通开发人员要如何转型为架构人员?现在涌现的很多轻便化和简易化的产品会不会降低对架构师的门槛?

(1)普通开发人员不应该急躁、眼高手低,成为高手不是一朝一夕的。首先,应该做好自己的本职工作,在每一次解决完问题后再思考还有没有更好的解决方案,一点一点的进步,同时养成好的习惯,动手之前先想,能想出多种解决方案,并选择出最适合的,对于自己的成长一开始不要定一个很大的目标,给自己一个规划,有想法就去做,一点一点地积累,多动手,多思考,多重构。曾经遇到一个应届毕业生看设计模式,这就是我不推崇的,当然,能力特别突出就另当别论。

(2)轻便化和简易化的产品不仅不会降低架构师的价值,反而是一个合格的架构师要学会用这些稳定的、可靠的小组件,去丰富工作中的一些解决方案。如何将众多好的开源产品进行融合、整理,这是架构师一个重要的能力:架构治理能力。

你对Java 程序员的架构学习路线有没有什么好的建议?

一、Java工程化

工欲善其事,必先利其器,不管是小白,还是资深开发,都需要先选择好的工具。提升开发效率何团队协作效率。让自己有更多时间来思考。


二、源码分析

源码分析是一种临界知识,掌握了这种临界知识,能不变应万变,源码分析对于很多人来说很枯燥,生涩难懂。

源码阅读,我觉得最核心有三点:技术基础+强烈的求知欲+耐心。

我认为是阅读源码的最核心驱动力。我见到绝大多数程序员,对学习的态度,基本上就是这几个层次(很偏激哦):

如果你想学习以上的知识内容,你可以加这个群获取:交流学习群:561614305 里面会分享一些资深架构师录制的视频录像

1、只关注项目本身,不懂就baidu一下。

2、除了做好项目,还会阅读和项目有关的技术书籍,看wikipedia。

3、除了阅读和项目相关的书外,还会阅读IT行业的书,比如学Java时,还会去了解函数语言,如LISP。

4、找一些开源项目看看,大量试用试用第三方框架,还会写写demo。

5、阅读基础框架、J2EE规范、Debug服务器内核。

大多数程序都是第1种,到第5种不光需要浓厚的兴趣,还需要勇气:我能读懂吗?其实,你能够读懂的

耐心,真的很重要。因为你极少看到阅读源码的指导性文章或书籍,也没有人要求或建议你读。你读的过程中经常会卡住,而一卡主可能就陷进了迷宫。这时,你需要做的,可能是暂时中断一下,再从外围看看它:如API结构、框架的设计图。

下图是我总结出目前最应该学习的源码知识点:


三、微服务

当前微服务很热,大家都号称在使用微服务架构,但究竟什么是微服务架构?微服务架构是不是发展趋势?对于这些问题,我们都缺乏清楚的认识。

为解决单体架构下的各种问题,微服务架构应运而生。与其构建一个臃肿庞大、难以驯服的怪兽,还不如及早将服务拆分。微服务的核心思想便是服务拆分与解耦,降低复杂性。微服务强调将功能合理拆解,尽可能保证每个服务的功能单一,按照单一责任原则(Single Responsibility Principle)明确角色。 将各个服务做轻,从而做到灵活、可复用,亦可根据各个服务自身资源需求,单独布署,单独作横向扩展。

下图是我总结出微服务需要学习的知识点:


四、分布式架构

分布式系统是一个古老而宽泛的话题,而近几年因为 “大数据” 概念的兴起,又焕发出了新的青春与活力。除此之外,分布式系统也是一门理论模型与工程技法并重的学科内容。相比于机器学习这样的研究方向,学习分布式系统的同学往往会感觉:“入门容易,深入难”。的确,学习分布式系统几乎不需要太多数学知识。

分布式系统是一个复杂且宽泛的研究领域,学习一两门在线课程,看一两本书可能都是不能完全覆盖其所有内容的。

总的来说,分布式系统要做的任务就是把多台机器有机的组合、连接起来,让其协同完成一件任务,可以是计算任务,也可以是存储任务。如果一定要给近些年的分布式系统研究做一个分类的话,我个人认为大概可以包括三大部分:

分布式存储系统

分布式计算系统

分布式管理系统

下图是我总结近几年目前分布式最主流的技术:


五、性能优化

不管是应付前端面试还是改进产品体验,性能优化都是躲不开的话题。

优化的目的是让用户有“快”的感受,那如何让用户感受到快呢?

加载速度真的很快,用户打开输入网址按下回车立即看到了页面

加载速度并没有变快,但用户感觉你的网站很快

性能优化取决于多个因素,包括垃圾收集、虚拟机和底层操作系统(OS)设置。有多个工具可供开发人员进行分析和优化时使用,你可以通过阅读 Java Tools for Source Code Optimization and Analysis 来学习和使用它们。

必须要明白的是,没有两个应用程序可以使用相同的优化方式,也没有完美的优化 java 应用程序的参考路径。使用最佳实践并且坚持采用适当的方式处理性能优化。想要达到真正最高的性能优化,你作为一个 Java 开发人员,需要对 Java 虚拟机(JVM)和底层操作系统有正确的理解。

以上五大知识体系是我从业多年总结出来的经验,都是当前最主流的技术。

下图是我总结性能优化应该学习理解的几大知识体系:


以上就是我推荐给大家的最具有系统化的学习体系,如果你想学习以上的知识内容,你可以加这个群获取:Java大神交流群:561614305 里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

阅读更多

没有更多推荐了,返回首页