APP开发架构规划

 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)

 业务逻辑思维导图;

  根据需求抽象出业务逻辑。

 — 欢迎下载 3 (2)

 功能-业务逻辑思维导图;

  支撑业务逻辑的功能模块,

 (3)

 基本功能模块关系;

  功能模块设计;

 (4)

 功能模块设计 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 选择合适的数据库产品

 — 欢迎下载 4 (1)

 Redis、MongoDB、MySQL

 2.4 选择消息队列产品

 (1)

 消息队列一般都包含 3 个角色:队列服务端、队列生产者、队列消费者;

 (2)

 常见消息队列产品,RabbitMQ、Redis、ZeroMQ、ActiveMQ、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 签名;

 — 欢迎下载 5 (2)

 AES 对称加密;

 3.3 短信服务

 (1)

 选择短信平台;

 3.4 高效更新数据

 (1)

 内容的推拉;

 (2)

 增量更新。

 3.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 日志分析平台

 — 欢迎下载 6 (1)

 Logstash、ElasticSearch、Kibana。

 3.10 Docker 容器

 (1)

 Docker 构建一致的开发环境;

 4 App 后台运维

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

 (1)

 常用命令,top、ps、netstat、lsof、traceroute

 4.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 后台新兴的数据库

 — 欢迎下载 7 (1)

 高可用集群;

 (2)

 LBS。

 5 App 后台架构剖析

 5.1 聊天 App 后台架构

 (1)

 移动互联网的网络特性,弱网络性、对流量敏感;

 (2)

 协议,XMPP、MQTT、ActivitySync、TCP 自定义;

 (3)

 整体架构,主要包括连接层、业务层、数据层;

 (4)

 消息推拉模式;

 (5)

 数据库架构,单机部署、读写分离、分表分库;

 (6)

 缓存架构,单台缓存、分布式缓存、主从缓存。

 5.2 LBS App 后台架构

 (1)

 地理坐标,GPS、基站、AGPS(GPS+基站结合)、WiFi 定位;

 (2)

 基于 MongoDB;

 (3)

 推送服务。

 6 App 后台架构的演进

 6.1 架构的核心要素

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

 (1)

 高性能;

 — 欢迎下载 8 (2)

 高可用;

 (3)

 可伸缩;

 (4)

 可扩展

 (5)

 安全性。

 6.2 架构选型的要点

 (1)

 用成熟稳定的开源软件;

 (2)

 尽可能使用云服务。

 6.3 架构的演进

 (1)

 单机部署;

 (2)

 分布式部署;

 (3)

 服务化。