软件工程 个人学习笔记(第四章)

目录

一、数据库选择策略

选择数据库时考虑的因素:

 常用数据库特点及其使用场合:

二、软件体系结构概念

软件体系结构的目标

 软件体系结构的发展

 软件体系结构的风格、模式和框架

三、软件设计原则

抽象:

封装:

模块化:

层次化:

复用:

四、软件体系结构风格

常见的体系结构风格:

层次结构:

  集群结构:

五、Web系统架构设计

总结


一、数据库选择策略

对于具体的实际问题,我们需要具体的分析。

选择数据库时考虑的因素:

 常用数据库特点及其使用场合:

  • MySQL:

 

  • Mongodb:

  • Redis:


二、软件体系结构概念

什么是软件体系结构?
软件体系结构包括构成系统的设计元素的描述、设计元素之间的交互、设计元素的组合模式以及在这些模式中的约束。它主要包含五个方面的内容:1构件,2连接件,3约束,4质量,5物理分布

构件:代表着一组基本的构成要素。

连接件:表示了这些要素之间的连接关系

约束:作用与这些要素或者连接关系上的一些限制条件

质量:是系统的质量属性,像性能、可扩展性、可修改性、可重用性、安全性等

物理分布:代表着这些要素连接之后形成的拓扑结构,描述了软件到硬件的映射

简单的说,软件体系结构=构件+连接件+约束。它提供了在更宏观的结构层次上来理解系统层面问题的一个骨架。

  •  构件:

  • 连接:

  • 连接件:

软件体系结构的目标

 软件体系结构的发展

 软件体系结构的风格、模式和框架


三、软件设计原则

设计原则是系统分解和模块设计的基本标准,应用这些原则可以使代码更加灵活、易于维护和扩展,抽象、封装、模块化、层次化和复用这样一些原则基本是所有语言都通用的。

  • 抽象:

  • 封装:

  • 模块化:

  • 层次化:

  • 复用:

四、软件体系结构风格

软件体系结构风格是描述特定系统组织方式的惯用范例,强调了软件系统中通用的组织结构。使用软件体系结构风格可以促进设计的重用和大量代码的重用,使系统更加易于理解,而且标准化的风格也有利于系统的互操作。

常见的体系结构风格:

1、主程序-子程序风格:

 2、面向对象风格:

  3、管道-过滤器风格:

  4、以数据为中心风格(之仓库体系结构):

 

层次结构:

  客户机/服务器结构:

  集群结构:

 MVC结构:


五、Web系统架构设计

1.软件设计过程

软件交互设计+系统总体设计+模块设计和实现(算法和数据结构、数据库设计)

系统总体设计:明确设计目标、确定子系统或模块、选择系统部署方案(与硬件关联)、定义设计策略、评审系统设计方案

系统设计目标:性能准则:响应时间、吞吐量(一个固定时间内系统完成的任务数,与响应时间有所折中)、存储量

可靠性准则、维护准则、最终用户准则、成本准则

权衡设计目标:空间与速度、交付时间与功能、交付时间与质量、交付时间与人员(在项目的后期,增加人手是不可取的?)

定义设计策略:数据:数据文件(由操作系统决定)、关系数据库(以二维表的形式存储管理)、非关系型数据库(以key-value方式存储)、内存数据库

确定访问控制策略、验证用户身份、设计全局控制流(控制流机制:过程驱动、事件驱动、线程)、识别边界问题(系统启动、初始化、关闭、异常处理)

2.web体系架构设计

MVC:一种架构模式,Model(数据层)、View、Controller(实现业务逻辑)


RESTFul API:隔离前后端,使得程序员专注于业务逻辑

 

异步处理响应:提供更复杂的服务;先发送一个task_id,根据id查询进度等;设一个定时器,定时发邮件等。实现方式有:celery(异步任务队列)

内存数据库:加快响应时间,比如redis、memcached,注意过期机制

NGINX:不同端口处理不同问题



总结

架构设计,是为了控制软件项目中技术复杂的问题。架构设计,通过组织人员和技术,低成本满足需求以及需求的变化,保障软件稳定高效运行。

架构设计可以通过四个基本步骤:

  • 第一步:分析需求;
  • 第二步:选择相似的成熟的架构设计方案;
  • 第三步:自顶向下层层细化;
  • 第四步:验证和优化架构设计方案。

通过良好的架构设计,可以有效降低开发难度和成本,让普通程序员也能实现复杂系统。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值