怎样成为一名架构师?

在大家眼中『架构师』的地位高高在上,不可逾越,其实不然,架构师并没有想象中那么难,我认识一个小企业的架构师,他工作了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 的发展,这个领域我持续看好。

总结

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

最后

如果你想要学习Java的话,我给你分享一些Java的学习资料,你不用浪费时间到处搜了,从Java入门到精通的资料我都给你整理好了,这些资料都是我做Java这几年整理的Java最新学习路线,Java笔试题,Java面试题,Java零基础到精通视频课程,Java开发工具,Java练手项目,Java电子书,Java学习笔记,PDF文档教程,Java程序员面经,Java求职简历模板等,这些资料对你接下来学习Java一定会带来非常大的帮助,每个Java初学者都必备,请你进我的Java技术qq交流群自行下载,所有资料都在群文件里,进去要跟大家多交流学习哦。

硬核干货,Java工程师飞升之路相关推荐

  1. 超硬核的Java工程师分享,什么是Java?为什么我要做Java,我是如何学习Java的?

    Java是啥 新手程序员通常会走入一个误区,就是认为学习了一门语言,就可以称为是某某语言工程师了.但事实上真的是这样吗?其实并非如此. 今天我们就来聊一聊,Java 开发工程师到底开发的是什么东西.准 ...

  2. 硬核干货Java集合详解

    目录 一.问题是最好的老师 二.集合的由来 三.数组存在的问题 四.数组和集合的区别? 五.集合是什么? 六.集合整体架构图 七.集合架构图详解 1.Collection 2.List ArrayLi ...

  3. sqlsever主库从库如何切换_超硬核的Java工程师分享,什么是Java?为什么我要做Java,我是如何学习Java的?...

    Java是啥 新手程序员通常会走入一个误区,就是认为学习了一门语言,就可以称为是某某语言工程师了.但事实上真的是这样吗?其实并非如此. 今天我们就来聊一聊,Java 开发工程师到底开发的是什么东西.准 ...

  4. 硬核干货合集!500+篇Java干货技术文章整理|资源|书单|工具|面试指南|强烈建议打开!

    今天给大家推荐一位在阿里做Java的朋友给大家,他是公众号[程序员书单]的作者黄小斜. 他的公众号[程序员书单]这两年来累积了200多篇优质原创文章,独家原创的系列文章有<五分钟学编程>系 ...

  5. 硬核干货来了!手把手教你实现热力图!

    以下内容转载自腾讯位置服务公众号的文章<硬核干货来了!鹅厂前端工程师手把手教你实现热力图!> 作者:腾讯位置服务 链接:https://mp.weixin.qq.com/s/bgS7uFl ...

  6. 超硬核全套Java视频教程(学习路线+免费视频+配套资料)

    文内福利,扫码免费领取 Hello,各位锋迷们,我是小千.很多学习Java的小伙伴都在找的全套免费java视频教程,这里全都有,资料齐全,拿来吧你! 零基础学Java的学习路线图是怎样的?! 曾经写过 ...

  7. e站app里站hosts_硬核干货区 | E站的国际站运营知识星球上线啦

    朋友们大家好,E站已上线了知识星球内容库和问答圈,以阿里国际站,Wordpress自建站,Google SEO的更新内容为主,用原理技术的视角+全栈运营的思维去加成对店铺的运营和优化,知道为什么要这样 ...

  8. 硬核干货:网易云音乐如何做产品创新

    网易云音乐是大家非常熟悉和喜欢的一款产品,作为一个音乐类应用,成功融合进了社交等元素,满足了多样化的用户需求.那么今天产品系就带大家揭秘网易云音乐是怎样做产品的,而揭秘者正是网易云音乐的产品总监沈博文 ...

  9. 史上最硬核全套Java视频教程(学习路线+视频+配套资料)

    Hello,各位锋迷们,我是小千.很多学习Java的小伙伴都在找的全套免费java视频教程,这里全都有,资料齐全,拿来吧你! 零基础学Java的学习路线图是怎样的? 曾经写过很多次关于Java学习指南 ...

最新文章

  1. python字典用法(创建、添加、删除(del()、clear()、pop()、popitem())、修改、查找(get()、keys()、values()、items())、更新update、遍历)
  2. 2017-10-6Linux基础知识(4)安装Linux及设置语言环境
  3. mysql存放图片的数据表_mysql数据库可以存图片吗?
  4. 2021考研数一李正元400题、张宇4套卷题目整理
  5. oc语言和c语言,C语言及OC语言初期学习心得
  6. 阿里凑单算法首次公开!打包购商品挖掘系统解析
  7. maven webapp栽坑录
  8. IOS TableView详解
  9. Cognitive Surplus 认知盈余
  10. 美团前期运营模式(怎么吸引商家入驻?怎么吸引用户?)
  11. 互联网盈利模式,网络策划运营模式
  12. 电子设计教程35:LC振荡电路
  13. 【NOIP2006】金明的预算方案
  14. 【中等】航班预定系统
  15. 语义分割的常用指标详解
  16. 使用PHP提取视频网站页面中的FLASH地址
  17. 爬取防盗链图片福利你懂得
  18. 构筑数字底座,同济医院用全闪存提速智慧医疗
  19. 一千万条数据去重_Mysql千万级数据快速去重
  20. 财报向好,但悦刻们迈入至暗时刻

热门文章

  1. python 边读边写文件_Python 文件读写
  2. cannot use column (type Column) as type gorm.ColumnType in append:
  3. SSM三大框架+SpringMVC的工作原理及其流程
  4. 江苏农牧科技职业学院考计算机,江苏农牧科技职业学院2020年提前招生简章
  5. 浅谈网络支付加密安全流程思路(安全性极高)
  6. 外贸ERP管理软件如何优化企业生产-汇信
  7. 2022-2028全球与中国CAE软件市场现状及未来发展趋势
  8. 怎样让百度收录你的网站
  9. 信息安全工程师第二版重点案例分析【建群网培】
  10. 啥是搜索引擎优化?SEO优化到底怎么做?