您的位置:首页 > 大数据 > 物联网

我的物联网项目(三)平台架构

2017-11-22 10:39 288 查看
介绍下目前整个软件开发团队的配套成员

技能人数
android1
ios1
前端1
美工1
java2
 以上就是我们这个项目的人员搭配,我除了项目上的管理,更多的是在做业务需求,系统架构,平台建设,然后也顶多算半个开发人员参与在写代码。

一 系统架构

从前面的业务需求描述,到现在的人员配置,再加上时间进度上要求二个月出产品,在技术架构选型上基本首先考虑到是单体模式架构,采用传统的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-mqttmqtt协议组件
 

二 物理架构

所有基础设施服务器首选阿里云,我不是在替阿里云打广告,如果非要觉得我在打广告,麻烦各位在阿里云买服务器的时候选择下我的幸运卷(哈哈),后续在服务器选型和部署有相关问题可以找我一起探讨,幸运卷地址:

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一样越往后面升级配置越贵)

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息