(转载非原创)IT架构师基本技能

架构师(Architecture)是目前很多软件企业最急需的人才,也是一个软件企业中薪水最高的技术人才。换句话说,架构师是企业的人力资本,与人力资源相比其能够通过架构、创新使企业获得新的产品、新的市场和新的技术体系。那么什么是架构师、架构师的作用、如何定位一个架构师和如何成为一个架构师呢?这是许多企业、许多程序员朋友希望知道的或希望参与讨论的话题内容。
所谓架构师通俗的说就是设计师、画图员、结构设计者,这些定义范畴主要用在建筑学上很容易理解。小时候到河中玩耍,经常干的事就是造桥,步骤如下:1、在沙滩上画图;2、选择形状好看、大小适合的石头;3、搭建拱桥。其中我们挑出来画图的那位光PP小孩就是传说中的“架构师”了。 在软件工程中,架构师的作用在于三方面:1、行业应用架构,行业架构师往往是行业专家,了解行业应用需求,其架构行为主要是将需求进行合理分析布局到应用模型中去,偏向于应用功能布局;2、应用系统技术体系架构,技术架构师往往是技术高手中的高手,掌握各类技术体系结构、掌握应用设计模式,其架构行为考虑软件系统的高效性、复用性、安全性、可维护性、灵活性、跨平台性等;3、规范架构师是通过多年磨砺或常年苦思顿悟后把某一类架构抽象成一套架构规范,当然也有专门研究规范而培养的规范架构师。他们的产物往往也分为应用规范和技术规范两类。

与建筑学类似,如果软件系统没有一个好的架构是不可能成为成功的软件系统的。没有图纸的建筑工地、没有设计的造桥工程都是不可以想象的混乱世界。建筑工程如是,软件工程中亦然!

由于国内合格、胜任的软件架构师极为少见,直接导致了我国民族软件产业水平的落后。在未来以信息产业为主导的社会,信息产业水平的低下将直接影响国家核心竞争力。究其原因,无企业非急功近利、个人缺乏引导。

企业的急功近利是有无法克服的原因的,那就是社会发展总体水平。“生存是第一位的,赚钱是第一位的”,多年来许多客户抱怨国内的软件公司无法信任、系统项目累做累败、公司越换越差,但因国外不可能给中国做应用系统项目还不得不找国内软件公司做。由于人月费用低、公司开发成本高,软件企业对于应用只能草草了事,拿钱走人(很多公司拿不到后期尾款)。这样的环境下,企业几乎无法投入更多资源培养自己的架构师,加上眼花缭乱的跳槽风气企业更是不愿投入…… 字串3

那么要成为架构师的途径似乎只有现在较为流行的软件学院和个人自我培养了。关于软件学院我接触过不少,其宗旨绝大部分都是造就(or打造)企业需要的软件架构师(or程序员or人才)。教师来源与企业、学员来源与企业、人才输送到企业是他们办学的手段。尽管各个如雨后春笋般出现的软件学院口号差不多,但恐怕大多只是为了圈钱卖学位了事... 字串4

架构师不是通过理论学习可以搞出来的,不过不学习相关知识那肯定是不行的。参考软件企业架构师需求、结合目前架构师所需知识,总结架构师自我培养过程大致如下仅供参考:

1、架构师胚胎(程序员)学习的知识是语言基础、设计基础、通信基础等,应该在大学完成,内容包括java、c、c++、uml、RUP、XML、socket通信(通信协议)――学习搭建应用系统所必须的原材料。
2、架构师萌芽(高级程序员)学习分布式系统、组建等内容,可以在大学或第一年工作时间接触,包括分布式系统原理、ejb、corba、com/com+、webservice(研究生可以研究网络计算机、高性能并发处理等内容)
3、架构师幼苗(设计师)应该在掌握上述基础之上,结合实际项目经验,透彻领会应用设计模式,内容包括设计模式(c++版本、java版本)、ejb设计模式、J2EE架构、UDDI、软件设计模式等。在此期间,最好能够了解软件工程在实际项目中的应用以及小组开发、团队管理。
4、软件架构师的正式成型在于机遇、个人努力和天赋,软件架构师其实是一种职位,但一个程序员在充分掌握软架构师所需的基本技能后,如何得到这样的机会、如何利用所掌握的技能进行应用的合理架构、如何不断的抽象和归纳自己的架构模式、如何深入行业成为能够胜任分析、架构为一体的精英人才这可不是每个人都能够遇上的馅饼……

然而学海无涯,精力有限,个人如何能够很快将这些所谓的架构师知识掌握?这是秘密,每个人都有自己的独门家传秘笈就不敢一一暴露了。不过有一点就是广泛学习的基础之上一定要根据个人兴趣、从事领域确定一条自己的主线来努力。

如果说架构师是在模型图纸上工作的,那么模型元素必须是实实在在的,正如我们不可能期望抽象派画家来设计高楼大厦,没有实际意义的模型元素,是不可能构筑出软件系统的。迄今为止,绝大部分软件架构师是依赖软件程序员来实现他们的架构意图的,这二者直接的鸿沟是显而易见的。设计模式的出现是为缩短二者之间的鸿沟所做的努力,目的是让架构师和程序员之间有更多的共同语言和规范。尽管设计模式让软件开发效率和质量有一定程度的提升,但是它始终面临一个很明显的局限,那就是人的因素。人虽然在创造性方面有绝对优势,但是在精确性、持久性、效率、质量上是无法比拟机器的。所以我们希望在软件系统构建过程中,人和机器发挥各自的长处,也就是说,让人来扮演架构师的角色,而让机器来扮演程序施工者的角色。事实上,目前已经有了成功的模式了,那就是KCOM 商业工程)企业应用平台所采用的基于设计的全自动化软件工厂模式,采用这种模式,架构师在工具平台所提供的模型图设计环境里做软件系统的设计,设计结果由工具平台自身所带的“软件工厂”自动加工成最终企业应用软件系统。这样的开发模式,能使企业应用软件系统的开发在效率、质量上有了质的提升,从根本上区别于传统的设计模式,因为这里的设计模式已经包含在软件工厂编译器之中了。
在截然不同的抽象层次上概念化解决方案是软件架构师的基本技能。通过将解决方案组织到离散的层次上,架构师可以将精力集中在解决方案的单个方面而忽略所有剩余的复杂性,一旦稳定了解决方案中的某个部分,就可以处理其他部分,从而不断的将层次发展并完善到最终可以被实现的粘合模型中。

而软件开发人员也应该理解解决方案的不同抽象层次,在实际项目中非常难于实践,第一个困难就是开发人员在急于编码时很容易放弃这些层次,架构师需要在整个项目的生命周期中严格保持这些层次。无论开发人员或架构师必须意识到通过不同抽象层次概念化解决方案可以简化系统,保证不会淹没在系统的复杂性中。

IT解决方案的抽象层次并没有固定的模式,在定义抽象层次的数量和范围时要注意抽象层次的完善性,在每个抽象层次上定义多个视图,每个视图展现系统的一个单独方面,其次在解决方案的实施过程中注意保持层次间的一致性,因为需求处在不断的变化当中,当需求发生变化时,对高抽象层次的更改需要同步低抽象层次。

这里展示了一个IT企业解决方案定义的抽象层次:

域。域层次捕获项目的业务环境。

项目洞察力。项目洞察力对系统将会有的对企业的业务影响进行通讯。它以投资回报分析量化了这个影响。项目洞察力表示该项目的最高抽象层次。

业务处理。系统层次为公司内的业务处理建模。对于极其复杂的单位来说,这个层次可以再细分到子层次:部门、部门间以及部门内。

UI 规范。UI 规范设计了实现业务处理的用户界面。它是由 UI 设计文档和功能 UI 原型组成的。

详细要求。详细要求指定了系统要求的最低层次抽象。它包括诸如数据类型格式和详细业务规则等详细信息。它还包括专业性要求,例如,性能、可用性、安全性、国际化、配置、可扩展性和灵活性要求等。

体系结构。系统的体系结构被组织到六个视图中:

逻辑。定义软件层和执行系统功能的主要抽象。

并发。捕获系统的并行方面,包括交易、服务器场和资源争用。

安全性。定义用于身份验证、授权、保护机密和日志记录的方法。

部署。定义网络拓扑和系统的部署配置。

组件。定义系统组件、其接口以及依赖项。

数据。定义持久性数据的设计结构。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 成为一名 Golang 架构师需要掌握的技能包括:熟练掌握 Golang 语言的基础知识;熟悉 Golang 应用程序的构建;具备良好的编码能力;了解 Golang 常用的 Web 框架;熟悉分布式系统概念及架构;具有高可用架构设计能力;了解常用的数据库及缓存;具备良好的调试和性能优化能力。 ### 回答2: 作为Golang架构师,必备的技能主要包括以下几个方面。 首先,深厚的Golang编程基础是必不可少的。作为一门编程语言,Golang具有简洁、高效的特点,因此熟练掌握Golang的基本语法和编程范式,能够灵活运用Golang的各种特性和库,是架构师必须具备的基本技能。 其次,设计和构建分布式系统的能力是重要的技能之一。在当今云计算和大数据时代,分布式系统成为了架构师必须面对的挑战。掌握分布式系统的设计原则,了解分布式系统的常见模式和技术栈,能够使用Golang构建高可用、高并发、可扩展的分布式系统,是架构师必备的技能之一。 此外,良好的系统设计能力和架构思维也是不可或缺的。架构师需要能够对系统进行全局的规划和设计,考虑系统的可靠性、可扩展性、性能等方面。通过分析和抽象复杂的问题,采用合适的模式和架构风格,将系统划分为不同的模块和组件,并定义它们之间的交互和通信方式,以实现系统的复杂需求。 另外,熟悉常用的开发工具和框架也是必备的技能之一。如Docker、Kubernetes等容器和容器编排工具,如gin、beego等Golang框架,如ELK、Prometheus等监控和日志分析工具等。熟悉这些工具和框架,能够帮助架构师更高效地构建和部署系统。 最后,良好的沟通和团队合作能力也是Golang架构师必不可少的技能。架构师通常需要与产品经理、开发团队、测试团队等进行有效的沟通和协作,了解需求和业务,提供技术方案和指导。同时,能够与团队成员密切合作,共同完成项目的设计和开发。 总之,作为Golang架构师,需要具备扎实的Golang编程基础、分布式系统设计能力、系统设计和架构思维、熟悉开发工具和框架,以及良好的沟通和团队合作能力。 ### 回答3: golang架构师必备技能包括以下几个方面: 1. 熟练掌握Golang语言:作为Golang架构师,首先需要对Golang语言有深入的理解和掌握。这包括了对Golang语法、特性、标准库的熟悉,以及对并发编程、内存管理等方面的了解。只有对Golang语言的熟悉,才能使用它来构建可靠、高效的系统。 2. 深刻了解分布式系统设计:架构师需要有扎实的分布式系统设计知识和经验,包括分布式计算、分布式存储、分布式消息传递等方面。对于Golang架构师来说,熟悉Golang在分布式系统中的特性和优势,能够合理地应用Goland来设计和开发分布式系统,提高系统性能和可扩展性。 3. 掌握常用的系统设计模式架构师需要了解和掌握常用的系统设计模式,包括但不限于单例模式、工厂模式、观察者模式、代理模式等。这些模式能够帮助架构师更好地设计系统结构,提高系统的可维护性和可扩展性。 4. 熟悉微服务架构:微服务架构是一种将系统拆分成若干小的、自治的服务的架构风格。Golang架构师需要熟悉微服务架构的原理和设计思想,并且能够使用Golang来实现和部署微服务。熟练掌握微服务架构可以提高系统的灵活性、可扩展性和可维护性。 5. 具备高可用和高性能系统设计能力:架构师需要具备设计高可用和高性能系统的能力。这包括对系统性能的监控和优化、负载均衡、容错处理等方面的知识。Golang作为一门高性能的语言,架构师需要了解Golang的性能优化技巧,使用Golang构建高可用和高性能的系统。 总之,作为Golang架构师,不仅需要熟练掌握Golang语言,还需要具备分布式系统设计、系统架构设计、微服务架构等方面的知识和经验,才能设计和构建出高效、可靠的系统。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值