APP后台架构

App后台

 APP功能: 远程数据存储  消息中转 

 App后台架构:

架构设计的流程(1) 根据App的设计,梳理出App的业务流程;(2) 把每个业务流程可能会遇到的问题整理出来;(3) 根据整理出来的问题,探讨可行的技术解决方案;(4) 把所有的技术解决方案有机融合,就是一个App后台的初步

架构设计的特点:(1) 架构是和业务紧密相关;(2) 架构的演变是由业务驱动;(3) 架构不是为了炫耀技术。

App和App后台的通信:(1) 用HTTP协议还是私有协议;(2) 用长连接还是短连接;(3) 通信数据格式(JSON、XML)

 选择服务器:(1) 传统IDC;(2) 云服务器。

 选择开发语言:(1) 不同语言有其擅长的业务场景和性能特性;(2) 考虑开发效率和运行效率;(3) 同一个项目不同业务逻辑可以用不同语言实现。

敏捷开发:(1) Sprint计划会议;(2) 迭代开发;(3) 每日例会;(4) 评审会议;(5) 回顾会议;(6) 及时反馈。

 App后台基础技术

从业务逻辑提炼API接口

从业务逻辑到提炼API可分为下面6个阶段:
(1) 业务逻辑思维导图;   根据需求抽象出业务逻辑。

(2) 功能-业务逻辑思维导图; 支撑业务逻辑的功能模块,

(3) 基本功能模块关系;  功能模块设计;

(4) 功能模块设计UML;

(5) 设计API;

(6) 编写API文档。 Swagger-UI在线API测试文档,测试驱动开发(TDD)。

设计API的要点:(1) 根据对象设计API;(2) API命名规范;(3) API安全性;(4) API返回数据;(5) 图片处理方式(6) 返回的提示信息;(7) 在线API测试文档;(8) API版本升级。

 选择合适的数据库产品(1) Redis、MongoDB、MySQL

选择消息队列产品:(1) 消息队列一般都包含3个角色:队列服务端、队列生产者、队列消费者;

                                (2) 常见消息队列产品,RabbitMQ、Redis、ZeroMQ、ActiveMQ、RocketMQ。

 分布式服务:(1) 远程服务,REST、RPC。

 搜索技术:(1) 开源搜索项目,Lucene、Solr、ElasticSearch、Sphinx、CoreSeek。

定时任务:(1) Linux定制任务Crontab;(2) Java Quartz;(3) Python APScheduler;

App后台核心技术

 用户验证方案:(1) 使用HTTPS协议;(2) 使用密钥+令牌。

 通信安全:(1) URL签名;(2) AES对称加密;

 短信服务(1) 选择短信平台;

 高效更新数据:(1) 内容的推拉;(2) 增量更新。

 图片处理:(1) APP本地缓存图片;(2) 不同尺寸图片动态生成。

视频处理:(1) FFmpeg。

资源文件(1) Android APK文件,通过Android-APKtool获取文件的基本信息;(2) iOS IPA文件。

文件系统(1) 云存储,CDN;(2) 分布式文件系统。

 ELK日志分析平台:(1) Logstash、ElasticSearch、Kibana。

 Docker容器:(1) Docker构建一致的开发环境;

App后台运维

Linux,App后台应用最广泛的系统

(1) 常用命令,top、ps、netstat、lsof、traceroute

Nginx,App后台HTTP服务的利器:(1) HTTP服务;(2) 负载均衡。

 MySQL,App后台最常用的数据库(1) 存储引擎,MyISAM、InnoDB;(2) 索引;(3) 分库分表,MyCat。

Redis,App后台高性能的缓存系统(1) 常用数据结构;2) 集群,Twemproxy,Codis;(3) 持久化。

 MongoDB,App后台新兴的数据库(1) 高可用集群;(2) LBS。

App后台架构剖析

5.1 聊天App后台架构:(1) 移动互联网的网络特性,弱网络性、对流量敏感;(2) 协议,XMPP、MQTT、ActivitySync、TCP自定义;(3) 整体架构,主要包括连接层、业务层、数据层;(4) 消息推拉模式;(5) 数据库架构,单机部署、读写分离、分表分库;(6) 缓存架构,单台缓存、分布式缓存、主从缓存。

 LBS App后台架构(1) 地理坐标,GPS、基站、AGPS(GPS+基站结合)、WiFi定位;(2) 基于MongoDB;(3) 推送服务。

App后台架构的演进

6.1 架构的核心要素

         软件架构是有关软件整体结构与组件的抽象描述,用于指导大型软件系统各个方面的设计。App后台架构可以定义为由App后台各个组件的功能描述、相互关系构成的整体系统。App后台架构的核心要素:

(1) 高性能;(2) 高可用;(3) 可伸缩(4) 可扩展:(5) 安全性。

架构选型的要点:(1) 用成熟稳定的开源软件;(2) 尽可能使用云服务。

架构的演进:(1) 单机部署:(2) 分布式部署;(3) 服务化。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值