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。

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. 现货!《PHP7实践指南:o2o网站与App后台开发》京东天猫有售

    终于发售了,啥也不想说了,喜欢的或需要的就点击 链接 进去购买吧. 另外此书将作为 2017 PHP全球开发者大会 现场活动用书 天猫购书 包邮 PHP7实践指南:O2O网站与App后台开发 数据库设 ...

  2. 后台开发(1)---app后台开发入门

    app后台开发入门 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/weixin_36571185/article/details/70269448 ...

  3. C/C++Linux服务器开发高级架构师/Linux后台开发架构师丨高级进阶学习

    01 课程介绍 [录播]课程介绍(66分钟) 免费试学 [录播]磁盘存储链式的B树与B+树(131分钟) 免费试学 免费学习视频链接点击:C/C++Linux服务器开发高级架构师/Linux后台架构师 ...

  4. 得到、微信、美团、爱奇艺APP组件化架构实践

    一.背景 随着项目逐渐扩展,业务功能越来越多,代码量越来越多,开发人员数量也越来越多.此过程中,你是否有过以下烦恼? 项目模块多且复杂,编译一次要5分钟甚至10分钟?太慢不能忍? 改了一行代码 或只调 ...

  5. app后台开发笔记-新手

    1,app和app后台通信一般都用http协议: , 2,长连接(一直连接着):socket和websocket, 短连接(需要时才通信):http  3,app一般以HTTP的形式调用后端提供的AP ...

  6. 我在阿里做中后台开发的实践

    「开发全流程在线化」近些年来热度不断攀升,比如 AWS 在 C9 的实践.开源届比较出名的 TheiaJS,到后起之秀 code-server.行业佼佼者 VS Online 等.我个人以及我们团队对 ...

  7. java app后台开发实例_支付宝app-java后台

    @ApiOperation(value= "支付宝预支付", httpMethod= "POST") @PostMapping(value= "/al ...

  8. App 后台架构设计方案 设计思想与最佳实践

    CSDN 2016博客之星评选结果公布      [系列直播]零基础学习微信小程序!        "我的2016"主题征文活动     博客的神秘功能 App 后台架构设计方案 ...

  9. Linux C/C++后台开发高级架构师进阶指南-剑指腾讯T9

    C++后台开发是一个庞杂的技术栈,因为没有统一的开发框架并且应用行业非常广泛.所有涉猎广泛,这里就把C/C++++后台开发的技术点进行整理总结,看完以后,不会让你失望的. -------------- ...

  10. 后台服务架构高性能设计之道

    "N 高 N 可",高性能.高并发.高可用.高可靠.可扩展.可维护.可用性等是后台开发耳熟能详的词了,它们中有些词在大部分情况下表达相近意思.本序列文章旨在探讨和总结后台架构设计中 ...

最新文章

  1. 英特尔北京2022年冬奥会体验中心落成
  2. Linux学习-文件管理(2)
  3. 机器学习面试题集 - 详解四种交叉验证方法
  4. 快手宣布 7 月将取消大小周,​互联网大厂不卷了?
  5. 【转】Cannot find -ltinfo when compiling android 4.0.3
  6. PHP苹果不给上架,苹果商城上架拒绝
  7. 微软研究院研究员Ryan Beckett 博士论文《Network Control Plane Synthesis and Verification》下载—2018ACM最佳博士论文题目奖
  8. 结合CKFinder,给CKEditor加上上传图片功能
  9. 开发项目的简单流程(需求、数据库、编码)
  10. 跟我从零开始学python之一_从零开始学 Python 之运算符
  11. 二分类数据集_玩转UCI心脏病二分类数据集 领学课笔记
  12. 5.4 continue,break跳出循环
  13. html中固定浏览器最小化,浏览器最小化暂停播放
  14. 解决笔记本没有COM端口导致无法用SecureCRT或者超级终端配置交换机
  15. ST集成传感器方案实现电子罗盘功能
  16. 红外热成像技术的应用与发展
  17. linux怎么定时备份文件,linux自动定时备份文件
  18. Qt5.12 QML——TextMetrics字体长度的测量指标
  19. VMware虚拟机硬盘大小修改
  20. 【Cisco(思科)路由器vlan配置实例】制作简单的B项目小组VLAN规划

热门文章

  1. Windows:无须再忍,Microsoft Store下载慢/加速/更快,不摘抄(2022新)
  2. 这样的谷歌街景,你肯定没见过
  3. Lomboz插件的使用
  4. lomboz eclipse介绍
  5. android表格布局占满整行,Android布局之表格布局TableLayout详解
  6. lazarus编译程序提示不能加载PostgreSQL客户端动态库“libpq.dll“
  7. DOSBOX 0.74模拟器安装Windows 95
  8. 毕业设计 python opencv 机器视觉图像拼接算法
  9. 打印机与计算机无法进行通讯,打印时电脑提示:“打印机不能与计算机进行通讯”是为什么啊?是电脑出现问题还是打印机出现问题了?...
  10. 软件项目管理课程设计-数字化校园学工信息系统