目录
一、数据库选择策略
对于具体的实际问题,我们需要具体的分析。
选择数据库时考虑的因素:
常用数据库特点及其使用场合:
- 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:不同端口处理不同问题
总结
架构设计,是为了控制软件项目中技术复杂的问题。架构设计,通过组织人员和技术,低成本满足需求以及需求的变化,保障软件稳定高效运行。
架构设计可以通过四个基本步骤:
- 第一步:分析需求;
- 第二步:选择相似的成熟的架构设计方案;
- 第三步:自顶向下层层细化;
- 第四步:验证和优化架构设计方案。
通过良好的架构设计,可以有效降低开发难度和成本,让普通程序员也能实现复杂系统。