1)逻辑分层
2)子系统、模块定义 。
3)关键类 。
2、职责之间的协作:
1)接口协议:应用对外输出的接口 。
2)协作关系:应用之间的调用关系 。
应用分层有两种方式:
一种是水平分(横向),按照功能处理顺序划分应用,比如把系统分为web前端/中间服务/后台任务,这是面向业务深度的划分 。
另一种是垂直分(纵向),按照不同的业务类型划分应用,比如进销存系统可以划分为三个独立的应用,这是面向业务广度的划分 。
应用的合反映应用之间如何协作,共同完成复杂的业务case,主要体现在应用之间的通讯机制和数据格式,通讯机制可以是同步调用/异步消息/共享DB访问等,数据格式可以是文本/XML/JSON/二进制等 。
应用的分偏向于业务,反映业务架构,应用的合偏向于技术,影响技术架构 。分降低了业务复杂度,系统更有序,合增加了技术复杂度,系统更无序 。
应用架构的本质是通过系统拆分,平衡业务和技术复杂性,保证系统形散神不散 。
系统采用什么样的应用架构,受业务复杂性影响,包括企业发展阶段和业务特点;同时受技术复杂性影响,包括IT技术发展阶段和内部技术人员水平 。业务复杂性(包括业务量大)必然带来技术复杂性,应用架构目标是解决业务复杂性的同时,避免技术太复杂,确保业务架构落地 。
三、代码架构(也叫开发架构):
子系统代码架构主要为开发人员提供切实可行的指导,如果代码架构设计不足,就会造成影响全局的架构设计 。比如公司内不同的开发团队使用不同的技术栈或者组件,结果公司整体架构设计就会失控 。
代码架构主要定义:
一、代码单元:
1、配置设计
2、框架、类库 。
二、代码单元组织:
1、编码规范,编码的惯例 。
2、项目模块划分
3、顶层文件结构设计,比如mvc设计 。
4、依赖关系
四、技术架构,也可以叫系统架构
技术架构:确定组成应用系统的实际运行组件(lvs,nginx,Tomcat,php-fpm等),这些运行组件之间的关系,以及部署到硬件的策略 。
技术架构主要考虑系统的非功能性特征,对系统的高可用、高性能、扩展、安全、伸缩性、简洁等做系统级的把握 。
系统架构的设计要求架构师具备软件和硬件的功能和性能的过硬知识,这也是架构设计工作中最为困难的工作 。
文章插图
五、部署拓扑架构图(实际物理架构图):
拓扑架构,包括架构部署了几个节点,节点之间的关系,服务器的高可用,网路接口和协议等,决定了应用如何运行,运行的性能,可维护性,可扩展性,是所有架构的基础 。这个图主要是运维工程师主要关注的对象 。
文章插图
应用架构架构演进路程:
->初始阶段:LAMP,部署在一台服务器
->应用服务器和数据服务器分离
->使用缓存改善性能
->使用集群改善并发
->数据库的读写分离
->使用反向代理和cdn加速
->使用分布式文件和分布式数据库
->业务拆分
->分布式服务
文章插图
业务架构是生产力,应用架构是生产关系,技术架构是生产工具 。业务架构决定应用架构,应用架构需要适配业务架构,并随着业务架构不断进化,同时应用架构依托技术架构最终落地 。
企业一开始业务比较简单,比如进销存,此时面向内部用户,提供简单的信息管理系统(MIS),支持数据增删改查即可,单体应用可以满足要求 。
随着业务深入,进销存每块业务都变复杂,同时新增客户关系管理,以更好支持营销,业务的深度和广度都增加,这时需要对系统按照业务拆分,变成一个分布式系统 。
更进一步,企业转向互联网+战略,拓展在线交易,线上系统和内部系统业务类似,没必要重做一套,此时把内部系统的逻辑做服务化改造,同时供线上线下系统使用,变成一个简单的SOA架构 。
紧接着业务模式越来越复杂,订单、商品、库存、价格每块玩法都很深入,比如价格区分会员等级,访问渠道(无线还是PC),销售方式(团购还是普通)等,还有大量的价格促销,这些规则很复杂,容易相互冲突,需要把分散到各个业务的价格逻辑进行统一管理,以基础价格服务的方式透明地提供给上层应用,变成一个微内核的SOA架构 。
推荐阅读
- 新品推广和爆款拉新哪个好 超级推荐商品推广和图文推广的区别
- 短发|口碑最好的护肤品排行榜
- 脑白金广告案例分析
- 低碳环保应该怎样做
- 经常美容整形的危害有哪些
- 高职高专是什么学历
- 农村太阳能取暖方法
- 哪些学生具备保送生资格
- 酒店式公寓的特点有哪些
- 淘宝测图通过怎么操作 淘宝测图怎么操作步骤