点击关注"爱笑的架构师"

右上角"设为星标"好文章送达比别人快

最近有很多读者问:怎样成为一名架构师?

在大家眼中『架构师』的地位高高在上,不可逾越,其实不然,架构师并没有想象中那么难,我认识一个小企业的架构师,他工作了9年,但是感觉水平也就等同于阿里 P6到 P7的水平。

在一个公司能否成为架构师关键在于你是否比你身边的人优秀,如果你的能力超过身边人几个层次,那架构师的职位非你莫属了。

废话不多说,下面以 Java 语言为例聊聊一个刚毕业的学生如何一步一步修炼最终飞升。

师傅领进门,修行在个人

在文章中我只会指出道路,相当于送你一本修炼武功手册,但修行之路还得靠个人努力,有不明白的地方可以问谷老师,如果大家具体对哪一块感兴趣可以留言,后续可以作为一个系列展开来讲。

阶段一:炼气

炼气其实就是对应入门,这一阶段需要掌握:

1、Java:俗称 JavaSE。不仅仅指 Java 语法,还有 JDK 的使用和源码理解,这块知识非常庞杂也非常重要,沉下心花几年学好它。推荐学习方式:

(1)《Effective Java》让你感受一下 Java 里面的弯弯绕绕,并不是简单语法表现的那样傻白甜。

(2)OCJP 考试,这个是 Oracle 官方的认证考试,可以让你全方位了解 Java 里面的细节,非常重要。

(3)《并发编程实践》多核 CPU 自带 L2 cache 却共享内存和线程,复杂的锁,一行 Java 代码却编译为多行机器指令而 CPU 在任意机器指令间都可切换线程。面对这么复杂的硬件环境,Java 是如何设计保证程序正确的。

2、算法和数据结构

(1)Leetcode刷题。虽然只有极少的开发会用到算法,但这是内功的体现。不要以为会写个单链表反转就可以了,至少要把动态规划级别的算法搞懂。

(2)《算法导论》,这本读读就行了,希望你能读懂。

阶段二:筑基

万丈高楼平地起,一砖一瓦皆根基,学习和建筑一样根基非常重要,根基决定着你未来的高度。飞升修仙也是一样的,这一阶段你需要掌握:

1、设计模式:《设计模式》,Gang Of Four。四杆老枪的设计模式,教会你一些固定招式应付各种经典场景。

2、JVM:《深入理解 Java 虚拟机》。在早些年,如果你说你懂 JVM 原理,那你就是国内Java顶尖人才了,现如今 JVM 知识已经烂大街,成为面试必备八股文。你需要了解 JVM 如何使用内存,如何 GC,如何调整启动参数,如何查看 dump 文件。

3、网络编程:需要搞懂 HTTP、TCP/IP 协议,了解一根网线如何串起整个网络。

4、分布式系统各种中间件

(1)Dubbo,这是国内最知名的开源项目之一,找一本阿里出的 dubbo 书读。无中心化分布式架构的核心取代了 IBM 的 SOA 产品(中心化架构容易造成性能瓶颈)。

(2)ZooKeeper,推荐读 ZooKeeper 小红书。ZK 是分布式系统数据一致性协调工具。在单机进程中代码执行被认为是完全可靠的,要么执行成功要么执行失败,而到了分布式系统,进程之间网络调用经常会出现超时,出现超时就麻烦了,到底是成功了还是失败了没法简单判断。理解 CAP 理解分布式系统数据的一致性是分布式系统不出错的保障。

(3)Kafka,推荐《Kafka 权威指南》。要理解其为什么那么快又那么可靠又那么大存储空间。这同时也是理解幂等性最方便的系统。

(4)MySQL,假装也是中间件了,推荐《MySQL高性能》,《MySQL 技术内幕:InnoDB 存储引擎》。要了解红黑树和索引的实现方式,了解 InnoDB 存储引擎的工作原理,你才能更好的理解 explain sql 后出来的各种回显结果,从而帮助你更好的调优 SQL。顺便说一句 MyISAM 被废弃了,你可以少看一本书了,偷着乐吧。

(5)nginx。之所以能有多个幂等存在就全靠它了。学习一下它的单线程技术,明明是单线程却能做到高性能。nginx:我就是看不上你多线程,咋啦?唯有真正理解计算机原理才能返璞归真。

(6)Netty,推荐《Netty 权威指南》。在2002之前很多系统都是阻塞 IO,随后的几年中计算机网络突然提速了,这是为什么?2002发布 JDK1.4,2004年出现 Netty,之前大量的计算机网络性能都被阻塞在 IO 上没有被释放,NIO 出现后大幅度提升了 IO 效率。我猜测,在 JDK 支持了 NIO 之后,Tomcat 等 web 容器很快跟进升级,于是全世界在硬件资源没变的情况下网络站点的并发响应能力却大福提升了。

(7)Flume,一个日志收集传输系统。

(8)Protobuf,序列化也是性能中需要重点关注的地方。

(9)Tomcat,太有名了,学学其 classloader 设计思想。

5、JavaEE,一个名存实亡的企业级开发标准,大部分已经被业界抛弃,依然有用的知识,如 servlet,JMX 等。一个时代的落幕,唉。

6、编译原理和操作系统:我假设你上大学的时候学过了,如果没有学过,操作系统至少要读一下,推荐清华大学的本科教材。

7、分布式数据库体系架构,需要掌握分库分表、异构索引、数据库主备等。推荐读一下阿里的 OceanBase,《大规模分布式存储系统:原理解析与架构实战》。另外推荐一本《数据密集型系统设计》,堪称存储设计的通史。

8、Spring 和 Mybatis,掌握使用,能读懂源码更好了。

9、UML 建模,推荐《UML 用户指南》。

阶段三:化神

这个阶段是最难晋升的了,多少开发者都被阻塞在这一步难以前进。因为既要承担繁重的开发任务,又要学习那么多的知识,还要处理个人的生活,打工人太难了。这些知识对你的提升又只是相加不是相乘的关系。熬过去你就海阔天空化神了。

这一阶段你会发现学习曲线越来越陡峭了,你要掌握:

1、架构设计方法论,推荐《软件架构设计》,教会你做事的章法。

2、领域驱动设计,推荐Eric 的《领域驱动设计》,很晦涩不太容易懂。软件是真实世界在计算机中的虚拟映射,需要学习如何让软件更贴近真实世界。

3、中台:中台这个词近些年太火了,这个词最早是阿里提出来的,推荐找阿里的书读一下。

4、高性能调优:真正了解计算机的本质才能做到性能调优,推荐读《性能之巅》。

5、稳定性建设:推荐阿里的《逆流而上》,这可不是小说,主要讲阿里巴巴集团荣耀背后的技术血泪史,分享了一些典型的踩坑案例。

6、两地三中心容灾系统建设:这个主要靠实践经验了。

7、全链路压测:对系统的性能瓶颈节点的探查,对系统 QPS 的掌控。

8、大数据:离线海量数据存储与计算的 Hadoop,将 Hadoop 变得更易用的 Hive,流计算的 Flink,自成一套的 ELK,尤其是弹性搜索 ElasticSearch。

9、数据仓库:大数据都学了,顺便也把数仓也学了吧,顺手的事。

10、网络安全:这一块我没有涉足,不班门弄斧了。

这一阶段我对技术的介绍越来越粗了,因为你之前打的基础可以支撑去学习这些粗粒度的技术,你也应该有自己的学习方法了,也能自己去找书学习了。

阶段四:渡劫

经过上面几个阶段的洗礼,你基本上已经成为技术骨干,组内技术大牛,但如果想在公司内或者行业内崭露头角,你需要在技术上再上一个台阶。

1、中间件实现细节:随着业务的快速发展,一些开源中间件不能完全满足要求,可能需要改造中间件,甚至再造一个轮子,你需要对中间件的实现细节了如指掌。

2、再扩展一下领域,比如 AI 领域,需要有数学基础,要了解各种论文与算法的实现。

3、也可以往 IOT 方向发展,随着5G 的发展,这个领域我持续看好。

总结

技术成长之路漫漫,需要积累和坚持,相信终究有一日你可以飞升成仙成神。

- END -

2021年Java工程师飞升成神之路相关推荐

  1. java入门到成神之路的宝藏资源

    大家好,给大家先做个自我介绍 我是码上代码,大家可以叫我码哥 我也是一个普通本科毕业的最普通学生,我相信大部分程序员或者想从事程序员行业的都是普通家庭的孩子,所以我也是靠自己的努力,从毕业入职到一家传 ...

  2. Java程序员成神之路

    类变量和类方法(static) 什么时候需要用类变量 当我们需要让某个类共享同一个变量时,可以考虑将变量设置为类变量 类变量和实例变量的区别 类变量是该类的所有对象共享的,而实例变量是每个对象独享的 ...

  3. Java小白怎么学?2021年最强版Java工程师成神之路

    以下文章来源于爱笑的架构师 最近很多读者在问:Java 怎么学习啊 ?有没有什么学习路线 ?Java " 成神 " 之路怎么走? 当然「成神」是有些夸张了,我相信问这句话的读者或多 ...

  4. 《Java工程师成神之路》终于免费开放下载了!

    很多Java程序员一直希望找到一份完整的学习路径,但是市面上很多书都是专注某一个领域的,没有一份完整的大图,以至于很多程序员很迷茫,不知道自己到底应该从哪里开始学,或者不知道自己学习些什么. 好在,很 ...

  5. GitHub上12k Star的《Java工程师成神之路》中终于开放阅读了!

    很多Java程序员一直希望找到一份完整的学习路径,但是市面上很多书都是专注某一个领域的,没有一分完整的大图,以至于很多程序员很迷茫,不知道自己到底应该从哪里开始学,或者不知道自己学习些什么. 好在,很 ...

  6. Java工程师成神之路思维导图

    前面看Hollis的微信公众号更新了Java工程师成神之路的文档,感觉里面的内容清晰.齐全,可以用来审视自己,也能够知道自己在那些方面可以继续前行,想着有时间把它画下来,画下来之后分享出来. 主要内容 ...

  7. java工程师知识架构图图_阿里技术专家教你画架构图、Java 工程师成神之路 | 2019 年 2 月收藏排行...

    五一假期,头条君会推送 2019 年 1-4 月 开发者头条 上收藏最多的文章 点击链接或图片 即可阅读 喜欢请 分享到朋友圈 哦 Java 工程师成神之路(2019 正式版) 结构调整,更适合从入门 ...

  8. Java 工程师成神之路 | 2019正式版 1

    Java 工程师成神之路 | 2019正式版 基础篇 01 面向对象→ 什么是面向对象 面向对象.面向过程 面向对象的三大基本特征和五大基本原则 → 平台无关性 Java 如何实现的平台无关 JVM ...

  9. Java工程师成神之路 | 2022正式版

    基础篇 面向对象 什么是面向对象 面向对象与面向过程 面向对象的三大基本特征 面向对象的五大基本原则 封装.继承.多态 什么是多态 方法重写与重载 Java的继承与实现 Java的继承与组合 构造函数 ...

最新文章

  1. 解析 Callable Runnable Future 使用和原理
  2. 实用 JavaScript 调试技巧
  3. 华为荣耀6 H60-L02/L12(联通版)救砖包【适用于无限重启】
  4. c语言mysql自动重连接_c++操作mysql数据库
  5. 送10本今年最火的《动手学深度学习》
  6. sa密码修改记录_【数据完整性】一文读懂电子记录与电子签名
  7. linux如何判断网线插入_快速鉴定网线质量的常用方法
  8. 传统的6d位姿估计fangfa1_基于视觉的机器人抓取从物体定位、位姿估计到抓取位姿估计 | 公开课预告...
  9. [渝粤教育] 广东-国家-开放大学 21秋期末考试组织行为学10068k2
  10. 企业微信有权限查看通讯录吗?
  11. 关于CDN和DNS技术的解析以及搭建智能DNS的方法
  12. chrome浏览器F12调试模式network不显示接口请求地址解决办法
  13. 推荐系统与深度学习(十七)——DIN模型原理
  14. android 坚挺通话广播_Android智能机 摩托罗拉MileStone坚挺
  15. nyoj 305 表达式求值 (递归)
  16. 无法启动此应用因为计算机丢失,解决提示“无法启动此程序,因为计算机中丢失chrome_elf.dll”的问题...
  17. Mongo的常用的相关语法
  18. activiti的简介
  19. 如何缩短网址,将长网址转换为短网址
  20. 1446282-28-5,PEG5-bis-(ethyl phosphonate)含有两个乙基膦酸盐部分的PEG连接物

热门文章

  1. python及pygame雷霆战机游戏项目实战01 控制飞机
  2. □ 影片名:《拳霸2冬阴功》(20240) 在线播放
  3. 面试之路(13)-android apk之间共享数据的方式以及shareUserId详解
  4. 基于gradle的dependency-management配置实现多模块springboot依赖库的版本管理
  5. JetBrains 推出全新数据科学 IDE——DataSpell
  6. 场景化AI数据推动智慧家居发展
  7. 跑步运动耳机哪个牌子好,值得推荐的六款跑步运动耳机
  8. mysql超市表格_py mysql结合面向对象,实现类似超市导购机器的功能【1.初始化表数据】...
  9. URAL 1517. Freedom of choice (后缀数组)
  10. 计算机职业道德英语作文,考研英语作文范文-英语职业道德类作文来啦!