APP開(kāi)發(fā)架構(gòu)規(guī)劃_第1頁(yè)
APP開(kāi)發(fā)架構(gòu)規(guī)劃_第2頁(yè)
APP開(kāi)發(fā)架構(gòu)規(guī)劃_第3頁(yè)
APP開(kāi)發(fā)架構(gòu)規(guī)劃_第4頁(yè)
APP開(kāi)發(fā)架構(gòu)規(guī)劃_第5頁(yè)
已閱讀5頁(yè),還剩4頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、App后臺(tái)開(kāi)發(fā)架構(gòu)實(shí)踐筆記1 App后臺(tái)入門(mén)1.1 App后臺(tái)的功能(1)遠(yuǎn)程存儲(chǔ)數(shù)據(jù);(2)消息中轉(zhuǎn)。1.2 App后臺(tái)架構(gòu)架構(gòu)設(shè)計(jì)的流程(1) 根據(jù)App的設(shè)計(jì),梳理出App的業(yè)務(wù)流程;(2) 把每個(gè)業(yè)務(wù)流程可能會(huì)遇到的問(wèn)題整理出來(lái);(3) 根據(jù)整理出來(lái)的問(wèn)題,探討可行的技術(shù)解決方案;(4) 把所有的技術(shù)解決方案有機(jī)融合,就是一個(gè)App后臺(tái)的初步架構(gòu)。架構(gòu)設(shè)計(jì)的特點(diǎn)(1) 架構(gòu)是和業(yè)務(wù)緊密相關(guān);(2) 架構(gòu)的演變是由業(yè)務(wù)驅(qū)動(dòng);(3) 架構(gòu)不是為了炫耀技術(shù)。1.3 App和App后臺(tái)的通信(1) 用HTTP協(xié)議還是私有協(xié)議;(2) 用長(zhǎng)連接還是短連接;(3) 通信數(shù)據(jù)格式(JSON、XML)

2、1.4 選擇服務(wù)器(1) 傳統(tǒng)IDC;(2) 云服務(wù)器。1.5 選擇開(kāi)發(fā)語(yǔ)言(1) 不同語(yǔ)言有其擅長(zhǎng)的業(yè)務(wù)場(chǎng)景和性能特性;(2) 考慮開(kāi)發(fā)效率和運(yùn)行效率;(3) 同一個(gè)項(xiàng)目不同業(yè)務(wù)邏輯可以用不同語(yǔ)言實(shí)現(xiàn)。1.6 敏捷開(kāi)發(fā)(1) Sprint計(jì)劃會(huì)議;(2) 迭代開(kāi)發(fā);(3) 每日例會(huì);(4) 評(píng)審會(huì)議;(5) 回顧會(huì)議;(6) 及時(shí)反饋。2 App后臺(tái)基礎(chǔ)技術(shù)2.1 從業(yè)務(wù)邏輯提煉API接口從業(yè)務(wù)邏輯到提煉API可分為下面6個(gè)階段:(1) 業(yè)務(wù)邏輯思維導(dǎo)圖; 根據(jù)需求抽象出業(yè)務(wù)邏輯。(2) 功能-業(yè)務(wù)邏輯思維導(dǎo)圖; 支撐業(yè)務(wù)邏輯的功能模塊,(3) 基本功能模塊關(guān)系; 功能模塊設(shè)計(jì);(4) 功能

3、模塊設(shè)計(jì)UML;(5) 設(shè)計(jì)API;(6) 編寫(xiě)API文檔。 Swagger-UI在線API測(cè)試文檔,測(cè)試驅(qū)動(dòng)開(kāi)發(fā)(TDD)。2.2 設(shè)計(jì)API的要點(diǎn)(1) 根據(jù)對(duì)象設(shè)計(jì)API;(2) API命名規(guī)范;(3) API安全性;(4) API返回?cái)?shù)據(jù);(5) 圖片處理方式;(6) 返回的提示信息;(7) 在線API測(cè)試文檔;(8) API版本升級(jí)。2.3 選擇合適的數(shù)據(jù)庫(kù)產(chǎn)品(1) Redis、MongoDB、MySQL2.4 選擇消息隊(duì)列產(chǎn)品(1) 消息隊(duì)列一般都包含3個(gè)角色:隊(duì)列服務(wù)端、隊(duì)列生產(chǎn)者、隊(duì)列消費(fèi)者;(2) 常見(jiàn)消息隊(duì)列產(chǎn)品,RabbitMQ、Redis、ZeroMQ、ActiveM

4、Q、RocketMQ。2.5 分布式服務(wù)(1) 遠(yuǎn)程服務(wù),REST、RPC。2.6 搜索技術(shù)(1) 開(kāi)源搜索項(xiàng)目,Lucene、Solr、ElasticSearch、Sphinx、CoreSeek。2.7 定時(shí)任務(wù)(1) Linux定制任務(wù)Crontab;(2) Java Quartz;(3) Python APScheduler;3 App后臺(tái)核心技術(shù)3.1 用戶驗(yàn)證方案(1) 使用HTTPS協(xié)議;(2) 使用密鑰+令牌。3.2 通信安全(1) URL簽名;(2) AES對(duì)稱加密;3.3 短信服務(wù)(1) 選擇短信平臺(tái);3.4 高效更新數(shù)據(jù)(1) 內(nèi)容的推拉;(2) 增量更新。3.5 圖片處理

5、(1) APP本地緩存圖片;(2) 不同尺寸圖片動(dòng)態(tài)生成。3.6 視頻處理(1) FFmpeg。3.7 資源文件(1) Android APK文件,通過(guò)Android-APKtool獲取文件的基本信息;(2) iOS IPA文件。3.8 文件系統(tǒng)(1) 云存儲(chǔ),CDN;(2) 分布式文件系統(tǒng)。3.9 ELK日志分析平臺(tái)(1) Logstash、ElasticSearch、Kibana。3.10 Docker容器(1) Docker構(gòu)建一致的開(kāi)發(fā)環(huán)境;4 App后臺(tái)運(yùn)維4.1 Linux,App后臺(tái)應(yīng)用最廣泛的系統(tǒng)(1) 常用命令,top、ps、netstat、lsof、traceroute4.

6、2 Nginx,App后臺(tái)HTTP服務(wù)的利器(1) HTTP服務(wù);(2) 負(fù)載均衡。4.3 MySQL,App后臺(tái)最常用的數(shù)據(jù)庫(kù)(1) 存儲(chǔ)引擎,MyISAM、InnoDB;(2) 索引;(3) 分庫(kù)分表,MyCat。4.4 Redis,App后臺(tái)高性能的緩存系統(tǒng)(1) 常用數(shù)據(jù)結(jié)構(gòu);(2) 集群,Twemproxy,Codis;(3) 持久化。4.5 MongoDB,App后臺(tái)新興的數(shù)據(jù)庫(kù)(1) 高可用集群;(2) LBS。5 App后臺(tái)架構(gòu)剖析5.1 聊天App后臺(tái)架構(gòu)(1) 移動(dòng)互聯(lián)網(wǎng)的網(wǎng)絡(luò)特性,弱網(wǎng)絡(luò)性、對(duì)流量敏感;(2) 協(xié)議,XMPP、MQTT、ActivitySync、TCP自定義;(3) 整體架構(gòu),主要包括連接層、業(yè)務(wù)層、數(shù)據(jù)層;(4) 消息推拉模式;(5) 數(shù)據(jù)庫(kù)架構(gòu),單機(jī)部署、讀寫(xiě)分離、分表分庫(kù);(6) 緩存架構(gòu),單臺(tái)緩存、分布式緩存、主從緩存。5.2 LBS App后臺(tái)架構(gòu)(1) 地理坐標(biāo),GPS、基站、AGPS(GPS+基站結(jié)合)、WiFi定位;(2) 基于MongoDB;(3) 推送服務(wù)。6 App后臺(tái)架構(gòu)的演進(jìn)6.1 架構(gòu)的核心要素 軟件架構(gòu)是有關(guān)軟件整體結(jié)構(gòu)與組件的抽象描述,用于指導(dǎo)大型軟件系統(tǒng)各個(gè)方面的設(shè)計(jì)。App后臺(tái)架構(gòu)可以定義為由App后臺(tái)各個(gè)組件的功能描述、相互關(guān)系構(gòu)成的整體系統(tǒng)。App后臺(tái)架構(gòu)的核心要素:(1) 高

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論