关于APP开发架构规划

上传人:lb2****090 文档编号:148665812 上传时间:2020-10-21 格式:DOCX 页数:8 大小:27.73KB
返回 下载 相关 举报
关于APP开发架构规划_第1页
第1页 / 共8页
关于APP开发架构规划_第2页
第2页 / 共8页
关于APP开发架构规划_第3页
第3页 / 共8页
关于APP开发架构规划_第4页
第4页 / 共8页
关于APP开发架构规划_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《关于APP开发架构规划》由会员分享,可在线阅读,更多相关《关于APP开发架构规划(8页珍藏版)》请在金锄头文库上搜索。

1、App后台开发架构实践笔记1 App后台入门1.1 App后台的功能(1)远程存储数据;(2)消息中转。1.2 App后台架构架构设计的流程(1) 根据App的设计,梳理出App的业务流程;(2) 把每个业务流程可能会遇到的问题整理出来;(3) 根据整理出来的问题,探讨可行的技术解决方案;(4) 把所有的技术解决方案有机融合,就是一个App后台的初步架构。架构设计的特点(1) 架构是和业务紧密相关;(2) 架构的演变是由业务驱动;(3) 架构不是为了炫耀技术。1.3 App和App后台的通信(1) 用HTTP协议还是私有协议;(2) 用长连接还是短连接;(3) 通信数据格式(JSON、XML)

2、1.4 选择服务器(1) 传统IDC;(2) 云服务器。1.5 选择开发语言(1) 不同语言有其擅长的业务场景和性能特性;(2) 考虑开发效率和运行效率;(3) 同一个项目不同业务逻辑可以用不同语言实现。1.6 敏捷开发(1) Sprint计划会议;(2) 迭代开发;(3) 每日例会;(4) 评审会议;(5) 回顾会议;(6) 及时反馈。2 App后台基础技术2.1 从业务逻辑提炼API接口从业务逻辑到提炼API可分为下面6个阶段:(1) 业务逻辑思维导图; 根据需求抽象出业务逻辑。(2) 功能-业务逻辑思维导图; 支撑业务逻辑的功能模块,(3) 基本功能模块关系; 功能模块设计;(4) 功能

3、模块设计UML;(5) 设计API;(6) 编写API文档。 Swagger-UI在线API测试文档,测试驱动开发(TDD)。2.2 设计API的要点(1) 根据对象设计API;(2) API命名规范;(3) API安全性;(4) API返回数据;(5) 图片处理方式;(6) 返回的提示信息;(7) 在线API测试文档;(8) API版本升级。2.3 选择合适的数据库产品(1) Redis、MongoDB、MySQL2.4 选择消息队列产品(1) 消息队列一般都包含3个角色:队列服务端、队列生产者、队列消费者;(2) 常见消息队列产品,RabbitMQ、Redis、ZeroMQ、ActiveM

4、Q、RocketMQ。2.5 分布式服务(1) 远程服务,REST、RPC。2.6 搜索技术(1) 开源搜索项目,Lucene、Solr、ElasticSearch、Sphinx、CoreSeek。2.7 定时任务(1) Linux定制任务Crontab;(2) Java Quartz;(3) Python APScheduler;3 App后台核心技术3.1 用户验证方案(1) 使用HTTPS协议;(2) 使用密钥+令牌。3.2 通信安全(1) URL签名;(2) AES对称加密;3.3 短信服务(1) 选择短信平台;3.4 高效更新数据(1) 内容的推拉;(2) 增量更新。3.5 图片处理

5、(1) APP本地缓存图片;(2) 不同尺寸图片动态生成。3.6 视频处理(1) FFmpeg。3.7 资源文件(1) Android APK文件,通过Android-APKtool获取文件的基本信息;(2) iOS IPA文件。3.8 文件系统(1) 云存储,CDN;(2) 分布式文件系统。3.9 ELK日志分析平台(1) Logstash、ElasticSearch、Kibana。3.10 Docker容器(1) Docker构建一致的开发环境;4 App后台运维4.1 Linux,App后台应用最广泛的系统(1) 常用命令,top、ps、netstat、lsof、traceroute4.

6、2 Nginx,App后台HTTP服务的利器(1) HTTP服务;(2) 负载均衡。4.3 MySQL,App后台最常用的数据库(1) 存储引擎,MyISAM、InnoDB;(2) 索引;(3) 分库分表,MyCat。4.4 Redis,App后台高性能的缓存系统(1) 常用数据结构;(2) 集群,Twemproxy,Codis;(3) 持久化。4.5 MongoDB,App后台新兴的数据库(1) 高可用集群;(2) LBS。5 App后台架构剖析5.1 聊天App后台架构(1) 移动互联网的网络特性,弱网络性、对流量敏感;(2) 协议,XMPP、MQTT、ActivitySync、TCP自定

7、义;(3) 整体架构,主要包括连接层、业务层、数据层;(4) 消息推拉模式;(5) 数据库架构,单机部署、读写分离、分表分库;(6) 缓存架构,单台缓存、分布式缓存、主从缓存。5.2 LBS App后台架构(1) 地理坐标,GPS、基站、AGPS(GPS+基站结合)、WiFi定位;(2) 基于MongoDB;(3) 推送服务。6 App后台架构的演进6.1 架构的核心要素 软件架构是有关软件整体结构与组件的抽象描述,用于指导大型软件系统各个方面的设计。App后台架构可以定义为由App后台各个组件的功能描述、相互关系构成的整体系统。App后台架构的核心要素:(1) 高性能;(2) 高可用;(3)

8、 可伸缩;(4) 可扩展(5) 安全性。6.2 架构选型的要点(1) 用成熟稳定的开源软件;(2) 尽可能使用云服务。6.3 架构的演进(1) 单机部署;(2) 分布式部署;(3) 服务化。亲爱的用户:烟雨江南,画屏如展。在那桃花盛开的地方,在这醉人芬芳的季节,愿你生活像春天一样阳光,心情像桃花一样美丽,感谢你的阅读。1、最困难的事就是认识自己。20.10.2110.21.202021:1721:17:2910月-2021:172、自知之明是最难得的知识。二二二二年十月二十一日2020年10月21日星期三3、越是无能的人,越喜欢挑剔别人。21:1710.21.202021:1710.21.20

9、2021:1721:17:2910.21.202021:1710.21.20204、与肝胆人共事,无字句处读书。10.21.202010.21.202021:1721:1721:17:2921:17:295、三军可夺帅也。星期三, 十月 21, 2020十月 20星期三, 十月 21, 202010/21/20206、最大的骄傲于最大的自卑都表示心灵的最软弱无力。9时17分9时17分21-10月-2010.21.20207、人生就是学校。20.10.2120.10.2120.10.21。2020年10月21日星期三二二二二年十月二十一日8、你让爱生命吗,那么不要浪费时间。21:1721:17:2910.21.2020星期三, 十月 21, 2020

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号