后端开发工程师工资一般是多少(展望后端研发工程师的 2023:“后端难学”源于知识体系匮乏,面试时这三点是加分项)

wufei123 发布于 2024-01-02 阅读(222)

最新php菜鸟教程

作者 | 凌敏  后端开发很“卷”吗?学习路线是什么样的?就业前景如何?展望 2023 年,后端研发工程师需要提升哪些技能,做好哪些准备?1 月 4 日,微财数科资深工程师周正杭做客教程 InfoQ 视频号,畅聊后端研发工程师的技术成长路线与职业发展路径等话题。

以下根据直播内容整理,有不改变原意的删减,完整内容可点击查看回放视频(https://www.infoq.cn/video/教程8oZi40ex8z5R9OB9A8YR)1 如何从普通工程师成长为资深工程师?  。

InfoQ:您当初为什么会选择后端研发这个职业方向?可以分享一下您的技术成长经历吗? 周正杭:我的职业选择其实与学教程校期间所学的方向、擅长的技术有关我毕业后的第一份工作是在一家做第三方支付的公司中负责内部管理平台的后端开发,在工作一年后也接触到了公司的通用化支付产品。

在这期间,我对复杂的业务流程、高并发处理,以及流教程量激增的应对方式产生了浓厚的兴趣,并在接下来的近十年时间中一直专注于后端研发的工作 InfoQ:您是如何一步步地从普通工程师成长为资深工程师的呢?在这个过程中付出了哪些努力?

周正杭:其教程实毕业生们在刚进入职场时,常常会感到迷茫和挫败由于理论学习环境与实际工作间的差异,我们很难将学到的点状知识应用到公司长久积累下的技术框架和业务系统中但这很正常,学校学习的内容很难追赶上互联网的发展速度教程。

不过,既然能加入公司,说明公司是看重我们的能力和未来发展潜力的因此,我们要抛出这种可能的挫败感,用最短的时间做最多的事,尽量让自己熟悉工作实战的经历我在当时花费了两年的时间才逐渐熟悉工作中的单体应用教程及后期的 Kafka 使用,夯实自己技术能力的同时,也在理论设计模式和基础数据结构的实际应用中,提高了自己工作的信心。

在工作两年后,我作为公司的研发主力,进入了个人工作的上升期,也遭遇了工作之中的瓶颈教程在面对诸如大流量下如何对服务降级、高并发中如何进行压力处理等情况时,我们会学习开源代码中的优秀思路、设计模式、代码风格以及深层技术,并将其应用到工作中,解决类似问题。

比如,我们会将学习到的 senti教程nel 窗口算法应用到金融领域中的支付系统中,处理资金系统中业务异常的兼容、成功率调控等场景这种学习也能快速帮助个人实现成长在工作五年后,我遇到了互联网金融的快速发展时期,并加入了一家创业公司。

和其他教程公司的工作模式不同,创业公司没有较为健全的部门体系和职能划分,常常会有一人身担研发、测试、产品、需求数职的情况我们需要从基础技术实现层面中跳出来,关注产品的规划,明白产品功能的存在意义虽然很累,对个人教程也颇具挑战,但却能得到很全面的发展。

当然我并不是建议大家都进入创业公司,这里只是提供一个思路,希望大家能多关注其他职能部门同事的工作内容,这会帮你更为出色地完成自己的工作在这一阶段,我作为公司技术的负教程责人之一,组建并带领团队在两周时间完成了一个初版金融产品的上线,并在后续的多年间无数次的快速迭代。

期间也遇到了许多初创公司在技术开发工作中常见的配合问题,如项目质量及进度管理等,我们通过研究学习敏捷开教程发方式,引入多维度管理方式丰富日常工作经历,让项目进展更为顺畅这段时间对我来说也是快速横向发展的时间。

离开初创公司后,我加入了现在的微财数科公司,担任资深工程师,负责公司核心的账务系统内容从初创公司的教程乱战节奏转回到正规的开发模式,整体工作风格再次发生转变,与众多职能部门重新建立合作,这种差异化的工作内容也丰富了我自身的经历。

InfoQ:您在从小公司到大公司的过程中,是否会有不适应呢? 周正杭:这是教程肯定的,大小公司的主要差异在于其规范性举例来说,小公司中的需求改版,只需要大家想清楚怎么做,开发自测没什么问题就可以上线,但大公司中却还是需要遵守一定的流程避免出错。

除此之外,二者的技术深度与体量也必教程然是不同的小公司的金融产品每月放贷量峰值可能只有 6000 万,这在大公司看来可能连一天的量都不够因此,无论是流量激增还是服务架构的调整升级,大小公司的差异化都是非常大的。

InfoQ:您之前提到,从学教程校到职场的转变过程中可能会面临很多挑战可以分享一个您之前面临过的挑战,以及您的解决方法吗? 周正杭:后端技术架构方向的主要工作内容,是向上承接后端业务研发,向下协调基础运维部门。

我们既要服务后端业务系教程统稳定运行(监控组件日常运行、处理极端问题等),又要协调运维等部门多关注机器运行的状况我认为我们最大的挑战是基础架构,我们不仅要关注纯技术方面的工作内容,也要特别考虑如何服务好业务。

我们先前做的内部云教程服务发布系统在初期阶段,利用容器化技术进行更稳定、更快速的轻量级发布底层的 Kubernetes 最初虽然只支持 Rolling Update 的发布模式,但因为其通用化,我们并没有觉得有什么不好。

在教程后期,因为用户及内部维度的多元化,我们对稳定性及发布策略的多样化有了更多的需求先前单节点的 Rolling Update 在循环滚动发布时会终止老节点,导致在途流量的不稳定以及断连接异常,对于频繁为 教程C 端提供服务的后台服务而言影响较大。

因此,我们基于 Kubernetes 特性,考虑业务对稳定发布、平台上线的需求,研发了类似蓝绿发布、金丝雀等小流量验证发布的功能,从原先纯后台的工作走向了前台业务教程场景,充分考虑业务需求而进行的优化 InfoQ:现在新兴技术非常多,我们要如何保持自己的技术敏感度呢?

周正杭:在建立知识体系的基础上,我们可以上网浏览资料、现场参加活动等等其次,我们也教程可以在 InfoQ 等渠道上收获他人对新技术及其应用的见解分享我们今年也与 InfoQ 合作,陆续发布了许多文章,交流见解与思路。

在遇到性能瓶颈等问题上,也会从 InfoQ 等网站高效地搜寻适合的解决教程思路2 后端研发工程师的硬实力和软实力   InfoQ:后端研发给人的第一感觉就是很“高大上”,需要掌握很多种技术,基础架构方向的后端研发工程师最需要掌握哪几项技术?

周正杭:很多像是分教程布式操作系统之类的经典理论和架构均是建立在存储、计算、通讯等后端底层上,这些协助涉及了底层文件系统进程的 RTC,并以此为基础进行同步调度只要计算机依旧作为资源存在,这些问题就会以不同的尺度反复出现、教程反复被解决。

在初期阶段,我们需要了解的有:网络基础通信:TCP/IP 协议、HTTP 协议等;Linux 基础操作指令:grep 模糊匹配、kill 杀进程等;操作系统运行原理;进程与线程的关系及其在教程高并发场景中的应用;

列表、数等数据结构;排查找等常用算法在掌握一定技术基础后,我们要更深入地解决更多技术问题:框架类问题:Spring Boot、网络框架、.NET 框架等;持久化层:MyBaits、教程Hibernate 的实现原理,要如何防止 SQL 注入等攻击;。

应对大流量,系统的削峰策略;Kafka、RabbitMQ 的应用场景及各自特性而当大家最终成长为技术专家、CTO 级别时,我们就需要关教程注更高层面的技术,比如 Service Mesh、配置中心等原理 InfoQ:除了您所提到的这些技术硬实力,优秀的后端研发工程师还需要具备哪些特质呢?

周正杭:后端研发最重要的是细心如果教程我们的代码进入了死循环,或引发内存泄漏,都有可能导致线上服务崩溃在我毕业后加入的第一家公司中,身为初级工程师的我接触到了公司的核心支付业务因为一个错误的金额传值,线上出现了发售金额异常的错误,直接导致教程公司受到了损失。

在后续的工作中,我会自我要求不断精进,培养自测试的习惯,严格要求自己做事做到极致在接手公司的全国通用款产品时,我提前找测试组沟通可能涉及的测试点、异常以及风险点,自己编写了一些测试用例教程,并提前进行了一周左右的自测时间。

在实际进入测试阶段时,我在近 200 个测试用例中没有遇到任何 bug希望能通过我的这次血淋淋的教训,能让大家牢记后端研发中最基础的要求——细心其次,我认为后端研发不教程仅需要关注技术,也要周全考虑如何能在满足公司业务需求的情况下设计优秀的架构。

程序员们或许大多只关注如何将自己的代码写好,而不愿与人交流,但其实一段代码是否符合业务目标才是我们最大的痛点有时我们常常会发教程现代码并不能做到自己想做的事,因此我们一定要多思考业务,思考我们是否能对服务起支撑作用。

InfoQ:对于技术人员而言,是所有岗位都需要具备业务思维吗?还是只针对某些岗位而言? 周正杭:我认为所有的技术教程架构精进都应该以服务为目标以基础架构为例,我们从单体应用到分布式应用,再到微服务的发展,不仅仅是因为代码会更高级、系统吞吐量处理更强,而是因为这种发展解决了我们对业务稳定性支撑的需求。

基础架构中,借由教程 Kubernetes 的单节点滚动发布确实可以解决现有的发布工作,但由于我们的业务、内部服务对系统稳定性有要求,因此才需要做更多的工作以满足需求我认为对后端研发来说,业务思维是尤为重要的,我们要明白教程代码、流程背后的原因其实都是业务,只有满足了业务才能体现出技术的价值。

InfoQ:有用户提问,您认为最好的编程语言是什么? 周正杭:仁者见仁智者见智,编程语言没有好坏之分,区别只在于适用场景 教程 InfoQ:您认为后端是否很“卷”呢? 周正杭:我认为“卷”其实并不恰当。

技术人最关注的常常是自己的技术是否高超,所用工具是否新潮,这可能也是导致外界会认为后端研发非常“卷”的原因技术人对自己教程的要求,对自己于公司的发展、对未来技术规划等等都与之密切相关人人都希望在最短的时间做最多的事,接触更多的技术。

3 如何做好职业规划?   InfoQ:后端研发工程师如何做好职业规划?职教程业发展路径是什么样的? 周正杭:有的时候我们带着兴趣工作,会更容易达成自己的目标后端工程师的职业发展大致分为两个方向:希望深挖技术。

可以通过大量实战,对基础组件研究深挖,从初级工程师、高级工程师、资深教程工程师,一路发展到架构师、技术专家、CTO 等职位对公司的技术方向进行把控,对较低级别工程师进行技术上培训,从而让员工迅速提升,保证整体技术产出。

对复杂业务流程感兴趣可以沿着技术管理、项目管理方向,从教程工程师晋升至项目经理、技术经理、技术总监等岗位,日常工作中仅一半的时间在编码,另外一半则需要游走在各个部门,负责资源协调、规范制定、资源编排、工期监督等工作。

其他方向售前架构师、技术培训讲师等等我们需教程要尽快制定自己未来发展的目标,并为之努力任何一个职位都能有自己独当一面的机会 InfoQ:后端适合转岗到哪个岗位呢? 周正杭:这大概也是很多程序员在工作压力下辗转反侧、夜不能寐时常常思教程考的问题,问题的答案取决于我们所处的阶段及我们擅长的事。

的确,产品经理是个不错的转型方向,但前提是我们不仅需要懂技术,也要对现有业务知识、产品流程有深入的理解,能够与其他团队进行沟通另外像售前工程师,教程虽然日常编码工作不多,但却需要对公司已有技术产品有足够的了解,配合公司销售、推销产品,根据用户需求痛点进行定制化推荐。

InfoQ:您在面试后端研发工程师时,会注重求职者的哪方面能力?有哪些是加分项? 教程周正杭:在面试时我一般会关注三个点:基础知识初级工程师需要掌握牢固的基础知识能力,中级、高级工程师则需要对中间件使用、高性能场景下对性能瓶颈排查、微服务及分布式系统架构的使用场景、通过深层次源码解释不教程同注册中心的区别、一致性及高可用性的保障方式等等。

产品思维这点在互联网非纯技术类公司中非常重要,优秀的产品思维不仅可以减少沟通成本、快速传达项目目标,也能在做技术的同时主动思考产品化缺陷沟通能力这是程教程序员普遍的薄弱点,也是我认为的加分项没有良好的沟通能力,外界无法得知你的想法,真正需要表达的时候又因为没有与他人足够高的默契度而难以传达自身想法。

InfoQ:很多技术人在日常生活中不擅长或不喜沟通,这教程种情况下要如何提升自己的沟通能力呢? 周正杭:称不上经验,只能说是实战小技巧,但有了这项技能我们才能更全面地提升自己我先前提到看重沟通能力其实也有我本身经历问题的影响。

我刚到公司时,在项目评审、需求评教程审等场合都不怎么说话,导致沟通成本过高但沟通能力也不是一夜之间就能练好的,我们要先学着做一个“捧哏”,才能成为一个合格的“逗哏”我们只有强迫自己走出舒适区开始说话,才能逐渐建立与他人沟通的默契,分享交教程流技术、业务知识。

除此之外,沟通能力在跨部门协作时也非常重要我在协调产品与研发之间合作时,曾遇到过因为需求沟通不明确而导致的双方不断发生矛盾,作为研发部门负责人,我需要主动打破沟通壁垒、跨部门进行问题教程剖析在多轮沟通后,我们才输出了合作的规范化流程,让大家的配合更加顺畅。

InfoQ:有用户提问,“我已经 35 岁了还是一线职员,该怎么办”? 周正杭:这是一个很现实的问题能够思考这个问题,说明你已经确教程定了目标,但可能还做不到但如果你连目标都不确定,那么可能真的需要仔细想想了。

我们应当确定自己的远大目标,通过持续努力,培养自己的沟通能力、产品思维,深挖组件原理、源代码等等,通过这些积累才能确定自己未教程来的方向 InfoQ:技术架构与技术管理是否均需要全栈方向的发展? 周正杭

:只有对自己所用的技术非常了解时,才能去进行技术框架、管理类工作技术管理人员需要对团队与产品的稳定性负责,要有教程足够的知识储备,才能应付如 MQ 突然到达水位线,导致堵塞夯死情况的触发及快速恢复方式等日常的异常情况。

技术架构也是如此公司自有架构的设计、内部效率的提升、分布式事务解决手段、分库分表时 MyCat 教程中间件还是 JDBC 的选择,等等,在拥有足够的基础知识储备后,我们才能在全面分析后针对应用场景给出最合适的匹配。

像是大数据方向知识目前对架构设计而言可能用不上,因此我们也可以针对自己未来的发展和技术教程方向,提前做出预言2023 年,值得关注的后端技术趋势 InfoQ:2023 年,后端领域有哪些值得关注的技术方向? 。

周正杭:这主要与公司所处环境相关,而公司的发展则是影响个人技术发教程展方向的重要因素之一在新的一年里,我们会更多地关注效率提升,无论是云原生、Serverless、低代码化技术等等都应该提上日程我们要通过更少量的资源投入、应用的精细化管理、快速迭代,维护或突破现有业务教程,从而达到更大产出。

InfoQ:您认为后端学习是否很困难呢? 周正杭:“后端难学”的主要原因是知识发展体系的匮乏只有建立了技术框架的认知,建立了应用场景,才能明白技术究竟为什么实用理解了操作系统对线上教程应用的影响,才明白操作系统为什么有用;理解了分布式缓存时如何抵挡大流量,从而保护数据库、提高相应速度,才明白缓存有什么用。

我们在看书时也可以从目录的标题看起,目录的编排路径一定是由浅入深的技术介绍 教程 InfoQ:有用户提问,重构代码要如何打开思路? 周正杭:我们首先要确定驱动代码重构的原因,以及代码重构后能达成的结果对于十年来一直保持 Spring MVC 单体应用基础架构的公司而言教程,代码复杂度不言而喻,业务逻辑全部都在一个服务节点内,那么这种情况下重构是必然的。

重构可以为我们解决服务稳定性、维护性,降低内部服务通讯成本但我们不能盲目进行重构,新框架的应用会带来技术成本投入,未知教程技术会带来未知异常,从而导致业务事故、生产事故问题我们也不应直接进行根本性重构,可以从业务逻辑代码重构开始。

在重构过程中我们要实时关注业务导向,确保重构不会偏离对业务的支撑以我们的低代码改造为例,我们教程的目的是提高渠道对接效率在重构过程中,我们前期投入成本非常高,梳理了上千种不同业务流程中的共同点并界定抽象方法,但后期成功后使用非常顺畅。

InfoQ:您认为对于后端研发工程师来说,2023 年可能面临教程的最大挑战是什么? 周正杭:整体发展方向取决于业务,但个人而言,我们可以自我驱动,向 Serverless、云原生应用、低代码化改造等方向发展;也可以自我确立中短期发展的里程碑,比如学习一门新编程语言教程,完全了解并实际应用卡夫卡等等。

通过连续可触达的发展规划,我们能够持续地自我激励,以高昂的情绪继续寻求发展 InfoQ:对于希望成为后端开发工程师的年轻人,您会有什么建议或忠告呢? 周教程正杭:我的建议可以分为三点:编程语言基础无论是 C、C#、C++、Java、Go、PHP 等语言,掌握了语言才能掌握工作的工具,才能与同行进行交流。

知识体系的建立工具、技术方法学习利用业余实践多学习,教程只有这样才能提前适应工作 InfoQ:一位合格的研发工程师需要懂几种语言呢? 周正杭:这个问题也是见仁见智应用场景不同,语言的需求也各异大部分公司为减少多语言技术投入,会组件化统一技术教程栈,因此如果只是为了工作,那么一门语言足矣。

但如果目标是全栈或创业工作,那么安卓、iOS 客户端的编程语言必然不同,服务后端选择 PHP 或 Java 也是不同,再加上数据库与大数据层面,都需要不同基教程础我们可以在学习新的一门编程语言后,思考对比其与已知语言的差异并分析其优劣,更好地交付应用。

如果在学习新语言后发现旧语言的缺陷确实很大,那么我们旧需要投入成本去学习另一种语言从而完成应用投产 教程 InfoQ:请您给大家推荐几本书籍吧 周正杭:我会从两个方向进行推荐底层操作系统方向我推荐《深入理解计算机系统》。

这本书出版时间较早,从程序员的角度深入讲解操作系统对应用的影响,在每个章节均有教程实战经验帮我们更好地理解操作系统后端开发有时会忽视操作系统、JVM 调优方向,只会在 OM 问题、CPU 占用量剧增导致生产问题出现时,才会现场研究操作系统方面知识。

第二本则是经典的《人月神话》这本书教程针对技术研发、项目管理等方面提供了很多参考案例在项目进度不如意时,我们常倾向于投入大量人力追赶进度但大面积地引入新人会带来大量工作交接及培训成本,浪费了时间也降低了效率,我们应当维持现有团队,通过合理教程化结构调整,正常进度内追赶上工期。

InfoQ:站在 2023 年伊始,您能为后端研发工程师们送上一句祝福吗? 周正杭:希望大家能保持对自己未来发展方向的渴望,就和乔布斯所说“stay hungry, 教程stay foolish”,时刻清楚自己的成长目标,每天都要学习,让自己进步,积极的情绪能帮助大家快速成长。

点击底部阅读原文访问 InfoQ 官网,获取更多精彩内容!今日好文推荐阿里辟谣海外建全球总部教程;科技巨头加速裁员,商学教授直呼企业管理层愚蠢;谷歌Fuchsia OS部门遭遇重大打击 | Q资讯副业搞得好、赚钱没烦恼:新春程序员寻找“副业”灵感指南

一个科技新时代开启,硅谷五巨头将何去何从修完又教程复活!史诗级Log4j漏洞爆发1年仍“阴魂不散”,下一场暴雷可能已在路上

亲爱的读者们,感谢您花时间阅读本文。如果您对本文有任何疑问或建议,请随时联系我。我非常乐意与您交流。

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。