如果走技术路线,架构师是个关键的结点。如果在大厂,一般有有6年时间足以升级到高级开发。因为在大厂里,能提供架构师所需的分布式组件开发调试以及上线的经验,上进点的程序员只要跟着大流,多通过排查问题观察底层,多通过压测或部署组件多实践缓存、高并发高可能之类的技术,想不升级到架构师都难。

但不少程序员止步于高级开发,在我之前的博文为什么很多程序员没有升级到架构师?里讲述了这一现象并分析了原因。如果是因为主观不上进导致自身发展受限,那么别人也帮不了你,不过我在面试候选人的时候,发现一些态度积极的程序员把时间和精力用在了不正确的技术方面,从而无法升级,这是相当可惜的。在本文里,就先从反面讲,哪些技术可以在升级到架构师以后再看,同时讲下从高级开发升级到架构师的关键技术,以及实践方法。

1 理论方面的知识,不必整本书地学

像网络,Linux操作系统,编译原理等理论方面的书籍,一般很厚,不过幸好,此类知识可以边学边看,比如要看linux线程并发方面的知识时,再看相关资料也不迟。

这里将综合多个大厂面试和开发的标准,给出理论方面需要掌握的普遍标准,反之没提到的就可以用到再学。

1 数据结构方面,了解链表,队列,堆栈,线性表,树和矩阵,图以及更复杂的无需了解,然后结合一种语言,比如Java,了解对应的对象,比如ArrayList。同时了解下红黑树,二叉树之类的概念,或许面试会问到

2 编译原理,了解状态机概念,可能会用到。

3 网络方面,理解七层网络协议,外带了解下tcp,udp和http协议细节即可

4 Linux方面,稍微会写命令即可。

5 数据库原理方面,也就了解些概念即可,比如索引原理,事务,范式和锁即可。

总之,与其花时间看整本理论方面的书,还不如多敲些实际的代码。

2 项目管理方面的技能,需结合实际,而无需啃书

这方面有很多经典,但看百本书,比如实践一个月,这方面的建议是,在架构师之前的阶段,看些相关软件管理的实践要点即可,比如敏捷开发里,头脑风暴以及迭代发布的实践要点,而且最好和你当前从事的软件管理模式相匹配,比如你现在用的是敏捷模式,那么就关于详细设计概要设计等文档的编写方式,大致了解下格式即可,也无需深入。

还是这句话,这方面的一些经典书,当你成为项目经理或高层以后,再看不迟,而且到了这个层次看了很有帮助。不过话说回来,目前在大多数的公司里,不是你在项目管理方面的技能很资深才提拔你成为项目经理,而是你对业务有一定了解,同时技术,尤其是解决问题的能力达到一定水平 ,而且沟通协调方面的能力还不错,才提升你。

在成为架构师之前,项目管理方面的技能大致要了解到什么程度呢?比如拿敏捷开发举例。

1 每天站会该如何组织,如何表面自己已做,未做和当做的事,如何表明自己任务的阻碍点。

2 如何维护每天站会所需的看板,看板上该有哪些模块,相关任务点该怎么写。

如果到了项目经理级别,还得会用看板,站会和任务纸条等方式管理项目,以及控制风险,但如果仅仅是架构师之前的开发,了解这两点即可,不用看过多其它的资料。所以为了升级到架构师,更应当把时间用在分布式等技能上。

3 虚拟机,底层代码,一定要对景实际问题,别脱离实际去看

我见过不少虚拟机方面的书,非常经典,从底层和细节全面讲述了虚拟机的结构和GC流程,同时也看过不少关于字节码结构方面的资料,此外,我也见了不少深入细节讲线程的书。这些书在面试方面对人的帮助优于提升技能方面。

为什么不建议在升级到架构师之前,过多看虚拟机等方面理论的资料呢?第一平时开发用到的可能性不大,第二看不用不久就会忘掉,第三对解决调优高并发之类的问题,也没什么太大的帮助。

而且,对于底层代码,也要解决问题去看,不建议大面积地看诸如集合,Spring IOC底层的源码。比如某天遇到因Kafka而导致的OOM异常,那么可以通过Debug到底层看消息相关流程,再排查问题,调试MyCAT的问题也可以这样。总之如果带有排查问题的目的,针对性很强,非常有帮助,就像围绕语境学习常用英语单词和词组,但如果大面试去看底层代码,就好比背字典,效果大家可以想象。

4 设计模式,软件重构之类的技能应放在项目大环境,别抽象学,更全面铺开学

这方面也有不少经典,可谓字字珠玑。这里我提两个问题。

第一,面试时如何考察这方面的技能?估计是问“你用过哪些设计模式?”,大家结合项目叙述下即可。

第二,在工作中你接收了一段代码,在此技术上新增功能,你敢按设计模式和软件重构方面的知识,重构现有代码吗?估计不敢,因为风险太大。

那么这方面的技能对程序员有什么帮助呢?

第一固然是面试时帮助加分,第二能让你在解决问题时有更多的方案,比如实现通知回调类需求可以用观察者模式,第三能帮助你的代码看上去不难看。

比如一些文学名著,对我们的帮助更多的是陶冶情操多涨知识,设计模式和软件重构类的著作能帮我们提升在软件开发方面的素养,在升级到架构师之前,这方面该掌握到什么程度呢?

1 了解必要的设计模式,而不是23种都面面俱到,需要结合项目问题了解,同时面试时,能结合你解决过的问题说明某些设计模式的细节。

2  了解软件重构方面的结论,比如哪类代码不好,该如何重构?

要达到这个程度,所需花费的精力并不多,但如果用大量时间看这方面纯理论的书,而不结合项目实际有选择性地调个别点来看,那么到了架构师以后,你会发现当初学的很多点对你的帮助并不大。

5 面试时如何考察架构师?架构师平时干哪些活?

在前文里,给出了一些无需着重看的技能点,无需着重看,并不是怂恿大家不学习,而是把看这些技能的时间用在能立竿见影出效果的技能上。

在讲架构师哪些技能不可缺之前,我们先来看下面试架构师的问题。

第一层问理论和实践细节,比如Netty的序列化方式,以及Dubbo针对不同级别设置超时时间的方式。

第二层问分布式调优和解决实际问题的技巧,比如如何配置MySQL主从模式,如何配置MyCAT读写分离外带高可用,如何压测,如何根据压测结果调优代码。

第三层问底层细节,比如dubbo协议,Netty读写索引的细节,kafka持久化,Redis超时失效机制等方面。

第四层是针对资深架构,问如何根据业务设计高并发框架,比如秒杀系统如何实现。

为什么要问这些呢?因为招进来的架构师需要在平时工作中干这些活,哪方面的活呢?

第一固然是高级开发所需的,分析和解决代码层面的问题。

第二是出了分布式组件方面的问题,首先知道该看哪些底层代码,即了解组件的重要组件和工作流程。而且这方面要有经验,比如出了Netty OOM问题,得知道该从堆外内存等方面排查,而且得优先检查通讯结束时release部分的代码,如果没问题再debug。这才是架构师比高级开发值钱的点。

第三得给出面向高并发高可用的方案,比如搭建负载均衡和限流组件等,而且不光是理论层面的,还得负责部署上线。

其实在我之前相关博文里,已经给出了类似内容, 上文只是总结。在下文里,将面向这个目标,给出升级到架构师不可或缺的技能,以及如何高效掌握这些技能。

6 要熟悉解决异常问题方面的组件技能

理论方面的技能应该很多,网上有很多xx大厂的面试题,而且大家只要稍微上心点,应该也能看到理论方面的相关技能,比如Netty重要组件,Netty协议等,但如果光知道这些用处不大,还得继续看解决异常方面的技能。

比如为了Dubbo超时会有什么危害,如何防治?或者Netty线程池满了以后该如何优雅降级。如何掌握这方面的技能呢?

第一到网上搜,比如用 Netty OOM异常,Netty 线上问题排查 等关键字查,这样好歹能知道该看哪些方面。我在CSDN上就看到不少结合问题分析分布式组件的文章。

第二结合平时遇到的线上问题看底层代码,分析为什么会出错,也就是说结合实践看。如果没机会实践怎么办?大厂里一般可以找其它组, 小公司一般比较全栈,估计在部门里多观察即可。

比如遇到一个MyCAT问题,大家可以先按照大神分析问题的步骤,再调试一遍代码,复盘下大神排查问题的思路,然后再扩大看下这个流程的细节,以及MyCAT的组件,这样哪怕一周遇到一次问题,一个月也有四次实践学习的机会,积累个半年,你的能力就大涨了。比起单纯看资料,这样的升级效率就高多了。

7 更要掌握全栈流程的分布式组件部署技能

这方面,要多向运维学习,小到linux命令和shell脚本,中到系统上线,大到扩容,你未必动手敲代码,但可以参与值班。架构师所需的高可能高并发技能是虚的,下面给出这方面的具体技能。

1 能通过jenkins或shell脚本部署组件的能力,系统上线时,需要了解灰度发布切流量的实践技巧。

2 未必需要了解底层,但需要配置高可用的集群,比如redis集群,一台机器出故障,第一会报警,第二能自动切换。

3 需要掌握优雅停机和迁移扩容的实践技巧,比如迁移服务时,如何设置优雅停机,扩容时,第一如何起新服务,第二如何把流量切到新服务上,第三如何设置回退预案。

4 如何组织压测,如何在压测时监控关键指标,如何根据压测结果优化性能。

还是这句话,如果当前没机会参与,就先在边上看,等给出结论后,再自己复盘看下相关技能的实践要点。这些技能就比较难得了,网上类似资料有,但很少,而且需要自己组织,所以更需要在平时工作中主动积累。我见过很多高级开发,平时也就注重在windows上开发业务,由于工作中用不到,他们为图省事,不去参与部署压测和扩容方面的工作,结果会在高级开发的阶段停滞不前,最后年龄上来了,导致无法升级。

8 随后才是看些面试题应对面试

我也知道,如果当前处于初级和高级开发阶段,平时被分配的工作任务很少涉及到上述架构师所需要的技能,但并不意味着你身边就没有架构师,工作中就看不到这方面的技能,当你通过观察复盘,结合案例掌握了架构师相关技能后,如果在大厂,那么自然有机会升级到架构师,但如果在小公司,那么你就需要多刷相关面试题了。

这方面的题太多了,比如redis面试50题,xx大厂 dubbo面试xx题。如果光看这些题,面试官一旦结合案例问dubbo细节,一定能问出你没相关经验。如果被问出没相关实践经验,那么甚至你面不上大厂的高级开发岗,更别提架构师了。

但现在你已经积累了案例经验,那通过刷题积累更广泛的技能,那么面试架构师,甚至面试大厂架构师,都不是问题了。或者退而求其次,你或者可以先进大厂做高级开发,这个职位也能积累架构师的经验,这总比在小公司前途要光明。

9 总结:不为炫耀学,学的时候更得注意优先级和方法

我们看书,不是为了向朋友炫耀自己了解多少,而是要提升自己解决实际问题的能力,看底层代码同样也如此。

在明确目标的前提下,我们也要明确学习的优先级和方法,比如一些对现阶段帮助不大的技能,可以延后学,而对升级到架构师有帮助的技能得结合实际问题学。

总之目标得明确,所谓在正确的阶段做正确的事。如果要走技术发展路线,要升级到架构师,所有的学习都得是为这个目标。如果当前的技能无法满足大厂的面试需求,应方向正确,优先结合项目实践看分布式组件技能,而不是继续挖掘单机版这类对架构师帮助不大的技能,而且总是先深入技能,再看能帮助提升知识面的各种著作。

本人在之前也写过不少关于升级到架构师技巧的文章,比如以互联网公司的经验告诉大家,架构师究竟比高级开发厉害在哪?而在这篇文章里,是针对了一些升级方法上的误区,先讲述哪些技能无需过度学,再讲述哪些技能得优先结合项目学,自认为能在前文的基础上,进一步帮助大家在升级到架构师的路上少走弯路,希望大家能喜欢。

最后感谢大家能读完本文,祝大家新春愉快,身体健康,万事如意。

为了升级到架构师,程序员无需过度关注哪些技能?哪些技能不可缺?相关推荐

  1. 零架构项目经验的程序员,如何升级成架构师

    先说目前关于架构师的一些是实际情况. 1 要成为Java架构师,单纯靠学知识一定不行,得靠在项目里积累经验. 2 如何判断程序员是否已经成为java架构师?不是看程序员掌握的技能,更不是看程序员干的活 ...

  2. 5分钟弄懂程序员的如何升级到架构师。

    对我们程序员来说,发展的途径要么是走管理岗,从开发升级到项目经理甚至是部门经理:要么走技术升级路线.不过在技术路线方面,无法升级到架构师的程序员不在少数.一方面,在不少公司的高级开发岗位上,无法让程序 ...

  3. 为什么很多程序员没有升级到架构师?

    对我们程序员来说,发展的途径要么是走管理岗,从开发升级到项目经理甚至是部门经理:要么走技术升级路线.不过在技术路线方面,无法升级到架构师的程序员不在少数.一方面,在不少公司的高级开发岗位上,无法让程序 ...

  4. 从初级到资深:程序员的职业生涯思考与可迁移技能培养

    在去年的一年里,我经历了一次 "升职":从一个咨(cheng)询(xu)师(yuan)变成了一个高级咨询师.Title 变了,就意味着工作的内容也会发生一些变化.从拒绝升职,到被说 ...

  5. 阿里六年团队Leader实战秘诀|程序员最重要的八种软技能(找工作/就业生必读)

    前言 此笔者在带团队的六年中发现,程序员们在职场都有一个共同的困扰:"好像写代码都没什么问题了,日常工作基本上都是应付业务需求的开发,好像找不到其他的更大的附加价值了,我应该找一些什么样的发 ...

  6. 六年团队Leader实战秘诀|程序员最重要的八种软技能

    前言 笔者在带团队的六年中发现,程序员们在职场都有一个共同的困扰:"好像写代码都没什么问题了,日常工作基本上都是应付业务需求的开发,好像找不到其他的更大的附加价值了,我应该找一些什么样的发力 ...

  7. 程序员应该学习掌握哪些知识和技能?

    现在做为一名程序员,压力越来越大,各种开发工具越来越庞大.不断推陈出新,各种开发设计工程理念缤纷精彩.需要融入平常的开发当中,还有很多新的知识点在不断开拓中,相比以前,做为一名程序员尤其是合格程序员的 ...

  8. 程序员的自我修养——读《软技能-代码之外的生存指南》笔记

    我记得曾经读过俞甲子的<程序员的自我修养--链接.加载和库>,当时就觉得这个书名起的不太合适,有点不合主题,因为这本书主要讲述链接库的事情,我认为这个是编译器的一部分,是作为程序员要掌握的 ...

  9. 2019年,有远见的程序员都在关注这些硬核公众号

    2019年就要结束了,2020年,你有什么愿望吗? 希望自己一夜暴富,希望工作顺利,希望幸福安康... 不管怎样,都希望我们不要忘了为自己"充电". 小编经过几百次的踩坑,终于给大 ...

最新文章

  1. 又一位!26岁当上985博导,这才是乘风破浪的姐姐!
  2. 太阳的光和灯光有什么区别_太阳光
  3. 注册登录案例用MVC和mysql_用MVC模式实现简单用户登录注册功能
  4. Flask之DButils
  5. 操作系统内核(linux)
  6. 使用 Windbg 分析一个 异步操作 引发的 Crash 异常
  7. ARCore-Unity3d教程2 - 基本概念
  8. iOS端im实时音视频功能快速开发实操指导!
  9. C/C++ 图像二进制存储与读取
  10. 精通Hyperledger之Hyperledger composer建模语言(15)
  11. 如何用犀牛自带的电池快速制作tekla自定义截面
  12. 商品分类,汉码批发进销存管理软件
  13. 对话阿里云弹性计算负责人褚霸:把计算做到极致,关键还加量不加价!
  14. 计算机管理系统功能模块,设备管理系统功能模块
  15. GitHub快速学习-三
  16. 小波包变换/能量特征提取/结果图绘制-python代码
  17. Revit安装失败怎样卸载重新安装Revit,解决Revit安装失败的方法总结
  18. 常用相似性、相关性度量指标
  19. 抽象代数 04.08 自由幺半群与自由群
  20. NPN和PNP传感器区别及接线

热门文章

  1. 中间件:Nginx总结
  2. TCL脚本语言光速入门教程,一篇就够了(超全查表)
  3. AD15元器件向导封装
  4. MySQL_DDL数据定义语言_刘锋的博客
  5. 数据守护主备集群搭建
  6. 【《C Primer Plus》读书笔记】第16章:C预处理器和C库
  7. 程序猿小明需要为公司员工的个人信息录入编写前端代码,html +css +js正则表达式 实现个人信息登录表
  8. 查看Windows系统安装和卸载驱动的日志信息
  9. squid正向代理 反向代理 CDN加速
  10. 【干货】看过上千份简历后的经验总结