欢迎来到天天文库
浏览记录
ID:35787289
大小:899.75 KB
页数:18页
时间:2019-04-18
《系统设计之火车票预订系统》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、--背景:昨天元宵佳节同事聚餐,大家聊起今年的网上订票系统,毁誉参半呀。从程序员的角度我们是怎么看这个铁老大斥资几千万的大系统的,这里我就不说了。要写的是如果我是这个系统的架构师(呵呵夸口了,如果也许假设是,然而未必不见得,嘿嘿),我会如何设计这个系统。2月我会利用零星的时间,就这个系统演练下系统设计的能力,作为这个月送给自己的玩具,呵呵,不足之处欢迎大家批评指正踊跃拍砖。目标:本系统主要实现对火车车次的查询、车票预订功能。关注在大用户量集中访问情况下,比如春运订票高峰期,系统承载能力。当然细节方面也要注意系统的易
2、用性、用户体验,比如在查询两车站间没有直达车时给出中转站,输入车站名简称时有提示,管理员可修改预售期、增减车次信息等。功能:两站之间的车次查询具体某车次的查询进出某车站所有车次的查询车票预订(车票预定后,所需的座位被声明,其余座位解锁)乘客取票(首先根据身份证号查询订单,然后修改订单状态)用户的注册和登录,修改密码订单管理(订单的查询和撤销等)后台管理员系统(编辑列车、车票、预售期等相关信息)系统设计:---一、分析阶段---(1)需求分析---业务需求:本系统主要的业务需求包括车次查询、车票预订---用户需求(用
3、例图描述):行为需求(用例规约描述)------(2)领域建模首先按照功能进行模块化的分离。---然后对分离出来的模块进行抽象。下面以查询和预订模块为例:二、架构设计阶段---1.概念型架构设计---(1)确定关键需求车票预订是本系统的关键需求。(2)概念性架构设计步骤一、鲁棒性分析鲁棒图(静态):---鲁棒顺序图(动态):---步骤二、引入架构模式---步骤三、质量属性分析2.实际架构设计---(1)逻辑架构---车票预订的逻辑架构如下:---车票查询的逻辑架构如下:票的状态图如下:---(2)开发架构(3)运行
4、架构---(4)物理架构(5)数据架构---附加:可增加求购和转让信息发布功能。恰当使用AJAX技术进行信息的异步传输。经常查询的数据要设置缓存。系统可以扩展个makecharge的模块,调用服务商提供的接口,这样就可以增加信用卡或支付宝支付功能,最好还能提供送票服务。注意半段的车票可以继续出售问题的设计。注意学生票、军人票等特殊票种的处理情况。准备知识:(1)逻辑架构l思想:逻辑架构的设计着重考虑功能需求,即系统应向用户提供什么服务。规定了软件架构由哪些逻辑元素组成,以及这些逻辑元素之间的关系。逻辑架构的设计往往
5、是从用例分析开始的,然后综合这些用例分析成果,得到整个软件系统的逻辑架构。逻辑架构设计要实现层、子系统、模块等的划分决定交互接口和交互机制(交互机制是指不同软件单元之间交互的手段。交互机制的例子有:方法调用、基于RMI的远程方法调用、发送消息等。)l关注点:功能需求、行为和职责的划分,将不同的职责分配给逻辑层、功能模块、类等不同力度的逻辑单元。l工作任务:---?细化功能单元---?发现通用机制(机制Mechanism是模式的实例。机制必须进一步细化才能成为特定模型中的协作,因此机制是独特上下文中重复出现的问题的特
6、定解决方案。)?细化领域模型?确定子系统接口和交互机制l描述方式:静态:包图、类图、对象图。动态:序列图、协作图、状态图、活动图。(2)开发架构l思想:开发架构的设计着重考虑开发期质量属性,例如可扩展性、可重用性、可移植性、易理解性、易测试性等。l关注点:软件模块的实际组织方式,具体涉及源程序文件、配置文件、源程序包、编译及打包后的目标文件、第三方库文件等。l工作任务:?确定要开发或直接利用的程序包之间的依赖关系?确定采用的技术?确定采用的框架等l关系:开发架构和逻辑架构是什么关系?开发架构和逻辑架构之间存在一定的
7、映射关系:比如逻辑架构中的逻辑层一般会映射到开发架构中的多个程序包;开发架构中的源码文件可以包含逻辑架构中的一到多个类。---l描述方式:包图、类图、组件图。---(3)运行架构l思想:运行架构的设计着重考虑运行期质量属性。l关注点:进程、线程、对象等运行时概念,已经相关的并发、同步、通信等问题。l工作任务:?确定引入哪些进程与线程?确定主动对象、被动对象、以及控制流关系?处理相关问题:进程线程的创建、销毁、通信机制、资源争用等?协议设计(可选,例如基于TCP/IP协议定义本系统的“应用协议”)l关系:开发架构和运
8、行架构是什么关系?开发架构偏重程序包在编译时期的静态依赖关系,而这些程序运行起来之后会表现为对象、线程、进程,运行架构比较关注的是这些运行时单元的交互问题。运行架构是在开发架构的基础上,从宏观上规划多条控制流的并发和同步。l描述方式:静态方面可用包图、类图、对象图动态方面可用序列图、协作图(4)物理架构l思想:物理架构的设计着重考虑安装和部署需求。规定了软件
此文档下载收益归作者所有