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)

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) 功能模块设计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、MySQL

2.4 选择消息队列产品

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

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

2.5 分布式服务

(1) 远程服务,REST、RPC(开源RPC库dubbo、dubbox等)。

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 图片处理

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

(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) 高性能;

(2) 高可用;

(3) 可伸缩;

(4) 可扩展

(5) 安全性。

6.2 架构选型的要点

(1) 用成熟稳定的开源软件;

(2) 尽可能使用云服务。

6.3 架构的演进

(1) 单机部署;

(2) 分布式部署;

(3) 服务化。

APP后台架构开发实践笔记的更多相关文章

  1. 达达O2O后台架构演进实践:从0到4000高并发请求背后的努力

    1.引言   达达创立于2014年5月,业务覆盖全国37个城市,拥有130万注册众包配送员,日均配送百万单,是全国领先的最后三公里物流配送平台. 达达的业务模式与滴滴以及Uber很相似,以众包的方式利 ...

  2. App 后台架构

    转载请注明出处:http://blog.csdn.net/smartbetter/article/details/53933096 做App做的久了,就想研究一下与之相关的App后台,发现也是蛮有趣的 ...

  3. Java生鲜电商平台-App系统架构开发与设计

    Java生鲜电商平台-App系统架构开发与设计 说明:阅读此文,你可以学习到以下的技术分享 1.Java生鲜电商平台-App架构设计经验谈:接口的设计2.Java生鲜电商平台-App架构设计经验谈:技 ...

  4. APP后台架构20191205

    1.架构,架构与业务紧密相关,是有业务驱动的. 2.APP后台演进原则. App后台的架构是由业务规模驱动而演进的,App后台是为业务服务的,App后台的价值在于能为业务提供其所需要的功能,不应过度设 ...

  5. seajs的模块化开发--实践笔记

    2017-04-02 SeaJS是一个遵循CMD规范的JavaScript模块加载框架,可以实现JavaScript的模块化开发及加载机制.有效的解决复杂项目中命名冲突.依赖.性能等问题. SeaJS ...

  6. App后台开发架构实践笔记

    1 App后台入门 1.1 App后台的功能 (1)远程存储数据: (2)消息中转. 1.2 App后台架构 架构设计的流程 (1) 根据App的设计,梳理出App的业务流程: (2) 把每个业务流程 ...

  7. App架构师实践指南二之App开发工具

    App架构师实践指南二之App开发工具     1.Android Studio 2.编译调试---条件断点.右键单击断点,在弹出的窗口中输入Condition条件.---日志断点.右键单击断点,在弹 ...

  8. 基于React Native的58 APP开发实践

    React Native在iOS界早就炒的火热了,随着2015年底Android端推出后,一套代码能运行于双平台上,真正拥有了Hybrid框架的所有优势.再加上Native的优秀性能,让越来越多的公司 ...

  9. App架构师实践指南四之性能优化一

    App架构师实践指南四之性能优化一     1.性能维度常见用来衡量App性能的维度如图9-1所示.其中,性能指标包括电池(电量/温度).流量(上行流量/下行流量等).CPU(平均/最大/最小).内存 ...

随机推荐

  1. Python列出指定目录下的子目录/文件或者递归列出

    1.python只列出当前目录(或者指定目录)下的文件或者目录条目 import os files,dirs=[],[] for item in os.listdir(): if os.path.is ...

  2. Spark Extracting,transforming,selecting features

    Spark(3) - Extracting, transforming, selecting features 官方文档链接:https://spark.apache.org/docs/2.2.0/m ...

  3. macOS提示“将对您的电脑造成伤害……“进阶版

    > 很多小伙伴在更新完系统后运行应用会闪退以及提示"xxxx 将对您的电脑造成伤害. 您应该将它移到废纸篓",本文将针对此问题提供解决方法.如图:![-w456](https ...

  4. mysql 空值(null)和空字符('')的区别

    日常开发中,一般都会涉及到数据库增删改查,那么不可避免会遇到Mysql中的NULL和空字符. 空字符(")和空值(null)表面上看都是空,其实存在一些差异: 定义: 空值(NULL)的长度 ...

  5. Python-输入输出-input ouput

    输入.输出? 这种统称为IO流,也就是数据流向,在标准中,从终端输入称为标准输入 sidin,从终端输出为标准输出 stdout,从终端错误输出则为标准错误输出 stderr.这些只是IO流中终端方面 ...

  6. 抛弃vue-webpack-template,踩坑Vue-Cli创建vue项目

    官方指导网站https://cli.vuejs.org/ 一.全局安装@vue/cli //本人包管理工具使用yarn yarn global add @vue/cli 安装完成 二.创建vue项目 ...

  7. 初识HTTP 图解 形象生动

    使用软件: 通信猫  请自行下载 使用平台: win7 360浏览器 当前PC连接的是无线网,所以第2步查看的是 无线局域网适配器上的IP地址

  8. C语言普通写法实现:针对多次同步失败的节能处理机制

    程序不美, 不来一一整理了. 以后有时间可以把这个功能封装为一个类的对象来操作.即使不封装为类,至少也该封装为一个独立的函数吧... 关键代码摘要如下: 无线同步信号发射端,每分钟发一次,每次发射的时 ...

  9. Java知识系统回顾整理01基础06数组05复制数组

    数组的长度是不可变的,一旦分配好空间,是多长,就多长,不能增加也不能减少 一.复制数组 把一个数组的值,复制到另一个数组中 System.arraycopy(src, srcPos, dest, de ...

  10. <stdbool.h>的使用

    转载: 1.https://www.cnblogs.com/jediael/archive/2013/02/03/4304259.html 2.https://zhidao.baidu.com/que ...