学习笔记:
- 画出微信的架构示意图。
答:微信的业务架构图如下:
https://www.processon.com/view/link/61224fd30e3e743b3279c025
- “学生管理系统”毕设架构设计
假设今年学校毕业设计要求提升,要求做真正可运行的学生管理系统,学院对毕设的具体要求如下:
1 要求可以通过公网域名访问;
2 要求至少 3 人合作完成;
3 能够支撑管理 1000 个学生;
4 答辩的时候会根据架构方案来进行打分,不推荐太简单和太复杂的方案。
你找了 2 个好朋友一起来做这个项目,你们的基本情况如下:
1 大家都会 Java,但是有一个是 PHP 高手;
2 大家经济条件一般。
作业要求:
1 对照面向复杂度架构设计方法论,构思 2 个以上的备选架构方案。
2 使用 PPT 来画出你的备选架构方案,并说明方案的优缺点。
3 给出你选择的最终方案以及选择理由。
答:
方案 1:
- 采购域名,备案,从 Let's encrypt 或者云服务器厂商网站上,获取免费的 SSL 证书;
- 采购两台云服务器,各部署上 Nginx 和一套后台系统,MySQL 及 CDN 均采购云服务,选择按流量计价方式,云服务器均开放 443 端口,Nginx 配置,两台云服务器上均相同;
- 业务方面分配,采用前后端分离的架构,前后端通过 HTTP 接口交互;
- 后端业务开发采用 Java 语言,因为 Java 是大家的共同语言。后端由两人开发,按模块分为用户模块、课程模块、管理模块、存储模块,开发完打包成 jar 包,放到云服务器运行;
- 对于需要图片的相关场景,将图片对接到云 CDN 服务,提升用户体验;
- 前端页面开发,主要以 Vue,JavaScript 或者 PHP 为主,请 PHP 大神主要把关;
- 配置定时任务,定期从 MySQL 云服务拉取备份文件存储到云服务器上。
方案 2:
- 采购域名并备案,获取免费的 SSL 证书;
- 按功能拆分为用户服务、课程服务、文件存储服务、管理服务,从节约成本的角度考虑,均直接部署到云服务器上,文件与 MySQL 均部署到服务器上;
- 业务上,后台分为管理模块、用户模块、课程模块、文件存储模块,采用 Java 语言开发;
- 前端采用 PHP 或者 Vue、JavaScript 等语言开发。
方案三:
- 采用 LAMP 架构,前后端都由 PHP 大神实现,寻找 Github 上类似的代码,修改实现功能,完成需求。
方案对比:
方案一:
优点:稳定性及可靠性高,分工合理;
缺点:成本略高,学生党可能承受不了。
方案二:
优点:部署于一台服务器,将其性能压榨到极致,成本相对比较低;
缺点:服务器如果宕机,系统即不可用,且数据库及文件需要人工维护;自己实现的文件存储,需要考虑文件名重复、按路径获取到其他人文件(自己不应该看到的)等潜在问题。
方案三:
优点:PHP 开发相对较快,避免了沟通成本;
缺点:人员分工不合理。
最终采用:
方案一,分工合理,团队成员均能得到锻炼,对接云厂商的服务,收费尚可。