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)
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后台架构开发实践笔记的更多相关文章
- 达达O2O后台架构演进实践:从0到4000高并发请求背后的努力
1.引言 达达创立于2014年5月,业务覆盖全国37个城市,拥有130万注册众包配送员,日均配送百万单,是全国领先的最后三公里物流配送平台. 达达的业务模式与滴滴以及Uber很相似,以众包的方式利 ...
- App 后台架构
转载请注明出处:http://blog.csdn.net/smartbetter/article/details/53933096 做App做的久了,就想研究一下与之相关的App后台,发现也是蛮有趣的 ...
- Java生鲜电商平台-App系统架构开发与设计
Java生鲜电商平台-App系统架构开发与设计 说明:阅读此文,你可以学习到以下的技术分享 1.Java生鲜电商平台-App架构设计经验谈:接口的设计2.Java生鲜电商平台-App架构设计经验谈:技 ...
- APP后台架构20191205
1.架构,架构与业务紧密相关,是有业务驱动的. 2.APP后台演进原则. App后台的架构是由业务规模驱动而演进的,App后台是为业务服务的,App后台的价值在于能为业务提供其所需要的功能,不应过度设 ...
- seajs的模块化开发--实践笔记
2017-04-02 SeaJS是一个遵循CMD规范的JavaScript模块加载框架,可以实现JavaScript的模块化开发及加载机制.有效的解决复杂项目中命名冲突.依赖.性能等问题. SeaJS ...
- App后台开发架构实践笔记
1 App后台入门 1.1 App后台的功能 (1)远程存储数据: (2)消息中转. 1.2 App后台架构 架构设计的流程 (1) 根据App的设计,梳理出App的业务流程: (2) 把每个业务流程 ...
- App架构师实践指南二之App开发工具
App架构师实践指南二之App开发工具 1.Android Studio 2.编译调试---条件断点.右键单击断点,在弹出的窗口中输入Condition条件.---日志断点.右键单击断点,在弹 ...
- 基于React Native的58 APP开发实践
React Native在iOS界早就炒的火热了,随着2015年底Android端推出后,一套代码能运行于双平台上,真正拥有了Hybrid框架的所有优势.再加上Native的优秀性能,让越来越多的公司 ...
- App架构师实践指南四之性能优化一
App架构师实践指南四之性能优化一 1.性能维度常见用来衡量App性能的维度如图9-1所示.其中,性能指标包括电池(电量/温度).流量(上行流量/下行流量等).CPU(平均/最大/最小).内存 ...
随机推荐
- python爬取酷狗音乐
url:https://www.kugou.com/yy/html/rank.html 我们随便访问一个歌曲可以看到url有个hash https://www.kugou.com/song/#hash ...
- C# 中居然也有切片语法糖,太厉害了
一:背景 1. 讲故事 昨天在 github 上准备找找 C# 9 又有哪些新语法糖可以试用,不觉在一个文档上看到一个很奇怪的写法: foreach (var item in myArray[0..5 ...
- 种子爆破&[GWCTF 2019]枯燥的抽奖
伪随机数的爆破,种子爆破 做到了一道题,就是有个伪随机数爆破的漏洞,当时尽管是看到了这两个敏感的函数,但是先去看其他的了,没有看到什么漏洞,所以我当时是准备直接强行爆破,之后看到使用伪随机数爆破的方式 ...
- 几个超级好用但很少有人知道的 webstorm技巧
我总结一些我发现的比较实用的功能,内容来自日常工作中用到的功能.图片来自PPT,是在公司内部的分享. 你不知道的webstorm进阶使用技巧 1.双击shift 全局搜索,可以搜索代码.设置等. 如果 ...
- Solon详解(八)- Solon的缓存框架使用和定制
Solon详解系列文章: Solon详解(一)- 快速入门 Solon详解(二)- Solon的核心 Solon详解(三)- Solon的web开发 Solon详解(四)- Solon的事务传播机制 ...
- Typora,你好!
初识Typora 1.标题 一个井号+空格+回车 =一级标题 两个井号+空格+回车 =二级标题 三个井号+空格+回车 =三级标题 四个井号+空格+回车 =四级标题 快捷键的话: 按ctrl + 1 就 ...
- git的详细使用,项目创建到同步远程仓库,版本回退,忽略文件,分支创建,分支合并,分支名称修改,冲突解决,项目迁移
注意:此处省略git的安装 1..git的工作流程示意图: 2.本地仓库的初始化: 2.1 创建一个文件夹,如我创建的是:D:\gitdemo\shop 2.2 进入shop目录,鼠标右键,打开git ...
- Centos-链接-ln
ln 用来在文件或者目录之间创建链接,分为软链接和硬链接,硬链接依据文件的inode来进行链接,linux系统中允许存在多个inode号,文件真正的删除,是指向这个文件block的inode为0则该数 ...
- 039 01 Android 零基础入门 01 Java基础语法 05 Java流程控制之循环结构 01 循环结构概述
039 01 Android 零基础入门 01 Java基础语法 05 Java流程控制之循环结构 01 循环结构概述 本文知识点:循环结构概述 循环结构主要内容 while 循环 do-whiile ...
- apline无法向gitlab上传git lfs问题
1 背景 在k8s中基于alpine做底层系统的容器进行git lfs push操作时,发现报错无法上传成功 Fatal error: Server error: http://git.ops.xxx ...