前言:
最近有好多人问我说:“George,怎样才能成为公司里的前线主力架构师,我现在在公式已经干了快五年了,现在还是一个默默无闻的程序员,我也通过很多种渠道来突破我现在瓶疾,但就是走不出来,技术也一直没有突破上去,我真的是没有办法了,通过朋友推荐介绍,说您这里可以解决我的技术瓶疾,所以我想请你帮我突破一下技术方面上的瓶疾。”
你们是否有也有类似这样的问题——“天天写业务代码的程序员,怎么成为技术大牛,开始写技术代码?”
今天,我和我之前一起共事的朋友,一起探讨出了这么一个结论:要怎样努力才可以成为公司主力架构师。
不管是开发、测试、运维,每个技术人员心里多多少少都有一个成为技术大牛的梦,毕竟“梦想总是要有的,万一实现了呢”!正是对技术梦的追求,促使我们不断地努力和提升自己。
然而“梦想是美好的,现实却是残酷的”,很多同学在实际工作后就会发现,梦想是成为大牛,但做的事情看起来跟大牛都不沾边,例如,程序员说“天天写业务代码还加班,如何才能成为技术大牛”,测试说“每天都有执行不完的测试用例”,运维说“扛机器接网线敲shell命令,这不是我想要的运维人生”。
我也是一位程序员,所以我希望通过以下基于程序开发的一些例子,帮助大家解决这些困惑。大道理是相通的,测试、运维都可以借鉴。
成为架构师的几个误区
第一:拜大牛为师
有人认为想成为技术大牛最简单直接、快速有效的方式是“拜团队技术大牛为师”,让他们平时给你开小灶,给你分配一些有难度的任务。
我个人是反对这种方法的,主要的原因有几个:
大牛很忙,不太可能单独给你开小灶,更不可能每天都给你开1个小时的小灶;而且一个团队里面,如果大牛平时经常给你开小灶,难免会引起其他团队成员的疑惑,我个人认为如果团队里的大牛如果真正有心的话,多给团队培训是最好的。然而做过培训的都知道,准备一场培训是很耗费时间的,课件和材料至少2个小时(还不能是碎片时间),讲解1个小时,大牛们一个月做一次培训已经是很高频了。
因为第一个原因,所以一般要找大牛,都是带着问题去请教或者探讨。因为回答或者探讨问题无需太多的时间,更多的是靠经验和积累,这种情况下大牛们都是很乐意的,毕竟影响力是大牛的一个重要指标嘛。然而也要特别注意:如果经常问那些书本或者google能够很容易查到的知识,大牛们也会很不耐烦的,毕竟时间宝贵。经常有网友问我诸如“jvm的-Xmn参数如何配置”这类问题,我都是直接回答“请直接去google”,因为这样的问题实在是太多了,如果自己不去系统学习,每个都要问是非常浪费自己和别人的时间的。
大牛不多,不太可能每个团队都有技术大牛,只能说团队里面会有比你水平高的人,即使他每天给你开小灶,最终你也只能提升到他的水平;而如果是跨团队的技术大牛,由于工作安排和分配的原因,直接请教和辅导的机会是比较少的,单凭参加几次大牛的培训,是不太可能就成为技术大牛的。
综合上述的几个原因,我认为对于大部分人来说,要想成为技术大牛,首先还是要明白“主要靠自己”这个道理,不要期望有个像武功师傅一样的大牛手把手一步一步地教你。适当的时候可以通过请教大牛或者和大牛探讨来提升自己,但大部分时间还是自己系统性、有针对性的提升。
第二:业务代码一样很牛逼
有人认为写业务代码一样可以很牛逼,理由是业务代码一样可以有各种技巧,例如可以使用封装和抽象使得业务代码更具可扩展性,可以通过和产品多交流以便更好的理解和实现业务,日志记录好了问题定位效率可以提升10倍等等。
业务代码一样有技术含量,这点是肯定的,业务代码中的技术是每个程序员的基础,但只是掌握了这些技巧,并不能成为技术大牛,就像游戏中升级打怪一样,开始打小怪,经验值很高,越到后面经验值越少,打小怪已经不能提升经验值了,这个时候就需要打一些更高级的怪,刷一些有挑战的副本了,没看到哪个游戏只要一直打小怪就能升到顶级的。成为技术大牛的路也是类似的,你要不断的提升自己的水平,然后面临更大的挑战,通过应对这些挑战从而使自己水平更上一级,然后如此往复,最终达到技术大牛甚至业界大牛的境界,写业务代码只是这个打怪升级路上的一个挑战而已,而且我认为是比较初级的一个挑战。
所以我认为:业务代码都写不好的程序员肯定无法成为技术大牛,但只把业务代码写好的程序员也还不能成为技术大牛。
第三:上班太忙没时间自己学习
很多人认为自己没有成为技术大牛并不是自己不聪明,也不是自己不努力,而是中国的这个环境下,技术人员加班都太多了,导致自己没有额外的时间进行学习。
这个理由有一定的客观性,毕竟和欧美相比,我们的加班确实要多一些,但这个因素只是一个需要克服的问题,并不是不可逾越的鸿沟,毕竟我们身边还是有那么多的大牛也是在中国这个环境成长起来的。
我认为有几个误区导致了这种看法的形成:
(1)上班做的都是重复工作,要想提升必须自己额外去学习
形成这个误区的主要原因还是在于认为“写业务代码是没有技术含量的”,而我现在上班就是写业务代码,所以我在工作中不能提升。
(2)学习需要大段的连续时间
很多人以为要学习就要像学校上课一样,给你一整天时间来上课才算学习,而我们平时加班又比较多,周末累的只想睡懒觉,或者只想去看看电影打打游戏来放松,所以就没有时间学习了。
实际上的做法正好相反:首先我们应该在工作中学习和提升,因为学以致用或者有实例参考,学习的效果是最好的;其次工作后学习不需要大段时间,而是要挤出时间,利用时间碎片来学习。
如何突破和避免以上几大误区
如何突破以上的误区,那就看你怎么学习,有没有一套系统化的学习体系给你学习,有没有一个学习氛围的群,有没有一群是遇到瓶疾一起突破的兄弟姐妹。有么??????我这里有。
我向大家推荐一下我认为比较全面且最系统化的学习体系(分解后的,完整的加群可以获取)
一、源码分析
二、分布式架构
三、微服务
四、性能优化
五、Java工程化
以上就是我推荐给大家的最具有系统化的学习体系,若果你想学习以上的知识内容,你可以加这个群获取:交流学习群:433-540-541里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多
那么问题又来了,学完以上的课程体系后,就能成为公司主力架构师么?答案是:NO
要想成为主力架构师,还需知道以下知识
要想成为软件开发的专家,需要我们完整了解软件开发的流程,并在关键部分掌握丰富经验。
需要我们了解设计模式和算法的细微差别,同时遵循软件开发的最佳实践,包括创造性和思考力,为编程问题提供合适的解决方案。
实现这一目标需要掌握服务器端开发、客户端开发、DevOps运维、云计算、网页设计、分布式系统、数据库、编程规约、代码管理、基础设施管理、可扩展性、安全性待方面的能力。
你可能未必全部掌握以上内容。但是可以尝试从表层了解绝大部分内容,然后再深入掌握其中几个技术。
以下给各位列出开发者缺乏的几个主要技术能力,而技术管理者或架构师在招聘这些职位时应该熟悉检查这些要素。
编码规范
编码规范有助于确保良好的开发实践和产品开发。要了解一些最重要的编码规约:
DRY(不要重复自己),SOLID , TDD , 防御性编程
设计模式
设计模式在软件开发中是一种常见的,可重复使用的解决方案,可解决软件中的常见问题。软件开发者要了解一些常见的Design Partern是非常重要的,还有更重要的是要能够识别给定问题的正确设计模式。如MVC、Singleton、DAO、Facade、Proxy、Adapter、Strategy和Absract Factory等一些一流开发者使用的设计模式。
服务器端开发
在较复杂的软件系统中,后端会有各种各样的逻辑。作为后端开发人员,处理应该程序的业务逻辑就要面临很多挑战。任何开发人员都能够编写代码,但是只有有经验的开发人员才可以写出具有高性能、可伸缩性和可靠性都好的高质量代码。开发优秀软件的过程涉及的领域包括大量科学、数学、计算机等专业知识,有处理的思维和经验非常重要。
高速缓存
数据缓存的各种机制(文件、数据库、内存、反向代理、HTTP....)
内存管理
Java有一个非常好的垃圾收集器,能够自动管理内存,清理未使用的对象并释放一些内存。但是一个资深的Java开发者需要对内存的工作原因有一个非常透的理解,这样才能写出高性能和优化的应用程序。
了解以下概念至关重要:
堆栈,堆,强引用,弱引用,转义引用,如何引用字符串,垃圾收集过程,meta空间,垃圾收集器类型。
异常处理
这是一个相当重要,也是一个比较大的话题,我们后续会再写关于它的专门文章。现在,列出一些处理异常的一些良好实践:
1、遵循“错误优先”原则使软件更可靠
2、不要捕捉无法恢复的异常
3、不要记录完异常后,又将异常抛出来
4、选择正确的层来处理异常(例如:DAO不知道是数据库的故障如何处理,但是服务层可以知道)
5、如果无法从异常中恢复,则优先选择未经检查的异常
IO操作
了解I/O操作的成本以及可能出现的不可预知的结果。
异步编程
使用线程实现Java中的异步编程,它也是Java平台的基础部分,有效使用并发对于构建高性能应用程序非常重要。
比如线程池、死锁、生产者-消费者、原子性、不可变对象、信号量等等词汇对资深开发人员来说不应该是新东西。
批处理
在实际场景中,编写批量作业非常普遍。通常执行重要的任务,有一些基本规则:
1、每个任务应该按输入、处理过程与输出进行划分;
2、始终轮询批量输入数据;
3、处理器应该是线程安全;
4、产出物应该为原子属性;
5、存储工作结果;
6、要考虑EIP模式。
分布式计算
在现代世界中,分布式计算是指使用分布式系统来解决计算问题。然而,分布式系统与传统系统不同,具有非常高的复杂性。当用户开始高速增长资源消耗较大时,有分布式系统工作经验的工程师会在此时发挥作用。微服务软件体系结构是分布式计算以及分布式体系结构所有的优点与折衷的一个很好的例子。
而今,微服务是当今软件工程师之必备技能,就需要我们对分布式系统有丰富的经验。
比如容错性,可用性与一致性,分布式事务/事件、同步与异步通信,分布式认证,分布式应用,共识应用程序等非常重要。
数据库
精确掌握与数据库从通信到获取数据中要涉及的所有成本,如连接握手、数据传输等情况。清楚了解原子事务以及如何确保数据一致性。因此,数据库管理是软件开发人员的必备技能。
数据库用于管理数据,这是一项艰巨的任务,即使不考虑将业务逻辑添加到数据库中。 在大型IT系统中,数据库在安全性,可伸缩性,容量和可用性方面面临着诸多挑战。我们要考虑加密,复制,分片,大数据等问题。 了解数据库的工作方式以及如何优化它以及每项处理消耗的成本(例如,占用内存、CPU数)将有助于有效设计系统的数据库管理。
DevOps
主力开发工程师要有能推动DevOps的文化理念和实践的能力,在所有运维步骤中做到自动化,提高高质量和高速度交付应用程序与服务能力。代码部署或配置基础设施必须为自动化,且要灵活以及受到监控。
一个强大的开发者应该很好地了解从测试,发布到部署和基础架构管理的全开发生命周期。需要我们了解云计算,Linux,网络,容器,工程管理等。
代码管理
鉴于代码的重要性,只有主力开发人员才能够掌握代码生命周期,并力促软件工程最佳实践。 为此,需要你熟谙源代码管理系统,比如Git,对分支策略,版本控制,分布式修订控制,另外还有代码质量保证工具,代码间的通信和依赖管理,配置管理等有清晰的思维。
安全
Web安全是件很难处理的事情,一部分取决于许多外部参数; 软件工程师需要遵循构建安全Web应用程序的最佳实践与准则。
主力工程师需要对信息安全有较深的理解,不仅要如何避免构建不安全与容易受攻击的系统,还需要知道保护用户的隐私。
一个伟大的开发人员需要能够创建一个指南来处理前10个Web应用程序安全风险。 在Web应用程序中,我们有更多需要工程师关注安全威胁,其中包括如下:
1、上传文件检查;
2、密码暴力破解;
3、会话到期处理;
4、会话来源验证;
5、通过网络安全通信;
6、安全的Cookie访问;
7、用户凭证处理。
前端开发
前端开发是软件开发重要的一部分,如果您不知道程序设计与良好用户体验的关系,则不能成为主力软件工程师。
在前端世界中,Javas和CSS是软件工程师必备的。 在这两方面掌握掌握并不容易,但了解它们的工作方式以及两者如何与HTML连接一起,使我们能够提供出色的用户体验非常重要。
若要领导一个前端团队,你需要知道的不仅仅是如何建立一个漂亮布局,要想前端开发做得更好,你需要了解如下:
1、浏览器作为引擎可以构建什么?
2、如何开发响应式网站;
3、如何提高网站的性能;
4、如何开发单页面应用程序;
5、如何建设现代高效的发展环境;
6、熟悉HTML5 API。
7、熟悉React.js或Vue.js框架
为了掌握这些技能,开发人员需能够自我激励,主动学习新技术,并在职业生涯中给自己扣上很多帽子。 继而不断挑战自我,然后更好地解决问题,这就是编程的本质。 知识很重要,在某些复杂问题的情况下更是如此。在变化如此之快的IT技术领域中,知识的获取在任何时候比我们已会的技能更为重要。
需要学习,获取资料的也可以加下上面推荐的那个群,希望可以帮助在这个行业发展的朋友和童鞋们,在论坛博客等地方少花些时间找资料,把有限的时间,真正花在学习上。
相关推荐
《测试架构师修炼之道:从测试工程师到测试架构师1》这本书,就是为了指引那些期望在测试领域不断进步的工程师们,提供了一个清晰的成长蓝图。 ### 测试的核心——测试策略 测试工作并不仅仅是对业务的熟悉或者...
但不论何种角色,技术技能和业务经验都是架构师不可或缺的硬指标。 互联网+时代,系统架构展现出几个特征:首先是产品敏捷化,这体现在弱化长期规划,强化快速迭代,实施敏捷开发,并且业务调整的速度很快。其次是...
通过《InfoQ_ArchSummit全球架构师峰会_Day1》的学习,参会者不仅能够掌握最新的架构设计理念和技术,还能了解到如何将这些理念应用于实际工作中,以解决复杂的技术问题和挑战。这场峰会无疑为参与者提供了一个宝贵...
本次峰会的PPT汇总,囊括了67份精彩纷呈的演讲内容,为无法到场的技术爱好者提供了一次难得的学习机会,这些资料不仅是对大会成果的记录,更是架构师们分享经验、交流智慧的宝库。 在峰会上,来自不同领域、具有...
ArchSummit 2023全球架构师峰会深圳站(公开)PPT汇总,共42份。 基于自动化治理实践驱动数据成本零增长 AIGC浪潮下我们的关注方向 AIGC驱动的3D场景理解及医学图像解析 AI大模型落地的前景和痛点 AI多媒体技术在...
在《2009系统架构师大会PPT:吴静涛:架构师–企业的未来》这一演讲中,吴静涛先生作为F5中国区的技术总监,深入探讨了架构师在企业中的重要作用及其面临的挑战。 ##### 架构师的基本职能: - **响应业务需求**:...
【2017全球架构师峰会PPT】是一场汇集了全球顶尖架构师的盛会,其核心议题涵盖了金融科技(Fintech)的技术创新路径、数据库架构的深度探讨以及主题演讲等多个关键领域。这次峰会旨在分享最新的技术趋势和实践经验,...
ArchSummit全球架构师峰会是极客邦科技旗下InfoQ中国团队推出的重点面向高端技术管理者、架构师的技术会议,54%参会者拥有8年以上工作经验。 ArchSummit聚焦业界强大的技术成果,秉承“实践第一、案例为主”的原则...
人人都是架构师+分布式系统架构落地与瓶颈突破+高清完整版 本书并没有过多渲染系统架构的理论知识,而是切切实实站在开发一线角度,为各位读者诠释 了大型网站在架构演变过程中出现 系列技术难题时的解决方案。本书...
《架构师成长之路》这本书是为那些志在成为优秀架构师的IT专业人士量身打造的指南。它深入探讨了架构师的角色、职责以及如何在职业生涯中逐步提升自己的技能和视野,以适应快速变化的IT环境。 一、架构师的角色与...
ArchSummit 2023全球架构师峰会北京站(公开)PPT汇总,共42份。 混合云架构及技术风险防控实践 多租户多数据中心的架构演进 从广告应用中台建设看架构思维成长 从互联网到 ToB 服务 从NewSQL到全新的HTAP分布式...
全书分为四部分:概述、高可用原则、高并发原则、案例实战。从负载均衡、限流、降级、隔离、超时与重试、回滚机制、压测与预案、缓存、池化、...该书适用于任何对分布式系统架构感兴趣的架构师、开发人员以及运维人员
ArchSummit深圳 2019年全球架构师峰会PPT合集(59份)。 10PB天日志系统设计和实现 专为物联网优化设计的大数据平台 中台技术架构实践与思考 直播前端工程体系实践 云上DevOps工具链架构实现 新趋势下架构师的机遇...
管理架构师是企业管理领域中的重要角色,他们负责构建和维护企业的管理体系,确保企业能够在日益竞争激烈的市场环境中保持领先地位。管理架构师通过制定战略、设计组织结构、优化流程等方式,为企业提供高效、稳定和...
天翼云认证解决方案架构师题库知识点,帮你直接通过天翼云解决方案架构师认证考试。天翼云认证解决方案架构师题库知识点,帮你直接通过天翼云解决方案架构师认证考试。天翼云认证解决方案架构师题库知识点,帮你直接...
架构师是一个职业名称,而不是一个技术高下的职位名称。要想成为一个优秀的架构师,需要具备“个人特性”和“技术技能”两个方面的能力。“个人特性”包括人际关系的能力和业务能力,而“技术技能”则包括技术专业...
系统架构师是一个在IT行业中至关重要的角色,他们负责设计、规划和实施复杂的计算机系统,以满足业务需求。历年高级系统架构师真题是备考这一专业资格考试的重要参考资料,涵盖了从2009年至2017年的历年试题,旨在...
下载过程比较复杂,所以整理了一下,欢迎大家下载。 合集整理了两天的所以PPT, 一共有六个压缩包。 2年后我才发现我设置的积分下载没给我。。。。索性直接0积分了
通过阅读《一线架构师实践指南》,读者不仅可以提升自己的技术知识,还能学习到如何在实际项目中应用这些知识,成长为一名优秀的架构师。无论你是初入行业的新人,还是寻求进阶的老手,这本书都值得你仔细研读。
《软考架构师配套讲义》是...综上所述,《软考架构师配套讲义》这份资料将带领考生系统地学习这些核心内容,帮助他们构建全面的架构设计知识体系,以期在考试中取得优异成绩,并在未来的工作中成为一名优秀的IT架构师。