首页 范文大全 古典文学 职场知识 中国文学 公文书信 外国名著 寓言童话 百家讲坛 散文/诗歌 美文欣赏 礼仪知识 民俗风情
  • 工作总结
  • 工作计划
  • 心得体会
  • 竞聘演讲
  • 会议发言
  • 爱国演讲
  • 就职演说
  • 开业开幕
  • 思想学习
  • 征文演讲
  • 经验材料
  • 述职报告
  • 调研报告
  • 工作汇报
  • 年终总结
  • 申报材料
  • 学习体会
  • 企划方案
  • 活动方案
  • 技巧经验
  • 模板范例
  • 思想宣传
  • 经济工作
  • 工作报告
  • 组织人事
  • 反腐倡廉
  • 慰问贺电
  • 先进事迹
  • 思想汇报
  • 入党申请书
  • 党会发言
  • 先进性教育
  • 入团申请书
  • 个人简历
  • 演讲稿
  • 调查报告
  • 实习报告
  • 和谐社会
  • 观后感
  • 读后感
  • 作文范文
  • 自我鉴定
  • 讲话稿
  • 自查报告
  • APP开发架构规划

    时间:2020-10-07 12:01:44 来源:蒲公英阅读网 本文已影响 蒲公英阅读网手机站

    相关热词搜索:架构 规划 开发

     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)

     服务化。

    • 范文大全
    • 职场知识
    • 精美散文
    • 名著
    • 讲坛
    • 诗歌
    • 礼仪知识