• 通往架构师之路的三本书,高分!


    之前我写过几篇架构师、架构设计相关的文章。说实话,想通过几篇文章就把架构师的方方面面说明白,挺难的。

    这可能需要一系列的文章,今天就给大家安排了这篇文章。

    很多程序员都有和下面类似的困惑:

    为什么很多程序员成不了架构师?
    高级程序员和架构师之间有什么区别?

    我认为,架构师和高级程序员最主要的区别在于,两者之间的思想维度上。

    我举个例子,假如现在有个需求:公司想要做一套直播卖货的系统。

    产品需求给出来了,在我成为架构师之前,作为程序员的我会怎么想?

    我的想法可能是最简单直接的:

    • 需求中的礼物打赏如何实现
    • 是不是得有房间
    • 房间的逻辑是如何实现的
    • 滚屏弹幕该怎么落地
    • ……

    也就是说,作为程序员,我的第一反应是:业务如何转化为技术,各种业务功能是如何用技术实现的。

    那么,在我做过架构师之后,我会怎么想呢?

    如果是我牵头负责这个,除了这些业务转成技术的问题,我还需要思考如下问题:

    • 架构用单体还是微服务
    • 通信方式都有哪些
    • 中间件选哪些比较好
    • 普通存储和多媒体存储该如何规划
    • 应该选什么样的架构风格
    • 可靠性,弹性,可用性该怎么保障
    • 开发成本、部署成本、维护成本
    • 成本与系统性能的折中
    • ……

    以上,只是架构师典型思考的几个宏观问题。

    其实,在一套系统中,架构师不仅仅只是思考这些宏观问题而已。更会深入细节,去解决各种层次的技术难题。

    回到直播问题上,架构师还必须去解决一系列技术难题,比如:

    • 直播的卡顿问题
    • 通信协议的优化问题
    • 各种中间件的优化问题
    • 存储的一致性问题

    总的来说,一名程序员,他的思维往往是自下而上的,就是先思考功能实现,再根据功能实现去理解整个系统的运行机制。

    而一名架构师,他的思维往往是自上而下、自下而上相结合的。

    他本能的就会先去想系统的架构,根据系统的架构,再去根据架构的雏形,去根据各个业务定出业务模块之间的通信方法,再根据通信方法去理解各个业务模块的耦合,去想着一些代码实现难题,最后去完整的理顺整个系统的技术实现。

    所以,一名程序员想要成长为一名合格的架构师,必须经过思维的转变。

    而这种转变,需要多读一些好书,让这些书中的知识,来对个人的思维进行一次大清洗,从而使得这种转变更加容易和更加准确。

    我在这里想推荐 3 本书,这 3 本书能让程序员们对架构师的工作先有个初步的了解,从而让他们能对架构的思维略窥门径。

    1.《架构师修炼之道》

    要转成架构师思维,首先得知道架构师是如何思考问题的,当业务人员给出具体的需求之后,架构师们是如何根据需求去做对应的设计和分析的。

    因此,我推荐先可以看看《架构师修炼之道》这本书。

    这本书的英文版我其实也读过,自认为里面的所思所想,确实是我做架构时都考虑过的事情,甚至里面提及的一些思路,我自身都没考虑过。

    这本书,我认为可以作为程序员转架构师的第一本书:

    它起码会提醒程序员,从上到下思考系统架构,到底是怎样的一个思路。

    了解了架构师是如何从上而下的思考和设计系统架构的,初步对架构师的思维有了些许印象后,就需要找个师傅能全面带你一把,能通过走一遍架构师的工作流程,去开始尝试架构师工作入门,去通过实践,一点点的让这些思维形成习惯。

    2.《从零开始学架构》

    而这个师傅我认为是《从零开始学架构》这本书。

    这本书读起来非常快,读的也很过瘾,是我看到的最贴近中国架构师日常实践的书。

    书里面对架构师从设计到经常用的模式,以及对应的理论都做了介绍。

    尤其是架构设计中的一些重要的大坑,和架构师重要的取舍思想都做了清晰的介绍,非常适合帮助实践入门,对程序员的技能提升有肉眼可见的帮助。

    书的作者李运华还在极客时间出了对应于这本书的课。前几天有读者在群里问这门课,我当时还没反应过来,只是觉得名字耳熟,写这篇文章的时候才想起来。

    不过,我本人没订过他的课,听同事讲,说的不错,和他写的书形成了有效的互补。

    3.《Thinking Architecturally》

    我前面说的两本中文书,缺少了很重要的一部分,就是

    架构师是对新技术是如何调研和学习的。

    架构师引入新技术,也是架构师工作很重要的部分。

    这方面的书,我读过的极其出色的一本就是《Thinking Architecturally》。

    只是可惜这本书是英文书。不过,我始终认为,作为 IT 行业的程序员,英语还是重要的,国内引进的优秀技术书籍毕竟有限,很多优秀的书籍因为语言问题,从而错失品鉴的机会,非常可惜。

    这本书介绍了怎么评估新工具、新技术,包括新技术引入后的一些注意事项,介绍的都非常详细。

    可以说,从我读过这本书以后,看新技术、学新技术、引入新技术都有了坚实的理论基础。不仅如此,读了这本书以后,我甚至引入新技术后,风险的预估能力都提升了非常多。

    而且更难得的是,这本书写的十分通俗易懂,也不需要太多的技术门槛。也强烈推荐入门阅读。

    以上 3 本书,我认为对一名打算将来进阶成为架构师的程序员,作为入门的引导,以及寻找后面努力的方向是非常足够了。

    要知道,架构师不仅仅是个工作,同时也代表着各种各样的更高阶的技术能力,而要提升能力之前,先拥有一套全局的架构师思维,知道架构师都做什么事情,从而能得到努力前进的方向,是极其重要的第一步。

    迈出这一步之后,你就会明白,什么架构模式、架构设计、各种原理,都是以架构师的思维为基础的工具。

    希望大家能把 3 本书好好学一遍,把通往架构师的路走的更加坚实。

    原创不易,希望得到你的三连支持

    ps. 感谢你看到最后,有惊喜!

    我特意找了前两本书的电子版,如果想获取,可以扫下图的码,关注后,在公众号后台回复:架构师

  • 相关阅读:
    python內建模块之datetime
    python实现两个经纬度点之间的距离和方位角
    Python实现DBScan
    关于sru源码class Model的parameters
    pytorch之LSTM
    pytorch对可变长度序列的处理
    pytorch函数之torch.normal()
    PyTorch学习系列(九)——参数_初始化
    ubuntu16.04系统搜狗输入法的安装
    Scala 匿名函数
  • 原文地址:https://www.cnblogs.com/siyuanwai/p/15246611.html
Copyright © 2020-2023  润新知