介绍下目前整个软件
开发团队的配套成员
技能 人数
android 1
ios 1
前端 1
美工 1
java 2
以上就是我们这个项目的人员搭配,我除了项目上的管理,更多的是在做业务需求,系统
架构,平台建设,然后也顶多算半个开发人员参与在
写代码。
一 系统架构
从前面的业务需求描述,到现在的人员配置,再加上时间进度上要求二个月出产品,在技术架构选型上基本首先考虑到是单体模式架构,采用传统的MVC开发模式,java开发人员是整个项目的核心担当,
项目管理使用maven,运营平台UI采用的是容易上手的jquery easyui,后台采用的是springMVC+mybatis,数据库毫无疑问用的是mysql,app用的是原生语言开发,微信前端页面由美工设计(包括app),前端切图成html,交给java开发,整个分工大概就这样。
项目结构如下:
项目名 描述
orange-parent 定义整个项目基本群的基本信息,依赖插件信息,以及
自定义信息
orange-framework 定义spring curd,rest服务,MVC等基类和模板
orange-core 核心项目(dao,entity,mapper)
orange-utils 丰富的常用工具包
orange-redis 分布式缓存redis组件
orange-serviceweb 业务
接口,主要对接app
orange-wechat 微信平台
orange-adminweb 运营平台
orange-mqtt mqtt
协议组件
二 物理架构
所有基础设施服务器首选阿里云,我不是在替阿里云打广告,如果非要觉得我在打广告,麻烦各位在阿里云买服务器的时候选择下我的幸运卷(哈哈),后续在服务器选型和部署有相关问题可以找我一起探讨,幸运卷地址:
https://promotion.aliyun.com/ntms/act/ambassador/sharetouser.html?userCode=5gg22qjx&utm_source=5gg22qjx
言归正传,像这种创业型互联网项目首选阿里云是
比较好的选择,我指的不单单是阿里云提供的ECS服务器,更多看重的是阿里云的整套解决方案。比如我们要做tomcat集群,可能要装nginx,nginx要高可用,就得通过keepalive主从双机热备自动切换,就光这么一套配置下来,你少说也要好几台服务器吧,而且还不一定稳定,更加没有可视化控制台监控各项指标,但是在阿里云你根本无需花这些时间来弄这些,去买个SLB负载均衡即可搞定,而且又便宜。再比如数据库mysql,前期就算不做集群,你也要做主备高可用吧,如果二台mysql做高可用,你还得需要keepalive或者haproxy,这么一套配置下来,成本也不低。说实话,我觉得阿里云数据库RDS前期配置在同等的情况下更加便宜方便,毕竟RDS mysql本身还自带了控制台可以方便监控各项参数排查问题,阿里云数据库RDS在后期的配置升级的确是成本昂贵,这个时候自己用一些廉价的服务器搭建
数据库集群是可取的,当然这个是后话了。还有文件服务器就算采用fastdfs搭建也需要一台服务器,总的算下来,还是不划算。
平台ECS的配置:
项目名 描述 ECS服务器 SLB负载均衡
orange-adminweb 运营平台后台 1台4核8G5M
orange-mqtt mqtt中间平台 2台4核8G5M 1个主备5M
orange-serviceweb 核心业务层 2台4核8G5M 1个主备5M
orange-wechat 微信业务 1台4核8G5M
平台数据库配置: 高可用通用型4核8G
平台redis配置: 4G主从版
平台文件存储: OSS买流量包
平台mqtt配置: 按连接数上限购买,前期买2000,后期继续升级(说实话,这个和RDS一样越往后面升级配置越贵)