代码编织梦想

1、什么是架构和架构本质

在软件行业,对于什么是架构,都有很多的争论,每个人都有自己的理解。 此君说的架构和彼君理解的架构未必是一回事。

我们主要针对互联网服server系统(类似网站)来定义架构:架构是系统的骨架,支撑和链接各个部分,包括组件、连接件、约束规范,以及指导这些内容设计与演化的原理。

组件:类似应用服务,独立模块、数据库、nginx等等、

连接件:分布式调用、进程间调用、调用使用http协议还是tcp协议、组件之间的交互关系、

约束规范: 定规则做限制:例如设计原则、编码规范等等。

是系统性地思考,权衡利弊之后在现有资源约束下的“最合理决策”,并由它来指导团队中的每个人思想层面上的一致。

即架构=组件+交互。

这类似建筑设计规划,城市总体规划等,其实就是架构,只是应用的场景不同。盖一座小房子,可以拍脑袋干起来,但是当你要盖一座大楼,如果没有一个建筑设计规划,可以想象搭理最后是什么样?

架构的本质就是对系统进行有序化地重构以致符合当前业务的发展,并可以快速扩展。

那什么样的系统要考虑做架构设计?

1. 需求相对复杂.

2. 非功能性需求在整个系统占据重要位置.

3. 系统生命周期长,有扩展性需求.

4.系统基于组件或者集成的需要.

5.业务流程再造的需要.

  2、架构分类

架构可细分为业务架构、应用架构、技术架构, 代码架构, 部署架构,.

业务架构是战略,应用架构是战术,技术架构是装备。其中应用架构承上启下,一方面承接业务架构的落地,另一方面影响技术选型。

熟悉业务,形成业务架构,根据业务架构,做出相应的应用架构,最后技术架构落地实施。

如何针对当前需求,选择合适的应用架构,如何面向未来,保证架构平滑过渡,这个是软件开发者,特别是架构师,都需要深入思考的问题。

  一、业务架构(俯视架构):

包括业务规划,业务模块、业务流程,对整个系统的业务进行拆分,对领域模型进行设计,把现实的业务转化成抽象对象。

没有最优的架构,只有最合适的架构,一切系统设计原则都要以解决业务问题为最终目标,脱离实际业务的技术情怀架构往往会给系统带入大坑,任何不基于业务做异想天开的架构都是耍流氓。

所有问题的前提要搞清楚我们今天面临的业务量有多大,增长走势是什么样,而且解决高并发的过程,一定是一个循序渐进逐步的过程。 合理的架构能够提前预见业务发展1~2年为宜。这样可以付出较为合理的代价换来真正达到技术引领业务成长的效果。

看看京东业务架构(网上分享图):

  二、应用架构(剖面架构,也叫逻辑架构图):

硬件到应用的抽象,包括抽象层和编程接口。应用架构和业务架构是相辅相成的关系。业务架构的每一部分都有应用架构。

类似:

应用架构:应用作为独立可部署的单元,为系统划分了明确的边界,深刻影响系统功能组织、代码开发、部署和运维等各方面. 应用架构定义系统有哪些应用、以及应用之间如何分工和合作。这里所谓应用就是各个逻辑模块或者子系统。

应用架构图关键有2点:

1、职责划分: 明确应用(各个逻辑模块或者子系统)边界

1)逻辑分层

2)子系统、模块定义。

3)关键类。

2、职责之间的协作:

1)接口协议:应用对外输出的接口。

2)协作关系:应用之间的调用关系。

应用分层有两种方式:

一种是水平分(横向),按照功能处理顺序划分应用,比如把系统分为web前端/中间服务/后台任务,这是面向业务深度的划分。

另一种是垂直分(纵向),按照不同的业务类型划分应用,比如进销存系统可以划分为三个独立的应用,这是面向业务广度的划分。

应用的合反映应用之间如何协作,共同完成复杂的业务case,主要体现在应用之间的通讯机制和数据格式,通讯机制可以是同步调用/异步消息/共享DB访问等,数据格式可以是文本/XML/JSON/二进制等。

应用的分偏向于业务,反映业务架构,应用的合偏向于技术,影响技术架构。分降低了业务复杂度,系统更有序,合增加了技术复杂度,系统更无序。

应用架构的本质是通过系统拆分,平衡业务和技术复杂性,保证系统形散神不散。

系统采用什么样的应用架构,受业务复杂性影响,包括企业发展阶段和业务特点;同时受技术复杂性影响,包括IT技术发展阶段和内部技术人员水平。业务复杂性(包括业务量大)必然带来技术复杂性,应用架构目标是解决业务复杂性的同时,避免技术太复杂,确保业务架构落地。

  三、代码架构(也叫开发架构):

子系统代码架构主要为开发人员提供切实可行的指导,如果代码架构设计不足,就会造成影响全局的架构设计。比如公司内不同的开发团队使用不同的技术栈或者组件,结果公司整体架构设计就会失控。

代码架构主要定义:

一、代码单元:

1、配置设计

2、框架、类库。

二、代码单元组织:

1、编码规范,编码的惯例。

2、项目模块划分

3、顶层文件结构设计,比如mvc设计。

4、依赖关系

四、技术架构,也可以叫系统架构

技术架构:确定组成应用系统的实际运行组件(lvs,nginx,tomcat,php-fpm等),这些运行组件之间的关系,以及部署到硬件的策略。

技术架构主要考虑系统的非功能性特征,对系统的高可用、高性能、扩展、安全、伸缩性、简洁等做系统级的把握。

系统架构的设计要求架构师具备软件和硬件的功能和性能的过硬知识,这也是架构设计工作中最为困难的工作。

  五、部署拓扑架构图(实际物理架构图):

拓扑架构,包括架构部署了几个节点,节点之间的关系,服务器的高可用,网路接口和协议等,决定了应用如何运行,运行的性能,可维护性,可扩展性,是所有架构的基础。这个图主要是运维工程师主要关注的对象。

3、应用架构

架构演进路程:

->初始阶段:LAMP,部署在一台服务器

->应用服务器和数据服务器分离

->使用缓存改善性能

->使用集群改善并发

->数据库地读写分离

->使用反向代理和cdn加速

->使用分布式文件和分布式数据库

->业务拆分

->分布式服务

业务架构是生产力,应用架构是生产关系,技术架构是生产工具。业务架构决定应用架构,应用架构需要适配业务架构,并随着业务架构不断进化,同时应用架构依托技术架构最终落地。

企业一开始业务比较简单,比如进销存,此时面向内部用户,提供简单的信息管理系统(MIS),支持数据增删改查即可,单体应用可以满足要求。

随着业务深入,进销存每块业务都变复杂,同时新增客户关系管理,以更好支持营销,业务的深度和广度都增加,这时需要对系统按照业务拆分,变成一个分布式系统。

更进一步,企业转向互联网+战略,拓展在线交易,线上系统和内部系统业务类似,没必要重做一套,此时把内部系统的逻辑做服务化改造,同时供线上线下系统使用,变成一个简单的SOA架构。

紧接着业务模式越来越复杂,订单、商品、库存、价格每块玩法都很深入,比如价格区分会员等级,访问渠道(无线还是PC),销售方式(团购还是普通)等,还有大量的价格促销,这些规则很复杂,容易相互冲突,需要把分散到各个业务的价格逻辑进行统一管理,以基础价格服务的方式透明地提供给上层应用,变成一个微内核的SOA架构。

同时不管是企业内部用户,还是外部顾客所需要的功能,都由很多细分的应用提供支持,需要提供portal,集成相关应用,为不同用户提供统一视图,顶层变成一个AOA的架构(application orientated architecture)。

4、衡量架构的合理性

架构为业务服务,没有最优的架构,只有最合适的架构, 架构始终以高效,稳定,安全为目标来衡量其合理性。

一、稳定性。指标:

1. 高可用:要尽可能的提高软件的可用性,我想每个操作人都不愿意看到自己的工作无法正常进行。黑盒白盒测试、单元测试、自动化测试、故障注入测试、提高测试覆盖率等方式来一步一步推进。

二、高效指标:

1. 文档化:不管是整体还是部分的整个生命周期内都必须做好文档化,变动的来源包括但不限于BUG,需求。

2. 可扩展:软件的设计秉承着低耦合的理念去做,注意在合理的地方抽象。方便功能更改、新增和运用技术的迭代,并且支持在适时对架构做出重构。

3. 高复用:为了避免重复劳动,为了降低成本,我们希望能够重用之前的代码、之前的设计。这点对于架构环境的依赖是最大的。

三、安全指标

1. 安全:组织的运作过程中产生的数据都是具有商业价值的,保证数据的安全也是刻不容缓的一部分。以免出现XX门之类丑闻。加密、https等为普遍手段

5、常见架构误区

误区1——架构专门由架构师来做,业务开发人员无需关注:架构的再好,最终还是需要代码来落地,并且组织越大这个落地的难度越大。不单单是系统架构,每个解决方案每个项目也由自己的架构,如分层、设计模式等。如果每一块砖瓦不够坚固,那么整个系统还是会由崩塌的风险。所谓“千里之堤,溃于蚁穴”。

误区2——架构师确定了架构蓝图之后任务就结束了:架构不是“空中楼阁”,最终还是要落地的,但是架构师完全不去深入到第一线怎么知道“地”在哪?怎么才能落的稳稳当当。

误区3——不做出完美的架构设计不开工:世上没有最好架构,只有最合适的架构。我们需要的不是一下子造出一辆汽车,而是从单轮车 --> 自行车 --> 摩托车,最后再到汽车。想象一下2年后才能造出的产品,当初市场还存在吗?

  6、架构知识体系

架构演进

初始阶段:LAMP,部署在一台服务器

应用服务器和数据服务器分离

使用缓存改善性能

使用集群改善并发

数据库地读写分离

使用反向代理和cdn加速

使用分布式文件和分布式数据库

业务拆分

分布式服务

架构模式

分层:横向分层:应用层,服务层,数据层

分割:纵向分割:拆分功能和服务

分布式

分布式应用和服务

分布式静态资源

分布式数据和存储

分布式计算

集群:提高并发和可用性

缓存:优化系统性能

cdn

方向代理访问资源

本地缓存

分布式缓存

异步:降低系统的耦合性

提供系统的可用性

加快响应速度

冗余:冷备和热备,保证系统的可用性

自动化:发布,测试,部署,监控,报警,失效转移,故障恢复

安全:

架构核心要素

高性能:网站的灵魂

性能测试

前端优化

应用优化

数据库优化

可用性:保证服务器不宕机,一般通过冗余部署备份服务器来完成

负载均衡

数据备份

自动发布

灰度发布

监控报警

伸缩性:建集群,是否快速应对大规模增长的流量,容易添加新的机器

集群

负载均衡

缓存负载均衡

可扩展性:主要关注功能需求,应对业务的扩展,快速响应业务的变化。是否做法开闭原则,系统耦合依赖

分布式消息

服务化

安全性:网站的各种攻击,各种漏洞是否堵住,架构是否可以做到限流作用,防止ddos攻击。

xss攻击

sql注入

csr攻击

web防火墙漏洞

安全漏洞

ssl

  7、架构书籍推荐

1. 《大型网站技术架构:核心原理与案例分析》

这是比较早,比较系统介绍大型网站技术架构的书,通俗易懂又充满智慧,即便你之前完全没接触过网站开发,通读前几章,也能快速获取到常见的网站技术架构及其应用场景。非常赞。

2. 《亿级流量网站架构核心技术》

相比《大型网站技术架构》的高屋建瓴,开涛的这本《亿级流量网站架构核心技术》则落实到细节,网站架构中常见的各种技术,比如缓存、队列、线程池、代理……,统统都讲到了,而且配有核心代码。甚至连 Nginx 的配置都有!

如果你想在实现大流量网站时找参考技术和代码,这本书最合适啦。

3. 《架构即未来》

这是一本“神书”啦,超越具体技术层面,着重剖析架构问题的根源,帮助我们弄清楚应该以何种方式管理、领导、组织和配置团队。

4. 《分布式服务架构:原理、设计与实战》

这本书全面介绍了分布式服务架构的原理与设计,并结合作者在实施微服务架构过程中的实践经验,总结了保障线上服务健康、可靠的最佳方案,是一本架构级、实战型的重量级著作。

5. 《聊聊架构》

这算是架构方面的一本神书了,从架构的原初谈起,从业务的拆分谈起,谈到架构的目的,架构师的角色,架构师如何将架构落地……强烈推荐。

不过,对于没有架构实践经验的小伙伴来讲,可能会觉得这本书比较虚,概念多,实战少。但如果你有过一两个项目的架构经验,就会深深认同书中追本溯源探讨的架构理念。

6. 《软件架构师的12项修炼》

大多数时候所谓的“技术之玻璃天花板”其实只是缺乏软技能而已。这些技能可以学到,缺乏的知识可以通过决定改变的努力来弥补。
资料皆可分享

1 SpringBoot+ 高并发消息处理 EDM?项目 实战

2 SpringBoot ELK?分布式 数据分析

3 Netty?高 并发 UTS?项目实战

4 SpringCloud?微服务+NoSQL+ 负载均衡平台设计

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_57042151/article/details/128017171

架构可细分为业务架构、应用架构、技术架构_ejinxian的博客-爱代码爱编程_业务架构 应用架构 技术架构

架构可细分为业务架构、应用架构、技术架构, 业务架构是战略,应用架构是战术,技术架构是装备。 应用架构承上启下: 1、一方面承接业务架构的落地, 2、一方面影响技术选型   应用架构类型:单体式、分布式、SOA架构 应用架构     分有两种方式,       一种是水平分,从功能类型划分,比如把系统分为web前端/中

应用架构、业务架构、技术架构和业务流程图详解_代码帮的博客-爱代码爱编程_技术架构

应用架构 应用架构(Application Architecture)是描述了IT系统功能和技术实现的内容。应用架构分为以下两个不同的层次: 企业级的应用架构:企业层面的应用架构起到了统一规划、承上启下的作用,向上承接了企业战略发展方向和业务模式,向下规划和指导企业各个IT系统的定位和功能。在企业架构中,应用架构是最重要和工作量最大的部分,他包括了企业

架构漫谈:业务架构、应用架构与基础架构_forburning的博客-爱代码爱编程_业务架构和应用架构的区别

软件开发就是把一个复杂的问题分解为一系列简单的问题,再把一系列简单的解决方案组合成一个复杂的解决方案。而软件开发中最大的挑战,就是即能够快速高效地针对需求、环境的变化做出改变,也能够持续提供稳定、高可用的服务。而软件架构,就是软件系统的骨骼与框架。 所谓架构,见仁见智,很难有一个明确或标准的定义;但架构并非镜花水月或阳春白雪,有系统的地方就需要架构,大到

四种代码结构--纸上谈兵04-爱代码爱编程

四种代码结构:按层封装,按功能封装,按组件封装,端口与适配器 实现客户查看订单状态的用例,按上面四种结构进行设计如下: 按层封装: 在这种简单的设计中,把代码分成三层:Web, 业务逻辑,持久化层,每一层都只能对下层有依赖关系。 客户发出查询请求,Web层负责接受并处理Web请求,并把请求交给下面的业务逻辑来处理,最后访问持久层来获取订单的信息。

业务架构是战略,应用架构是战术,技术架构是装备-爱代码爱编程

  一. 什么是架构和架构本质   在软件行业,对于什么是架构,都有很多的争论,每个人都有自己的理解。此君说的架构和彼君理解的架构未必是一回事。因此我们在讨论架构之前,我们先讨论架构的概念定义,概念是人认识这个世界的基础,并用来沟通的手段,如果对架构概念理解不一样,那沟通起来自然不顺畅。 Linux有架构,MySQL有架构,JVM也有架构,使用Jav

代码结构经验总结-爱代码爱编程

代码结构浅析 简介 一个优良的程序模块应该具有良好的代码结构,以使其美观、实用、易维护。下面简单介绍一下自己总结的C++代码结构经验。 一.数据结构类 一般可以是g_Strucr.h文件中定义的数据结构体,也可以是CTree类等在程序中需要用到的数据结构类。 二.常用的通用辅助函数类 提供一些基本的数据类型转换、经纬度与XY坐标转换、时间换算等

代码架构--设计模式概述-爱代码爱编程

前言 “设计模式”这个术语最初并不是出现在软件设计中,而是被用于建筑领域的设计中,意在搭建扎实的建筑基础,解决日常或突发的房屋设计问题。现在狭义的“设计模式”被广泛应用于软件设计领域,它描述了在软件设计过程中的一些不断重复发生的问题,以及该问题的解决方案。其目的是为了提高代码的可重用性、代码的可读性和代码的可靠性。 何为设计模式 如上文介绍,软件设计

2021/2/28 一文理解所有代码含有的基本结构-爱代码爱编程

所有代码的结构 1.顺序结构 程序代码一行一行的往下执行就是顺序结构,它是最基本的一种结构,存在于任何代码中。 2.选择结构 就像我说的,计算机的世界就是建立在现实世界一样。而我们生活在这个世界,不管面都什么样的问题每天就会面临不同的选择,做出了选择才能解决、处理问题。 if/else 人生的岔路口 switch/case/default

代码架构(一)-爱代码爱编程

代码架构(一)________ 什么是架构?  and    需求? 架构本身和软件开发并无太大关系。每个软件项目都是由代码和服务器构成的,如何统筹安排代码和服务器,这便就是架构的范畴。 一个项目可能需要使用多台服务器,eg:web服务器、数据库服务器、文件服务器、CDN.......   如何针对不同的要求对服务器进行选型,这是架构;如何统一管理这

代码分层架构-爱代码爱编程

原则: 每层只能和位于其下方的层发生耦合。目的: 有效降低层与层之间的依赖。 分类: 严格分层架构:某层只能与位于其直接下方的层发生耦合松散分层架构:允许某层与它的任意下方层发生耦合。 传统三层架构  表示层(web) 业务逻辑层(business/service) 数据访问层(dao) DDD经典四层架构 用户接口

项目代码架构-业务分层和各层业务逻辑-爱代码爱编程

项目代码架构分层 1、代码分层现状 传统项目开发中,代码分层架构大概是controller层,Service层,Dao层,在SOA架构中会有facade层,Service层,Dao层,两种方式都是将所有的业务逻辑集中在Service层,包括业务参数的校验逻辑,业务的核心逻辑,对第三方工具的访问逻辑,甚至是持久层的转换逻辑都在这一层,对持久层数据库的访问

架构分类的-业务架构,应用架构,技术架构,数据架构-爱代码爱编程

Jetty和Tomcat的比较 目录概 述小结参考资料和推荐阅读 LD is tigger forever,CG are not brothers forever, throw the pot and shine forever. Modesty is not false, solid is not naive, treacherous

代码结构中Dao,Service,Controller,Util,Model是什么意思,为什么划分?-爱代码爱编程

很多刚入行的小白都不太清楚代码结构中Dao,Service,Controller,Util,Model是什么意思,为什么划分?今天我们一起来详细了解一下!本文内容较为简单,只是通俗化的讲解一些简单的概念。 适合受众 2年以下的初级程序员和0基础的门外汉 一、为什么需要一个好的代码结构 好的代码结构并不仅仅是为了看上去清晰,它更像是我们对一个系统的

领域模型中的实体类:vo,dto,do,po(比较)_vo dto po 实体类区别-爱代码爱编程

PO(Persistent Object):持久化对象,表示持久层的数据结构(如数据库表)DO(Domain Object):领域对象,即业务实体对象。领域对象很简单,可以看成数据库表的对象映射,每个字段对应一个对象属性。一