码迷,mamicode.com
首页 > 其他好文 > 详细

学生信息管理系统架构设计

时间:2018-06-20 21:23:12      阅读:406      评论:0      收藏:0      [点我收藏+]

标签:img   .com   src   ges   异常情况   服务   人工   image   type   

近期学习架构设计,首先从最基本的学生信息管理系统进行分析。


目的:学生信息管理系统架构设计

思考第一步:识别系统复杂度

??架构设计的真正目的是为了解决软件复杂度带来的问题,故应首先识别本系统复杂度在何处,后文分析完整个系统见分晓。

思考第二步:基本功能

  • 登录
  • 注册
  • 信息查询
  • 成绩管理
  • 课程管理

思考第三步:性能

??一般学校学生约1~5万人,学生信息管理系统访问频率不高,平均每天单个学生的访问次数不到1次,因此性能这部分要求并不复杂,存储使用常规的MySQL数据库既能胜任,缓存可以不用,Web服务器使用Nginx绰绰有余。

思考第四步:可扩展性

??学生信息管理系统功能比较稳定,可扩展空间并不大,因此可扩展性也不复杂。

思考第五步:高可用

??学生信息管理系统即使宕机2小时,对学生管理工作影响并不大,因此可以不用做负载均衡,更不用考虑异地多活这类复杂的方案。但是,如果学生的数据全部丢失,修复是非常麻烦的,只能靠人工逐条修复,这个很难接受,因此需要考虑存储高可靠,这里就有点复杂了。我们需要考虑多种异常情况:机器故障、机房故障等。针对机器故障,我们需要设计MySQL的同机房主备方案;针对机房故障,我们需要设计MySQL的跨机房同步方案。

思考第六步:成本

??由于系统很简单,基本上几台服务器就能搞定,对于一所大学来说完全不是问题,故无需关注太多。

结论

??至此,可以看出本系统设计方案的主要复杂性体现在存储可靠性上,需要保证异常的时候,不要丢失所有数据即可(丢失几个或几十个学生的信息问题不大)。对应的架构如下:
?

技术分享图片

学生信息管理系统架构设计

标签:img   .com   src   ges   异常情况   服务   人工   image   type   

原文地址:http://blog.51cto.com/weiyuqingcheng/2131089

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!