在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
在IT行业,大家对于架构肯定不陌生了。然而关于架构设计的概念和本质,还是有许多人没有真正的理解。本文就来带大家详解架构设计的概念和本质,内容包括认识架构、理解架构师岗位、架构的分类、架构的级别、应用架构的发展以及架构设计的注意事项。感兴趣的朋友可以一起来看看!
1、认识架构
架构的本质是经过系统性地思考,权衡利弊之后,在现有资源约束下的最合理决策,最终明确的系统骨架:,包括子系统, 模块, 组件。以及他们之间协作关系,约束规范,,指导原则。并由它来指导团队中的每个人思想层面上的一致。要全面理解架构设计的概念,还需要掌握以下一些知识点的理解。
(1)系统与子系统
系统:泛指由一群有关联的个体组成,根据某种规则运作,能完成个别元件不能独立完成的工作能力的群体。子系统:也是由一群关联的个体组成的系统,多半是在更大的系统中的一部分。
(2)模块与组件
都是系统的组成部分,从不同角度拆分系统而已。模块是逻辑单元,组件是物理单元。模块就是从逻辑上将系统分解, 即分而治之, 将复杂问题简单化。模块的粒度可大可小, 可以是系统,几个子系统、某个服务,函数, 类,方法、 功能块等等。组件可以包括应用服务、数据库、网络、物理机、还可以包括MQ、容器、Nginx等技术组件。
(3)框架与架构
框架是组件实现的规范,例如:MVC、MVP、MVVM等,是提供基础功能的产品,例如开源框架:Ruby on Rails、Spring、Laravel、Django等,这是可以拿来直接使用或者在此基础上二次开发。框架是规范,架构是结构。软件架构指软件系统的顶层结构。
2、理解架构师岗位
系统架构师是一个最终确认和评估系统需求,给出开发规范,搭建系统实现的核心构架,并澄清技术细节、扫清主要难点的技术人员。因此,作为主导系统全局分析设计和实施、负责软件架构和关键技术的决策者,架构师人才需求缺口大,薪资待遇高。一般来讲,架构师的主要工作内容是领导与协调整个项目中的技术活动,然后推动主要的技术决策,并最终表达为软件构架,接着确定和文档化系统的相对构架而言意义重大的方面,包括系统的需求、设计、实施和部署等“视图”。同时还需要理解、评价并接收系统需求。总的来讲,一个合格的架构师需要做到理解业务,全局把控,选择合适的技术,解决关键问题、指导研发落地实施。
3、架构的分类
(1)业务架构
包括业务规划,业务模块、业务流程,对整个系统的业务进行拆分,对领域模型进行设计,把现实的业务转化成抽象对象。没有最优的架构,只有最合适的架构,一切系统设计原则都要以解决业务问题为最终目标,脱离实际业务的技术情怀架构往往会给系统带入大坑,任何不基于业务做异想天开的架构都是耍流氓。所有问题的前提要搞清楚我们今天面临的业务量有多大,增长走势是什么样,而且解决高并发的过程,一定是一个循序渐进逐步的过程。合理的架构能够提前预见业务发展1~2年为宜。这样可以付出较为合理的代价换来真正达到技术引领业务成长的效果。
(2)应用架构
硬件到应用的抽象,包括抽象层和编程接口。应用架构和业务架构是相辅相成的关系。业务架构的每一部分都有应用架构。应用作为独立可部署的单元,为系统划分了明确的边界,深刻影响系统功能组织、代码开发、部署和运维等各方面. 应用架构定义系统有哪些应用、以及应用之间如何分工和合作。这里所谓应用就是各个逻辑模块或者子系统。
(3)数据架构
数据架构指导数据库的设计. 不仅仅要考虑开发中涉及到的数据库,实体模型,也要考虑物理架构中数据存储的设计。
(4)代码架构
子系统代码架构主要为开发人员提供切实可行的指导,如果代码架构设计不足,就会造成影响全局的架构设计。比如公司内不同的开发团队使用不同的技术栈或者组件,结果公司整体架构设计就会失控。
(5)技术架构
确定组成应用系统的实际运行组件,这些运行组件之间的关系,以及部署到硬件的策略。技术架构主要考虑系统的非功能性特征,对系统的高可用、高性能、扩展、安全、伸缩性、简洁等做系统级的把握。系统架构的设计要求架构师具备软件和硬件的功能和性能的过硬知识,这也是架构设计工作中最为困难的工作。
(6)总结
架构分类可细分为业务架构、应用架构、技术架构, 代码架构, 部署架构。业务架构是战略,应用架构是战术,技术架构是装备。其中应用架构承上启下,一方面承接业务架构的落地,另一方面影响技术选型。熟悉业务,形成业务架构,根据业务架构,做出相应的应用架构,最后技术架构落地实施。如何针对当前需求,选择合适的应用架构,如何面向未来,保证架构平滑过渡,这个是软件开发者,特别是架构师,都需要深入思考的问题。
4、架构的级别
架构的级别分别是系统级、应用级、模块级和代码级。系统级即整个系统内各部分的关系以及如何治理分层;应用级即单个应用的整体架构,及其与系统内单个应用的关系等;模块级即应用内部的模块架构,如代码的模块化、数据和状态的管理等;代码级即从代码级别保障架构实施。
5、应用架构的发展
从本质上来看,业务架构是生产力,应用架构是生产关系,技术架构是生产工具。业务架构决定应用架构,应用架构需要适配业务架构,并随着业务架构不断进化,同时应用架构依托技术架构最终落地。架构发展路程,即从单体应用到分布式应用服务化,最后到微服务。
6、架构设计的注意事项
(1)业务开发人员也需要关注架构设计。
架构的再好,最终还是需要代码来落地,并且组织越大这个落地的难度越大。不单单是系统架构,每个解决方案每个项目也由自己的架构,如分层、设计模式等。如果每一块砖瓦不够坚固,那么整个系统还是会由崩塌的风险。
(2)架构设计并不是一开始就很完美。
世上没有最好架构,只有最合适的架构,不要企图一步到位。我们需要的不是一下子造出一辆汽车,而是从单轮车→自行车→摩托车,最后再到汽车。想象一下2年后才能造出的产品,当初市场还存在吗?
(3)不要为虚无的未来而过度设计。
在创业公司初期,业务场景和需求边界很难把握,产品需要快速迭代和变现,需求频繁更新,这个时候需要的是快速实现。不要过多考虑未来的扩展,说不定功能做完,效果不好就无用了。如果业务模式和应用场景边界都已经比较清晰,是应该适当的考虑未来的扩展性设计。
(4)架构技术是为业务而存在的。
不要为了技术而技术,在技术选型和架构设计中,脱离网站业务发展的实际,一味追求时髦的新技术,可能会将技术发展引入崎岖小道,架构之路越走越难。考虑实现成本、时间、人员等各方面都要综合考虑,理想与现实需要折中。
以上就是架构设计的概念和本质详解,大家都看懂了吗?对于许多技术从业者来讲,架构师不失为一个很好的发展方向。如果大家对于架构设计有更深入的学习兴趣,不妨上博学谷进行更加详细轻松的视频课程学习。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
疫情当值,在家远程办公需要哪些软件?
随着疫情爆发,人社部和各地政府纷纷出台延期复工通知,企业均积极响应,开启在家远程办公模式。企业微信上沟通工作,还可以打卡、审批、汇报、联系客户等;WPS Office一款集文字、表格、演示、PDF、脑图、云文档管理于一体的办公软件
4411
2020-02-18 14:19:41
0基础如何快速入门软件编程
0基础如何快速入门软件编程,很多人觉得学编程难,大都是掌握方法,而不是能力、性别或其他原因。除了想达到行业顶级开发者的水平,如果你是想学编程,掌握了对的方法,就能学好。
4780
2020-06-09 14:38:49
热门IT职业的发展规划和行业分析
如今,IT行业已是人人都羡慕的香饽饽,其发展前景广阔,薪资待遇更是高出许多传统岗位。目前比较热门的IT职业发展方向有Java开发、Python开发、Web前端、PMP项目管理以及软件测试。下面我们一起来详细看看这些热门IT职业的发展规划和行业分析。
4971
2020-06-18 17:04:02
学习编程的软件有哪些值得推荐?
工欲善其事必先利其器,学习光靠一味的死记硬背是不够的。尤其是学习IT编程,需要我们在练中学、学中练,才能真正掌握编程知识。因此了解并使用一些学习编程的软件是很有必要的,它们可以极大地提高我们的学习效率,帮助我们在学习编程的路上走得更远。本文将为大家盘点一下那些值得推荐的软件,分别是Eclipse、IDEA、Sublime Text、Notepad++、网易有道以及博学谷。
5398
2020-07-08 12:00:06
扎心!程序员手疼7年查出骨肿瘤,满满骨头渣!
在杭州工作的黄先生是一名从事IT行业的程序员。早在7年前,他就发现自己的左手会莫名其妙地酸痛。以为工作中常有的“键盘手”症状,也就没怎么在意。近期,黄先生左手手指完全不能动了,这才到骨科就诊。
4213
2021-08-23 17:03:55