精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

也談基于NodeJS的全棧式開發(基于NodeJS的前后端分離)

開發 前端
前言 為了解決傳統Web開發模式帶來的各種問題,我們進行了許多嘗試,但由于前/后端的物理鴻溝,嘗試的方案都大同小異。痛定思痛,今天我們重新思考了“前后端”的定義,引入前端同學都熟悉的NodeJS,試圖探索一條全新的前后端分離模式。

隨著不同終端(Pad/Mobile/PC)的興起,對開發人員的要求越來越高,純瀏覽器端的響應式已經不能滿足用戶體驗的高要求,我們往往需要針對不同的終端開發定制的版本。為了提升開發效率,前后端分離的需求越來越被重視,后端負責業務/數據接口,前端負責展現/交互邏輯,同一份數據接口,我們可以定制開發多個版本。

這個話題最近被討論得比較多,阿里有些BU也在進行一些嘗試。討論了很久之后,我們團隊決定探索一套基于NodeJS的前后端分離方案,過程中有一些不斷變化的認識以及思考,記錄在這里,也希望看到的同學參與討論,幫我們完善。

一、什么是前后端分離?

最開始組內討論的過程中我發現,每個人對前后端分離的理解不一樣,為了保證能在同一個頻道討論,先就什么是”前后端分離”達成一致。

大家一致認同的前后端分離的例子就是SPA(Single-page application),所有用到的展現數據都是后端通過異步接口(AJAX/JSONP)的方式提供的,前端只管展現。
從某種意義上來說,SPA確實做到了前后端分離,但這種方式存在兩個問題:

  • WEB服務中,SPA類占的比例很少。很多場景下還有同步/同步+異步混合的模式,SPA不能作為一種通用的解決方案。
  • 現階段的SPA開發模式,接口通常是按照展現邏輯來提供的,有時候為了提高效率,后端會幫我們處理一些展現邏輯,這就意味著后端還是涉足了View層的工作,不是真正的前后端分離。

SPA式的前后端分離,是從物理層做區分(認為只要是客戶端的就是前端,服務器端的就是后端),這種分法已經無法滿足我們前后端分離的需求,我們認為從職責上劃分才能滿足目前我們的使用場景:

  • 前端:負責View和Controller層。
  • 后端:只負責Model層,業務處理/數據等。

為什么去做這種職責的劃分,后面會繼續探討。

二、為什么要前后端分離?

關于這個問題,玉伯的文章Web研發模式演變中解釋得非常全面,我們再大概理一下:

2.1 現有開發模式的適用場景

玉伯提到的幾種開發模式,各有各的適用場景,沒有哪一種完全取代另外一種。

  • 比如后端為主的MVC,做一些同步展現的業務效率很高,但是遇到同步異步結合的頁面,與后端開發溝通起來就會比較麻煩。
  • Ajax為主SPA型開發模式,比較適合開發APP類型的場景,但是只適合做APP,因為SEO等問題不好解決,對于很多類型的系統,這種開發方式也過重。

2.2 前后端職責不清

在業務邏輯復雜的系統里,我們最怕維護前后端混雜在一起的代碼,因為沒有約束,M-V-C每一層都可能出現別的層的代碼,日積月累,完全沒有維護性可言。
雖然前后端分離沒辦法完全解決這種問題,但是可以大大緩解。因為從物理層次上保證了你不可能這么做。

2.3 開發效率問題

淘寶的Web基本上都是基于MVC框架webx,架構決定了前端只能依賴后端。
所以我們的開發模式依然是,前端寫好靜態demo,后端翻譯成VM模版,這種模式的問題就不說了,被吐槽了很久。
直接基于后端環境開發也很痛苦,配置安裝使用都很麻煩。為了解決這個問題,我們發明了各種工具,比如VMarket,但是前端還是要寫VM,而且依賴后端數據,效率依然不高。
另外,后端也沒法擺脫對展現的強關注,從而專心于業務邏輯層的開發。

2.4 對前端發揮的局限

性能優化如果只在前端做空間非常有限,于是我們經常需要后端合作才能碰撞出火花,但由于后端框架限制,我們很難使用Comet、Bigpipe等技術方案來優化性能。

為了解決以上提到的一些問題,我們進行了很多嘗試,開發了各種工具,但始終沒有太多起色,主要是因為我們只能在后端給我們劃分的那一小塊空間去發揮。只有真正做到前后端分離,我們才能徹底解決以上問題。

三、怎么做前后端分離?

怎么做前后端分離,其實***節中已經有了答案:

  • 前端:負責View和Controller層。
  • 后端:負責Model層,業務處理/數據等。

MVC分

試想一下,如果前端掌握了Controller,我們可以做url design,我們可以根據場景決定在服務端同步渲染,還是根據view層數據輸出json數據,我們還可以根據表現層需求很容易的做Bigpipe,Comet,Socket等等,完全是需求決定使用方式。

3.1 基于NodeJS“全棧”式開發

如果想實現上圖的分層,就必然需要一種web服務幫我們實現以前后端做的事情,于是就有了標題提到的“基于NodeJS的全棧式開發”

Node 帶來的全棧時代

這張圖看起來簡單而且很好理解,但沒嘗試過,會有很多疑問。

  • SPA模式中,后端已供了所需的數據接口,view前端已經可以控制,為什么要多加NodeJS這一層?
  • 多加一層,性能怎么樣?
  • 多加一層,前端的工作量是不是增加了?
  • 多加一層就多一層風險,怎么破?
  • NodeJS什么都能做,為什么還要JAVA?

這些問題要說清楚不容易,下面說下我的認識過程。

3.2 為什么要增加一層NodeJS?

現階段我們主要以后端MVC的模式進行開發,這種模式嚴重阻礙了前端開發效率,也讓后端不能專注于業務開發。
解決方案是讓前端能控制Controller層,但是如果在現有技術體系下很難做到,因為不可能讓所有前端都學java,安裝后端的開發環境,寫VM。
NodeJS就能很好的解決這個問題,我們無需學習一門新的語言,就能做到以前開發幫我們做的事情,一切都顯得那么自然。

3.3 性能問題

分層就涉及每層之間的通訊,肯定會有一定的性能損耗。但是合理的分層能讓職責清晰、也方便協作,會大大提高開發效率。分層帶來的損失,一定能在其他方面的收益彌補回來。
另外,一旦決定分層,我們可以通過優化通訊方式、通訊協議,盡可能把損耗降到***。

舉個例子:
淘寶寶貝詳情頁靜態化之后,還是有不少需要實時獲取的信息,比如物流、促銷等等,因為這些信息在不同業務系統中,所以需要前端發送5,6個異步請求來回填這些內容。
有了NodeJS之后,前端可以在NodeJS中去代理這5個異步請求,還能很容易的做Bigpipe,這塊的優化能讓整個渲染效率提升很多。
可能在PC上你覺得發5,6個異步請求也沒什么,但是在無線端,在客戶手機上建立一個HTTP請求開銷很大,有了這個優化,性能一下提升好幾倍。

淘寶詳情基于NodeJS的優化我們正在進行中,上線之后我會分享一下優化的過程。

3.4 前端的工作量是否增加了?

相對于只切頁面/做demo,肯定是增加了一點,但是當前模式下有聯調、溝通環節,這個過程非?;〞r間,也容易出bug,還很難維護。
所以,雖然工作量會增加一點,但是總體開發效率會提升很多。

另外,測試成本可以節省很多。以前開發的接口都是針對表現層的,很難寫測試用例。如果做了前后端分離,甚至測試都可以分開,一撥人專門測試接口,一撥人專注測試UI(這部分工作甚至可以用工具代替)。

3.5 增加Node層帶來的風險怎么控制?

隨著Node大規模使用,系統/運維/安全部門的同學也一定會加入到基礎建設中,他們會幫助我們去完善各個環節可能出現的問題,保障系的穩定性。

3.6 Node什么都能做,為什么還要JAVA?

我們的初衷是做前后端分離,如果考慮這個問題就有點違背我們的初衷了。即使用Node替代Java,我們也沒辦法保證不出現今天遇到的種種問題,比如職責不清。我們的目的是分層開發,專業的人,專注做專業的事?;贘AVA的基礎架構已經非常強大而且穩定,而且更適合做現在架構的事情。

四、淘寶基于Node的前后端分離

淘寶基于NodeJS的前后端分離

上圖是我理解的淘寶基于Node的前后端分離分層,以及Node的職責范圍。簡單解釋下:

  • 最上端是服務端,就是我們常說的后端。后端對于我們來說,就是一個接口的集合,服務端提供各種各樣的接口供我們使用。因為有Node層,也不用局限是什么形式的服務。對于后端開發來說,他們只用關心業務代碼的接口實現。
  • 服務端下面是Node應用。
  • Node應用中有一層Model Proxy與服務端進行通訊。這一層主要目前是抹平我們對不同接口的調用方式,封裝一些view層需要的Model。
  • Node層還能輕松實現原來vmcommon,tms(引用淘寶內容管理系統)等需求。
  • Node層要使用什么框架由開發者自己決定。不過推薦使用express+xTemplate的組合,xTemplate能做到前后端公用。
  • 怎么用Node大家自己決定,但是令人興奮的是,我們終于可以使用Node輕松實現我們想要的輸出方式:JSON/JSONP/RESTful/HTML/BigPipe/Comet/Socket/同步、異步,想怎么整就怎么整,完全根據你的場景決定。
  • 瀏覽器層在我們這個架構中沒有變化,也不希望因為引入Node改變你以前在瀏覽器中開發的認知。
  • 引入Node,只是把本該就前端控制的部分交由前端掌控。

這種模式我們已經有兩個項目在開發中,雖然還沒上線,但是無論是在開發效率,還是在性能優化方面,我們都已經嘗到了甜頭。

五、我們還需要要做什么?

  • 把Node的開發流程集成到淘寶現有的SCM流程中。
  • 基礎設施建設,比如session,logger等通用模塊。
  • ***開發實踐
  • 線上成功案例
  • 大家對Node前后端分離概念的認識
  • 安全
  • 性能

技術上不會有太多需要去創新和研究的,已經有非常多現成的積累。其實關鍵是一些流程的打通和通用解決方案的積累,相信隨著更多的項目實踐,這塊慢慢會變成一個穩定的流程。

六、“中途島”

雖然“基于NodeJS的全棧式開發”模式很讓人興奮,但是把基于Node的全棧開發變成一個穩定,讓大家都能接受的東西還有很多路要走,我們正在進行的“中途島”項目就是為了解決這個問題。雖然我們起步不久,但是離目標已經越來越近!!

原文鏈接:http://ued.taobao.org/blog/2014/04/full-stack-development-with-nodejs/

責任編輯:林師授 來源: Taobao UED
相關推薦

2014-04-18 14:43:07

前后端分離NodeJS

2014-07-29 10:35:21

DockerNodeJS

2016-10-31 14:16:33

node前后端分離koa

2019-06-12 19:00:14

前后端分離AppJava

2023-02-08 16:29:58

前后端開發

2016-11-09 10:28:36

Nodejs文件上傳express+mul

2014-02-20 13:46:30

C++JavaScript

2024-10-06 13:47:43

后端開發者項目

2022-04-07 08:06:32

viteVue3項目

2019-07-09 05:44:35

前后端分離架構接口規范

2014-08-15 10:05:37

Angular權限控制

2022-04-06 07:50:57

JWT后端Spring

2015-04-21 11:18:20

Web系統開發構架前后端

2016-10-28 22:22:35

nodenode.jsdocker

2021-09-18 09:45:33

前端接口架構

2022-05-27 10:40:04

前后端權限控制設計

2019-10-31 11:06:57

Spring ClouVue.js前端

2019-12-16 09:21:14

HTTPAPI認證

2020-01-14 08:58:38

Serverless框架web

2021-05-04 23:40:44

Nodejs后端開發
點贊
收藏

51CTO技術棧公眾號

91在线中文字幕| 日韩在线观看免费全| 日韩欧美亚洲天堂| 神马电影在线观看| 天堂蜜桃91精品| 久久精品成人一区二区三区| 国产白袜脚足j棉袜在线观看| 成人免费直播| 亚洲男同性恋视频| 久久国产手机看片| 一级片在线观看视频| 伊人久久成人| 日日骚av一区| a视频免费观看| 国产精品一区二区美女视频免费看 | 自拍偷拍国产精品| 国产一区不卡在线观看| 伊人网中文字幕| 影音先锋久久资源网| 中文字幕av一区中文字幕天堂 | 草草久久久无码国产专区| 三区四区电影在线观看| 99综合电影在线视频| 国产伊人精品在线| 五月天激情四射| 好吊视频一区二区三区四区| www.日本久久久久com.| 中文字幕一区二区三区人妻不卡| 清纯唯美激情亚洲| 欧美视频一区二区三区在线观看 | 精品久久99ma| 久久6免费视频| 小黄鸭精品aⅴ导航网站入口| 一区二区三区高清在线| 一区二区三区精品国产| 蜜桃成人在线视频| 99精品国产热久久91蜜凸| 91香蕉嫩草影院入口| 在线观看视频中文字幕| 日本不卡中文字幕| 国产成人aa精品一区在线播放 | 九七电影韩国女主播在线观看| 久久婷婷综合激情| 麻豆成人小视频| 天堂网在线观看视频| 国产成人亚洲综合a∨猫咪| 国产狼人综合免费视频| 中文字幕第一页在线播放| 玖玖玖国产精品| 欧美亚洲在线播放| 五月天激情国产综合婷婷婷| 99成人在线| 97成人精品视频在线观看| 日韩精品视频免费看| 亚洲美洲欧洲综合国产一区| 久久久亚洲精品视频| 国产在线观看成人| 在线成人亚洲| 久久久亚洲网站| 亚洲日本韩国在线| 久久午夜精品一区二区| 欧美中文在线免费| 草莓视频18免费观看| 久久久夜精品| 国产伦精品免费视频| 一级黄色片免费看| 国产乱子伦一区二区三区国色天香 | 国产午夜视频在线播放| 国产精品日本| 国产精品第8页| 中文字幕一区二区三区波野结 | 91福利视频导航| av中文字幕观看| 99视频有精品| 日韩黄色影视| 麻豆视频网站在线观看| 亚洲精品日韩综合观看成人91| 无码人妻精品一区二区蜜桃百度| 久草在线视频资源| 好吊成人免视频| 污片在线免费看| 日韩欧美中文字幕一区二区三区| 精品成人在线观看| 国产色视频一区二区三区qq号| 欧美亚洲国产激情| 欧美另类交人妖| 成人免费看片98欧美| 免费黄网站欧美| 99久久免费国| 国产在线网站| 亚洲伦理在线精品| 国产精品免费入口| 久久av影院| 精品sm捆绑视频| 国产精品国产三级国产专业不 | 久久久久国产精品麻豆ai换脸 | 亚洲激情偷拍| 国产精品美女网站| 黄片毛片在线看| 中文无字幕一区二区三区| av片在线免费| 日本成人片在线| 精品国产91洋老外米糕| 三级黄色录像视频| 在线午夜精品| 97netav| 成人一区二区不卡免费| 亚洲图片欧美视频| 国产原创精品在线| 羞羞答答一区二区| 美女久久久久久久久久久| 五月天激情国产综合婷婷婷| 国产精品99久久久久久久vr| 日本一区二区精品视频| 77thz桃花论族在线观看| 欧美久久高跟鞋激| 90岁老太婆乱淫| 亚洲精品乱码久久久久久蜜桃麻豆| 国产精品一区电影| 黄色片在线免费观看| 亚洲第一福利视频在线| 久久久久久久高清| 红桃成人av在线播放| 97视频com| 亚洲AV午夜精品| 综合久久综合久久| 免费一级特黄录像| 你懂的一区二区三区| 久久久久久久久久久免费| 国产欧美日韩综合精品一区二区三区| 久久久精品日韩欧美| 浮妇高潮喷白浆视频| 日韩av综合| 久久偷看各类女兵18女厕嘘嘘| 少妇一级淫片日本| 久久久综合激的五月天| jizzjizz国产精品喷水| 国产精东传媒成人av电影| 久99九色视频在线观看| 国产女人爽到高潮a毛片| 亚洲视频一区二区免费在线观看| 黑森林精品导航| 欧美精选一区二区三区| 国产mv免费观看入口亚洲| 日韩精品系列| 日韩欧美亚洲成人| 精品久久久久久中文字幕人妻最新| 亚洲欧洲综合| 国产一区不卡在线观看| 瑟瑟视频在线看| 亚洲免费小视频| 精品国产午夜福利| 欧美激情资源网| 中文字幕国产传媒| 四虎国产精品免费观看| 国产视频999| 福利视频在线| 日韩欧美视频一区| 久久免费播放视频| 成人午夜av电影| 奇米精品一区二区三区| 欧美人与拘性视交免费看| 国产精品r级在线| av网站在线免费观看| 欧美日韩中文精品| 日韩成人短视频| 成人sese在线| 国产福利视频在线播放| 精品一区电影| 成人免费淫片视频软件| 美女精品导航| 精品偷拍各种wc美女嘘嘘| 国产成人a v| 国产精品久久久久久妇女6080| 中文国产在线观看| 韩日精品视频| 日本免费一区二区三区| 欧美日韩免费电影| 欧美精品www在线观看| 青青操在线视频| 精品视频一区三区九区| 91成人福利视频| 91在线精品一区二区| 男女男精品视频站| 欧美人成在线| 欧美日韩精品免费看| 国产一区二区视频在线看| 91国产精品91| 老司机在线永久免费观看| 精品国产一区二区三区不卡 | 欧美草逼视频| 亚洲精品永久免费精品| 国产一区二区三区视频免费观看 | 日韩中文在线视频| 欧美一级性视频| 欧美日韩一卡二卡三卡| 欧美亚洲天堂网| 国产精品成人在线观看| 精品影片一区二区入口| 日本一区中文字幕| 日本福利视频一区| 久久综合99| 久久久久久一区| 蜜桃精品视频| 国产精品国产三级国产aⅴ9色 | 手机亚洲手机国产手机日韩| 国产成人精品免费视频大全最热 | 18视频在线观看| 亚洲人成电影在线| 男人的天堂a在线| 欧美精品xxxxbbbb| 日韩国产亚洲欧美| 精品久久久久久久久中文字幕 | 色婷婷综合五月| 九九九国产视频| 亚洲日本在线a| 国产精品美女高潮无套| 99视频有精品| 91精品人妻一区二区三区四区| 美女任你摸久久| aaaaaa亚洲| 亚洲精品乱码| 亚洲精品久久久久久久蜜桃臀| 91精品推荐| 亚洲成人精品电影在线观看| 日韩av三区| 国产精品欧美久久| 一区二区三区国产好| 91久久在线观看| 国产精品久久久久久久久久齐齐| 欧美在线视频在线播放完整版免费观看| www.久久ai| 久久激情视频久久| 日韩大片在线永久免费观看网站| 国产一区二区黄| 欧美日韩影视| 亚洲欧美日韩另类| 青春草在线观看| 亚洲欧美中文日韩在线| 亚洲最新在线视频| 一级片视频网站| 欧洲精品一区二区| 久久久久久久亚洲| 色8久久精品久久久久久蜜| 欧美日韩一二三四区| 五月天亚洲精品| 国产成人在线免费观看视频| 亚洲h在线观看| 日韩精品无码一区二区| 天天影视涩香欲综合网| 波多野结衣国产| 色综合色狠狠综合色| 国产精品视频一区在线观看| 日韩欧美成人免费视频| 69视频免费在线观看| 日韩欧美国产一区二区| 欧美日韩一级黄色片| 在线观看国产精品网站| 在线黄色av网站| 欧美一区二区黄色| 粉嫩av一区二区夜夜嗨| 亚洲国产日韩欧美在线99| 天堂中文资源在线观看| 亚洲人精品午夜在线观看| 福利片在线观看| 色99之美女主播在线视频| 国产黄大片在线观看画质优化| 久久久极品av| 俺来也官网欧美久久精品| 97视频免费在线看| 久久uomeier| 国产精品老女人精品视频| 激情不卡一区二区三区视频在线| 999国内精品视频在线| 亚洲精品午夜| 久久香蕉综合色| 波多野结衣在线观看一区二区| 亚洲一区二区高清视频| 永久91嫩草亚洲精品人人| 美脚丝袜脚交一区二区| 久久久国产精品一区二区中文| 国产又黄又猛又粗又爽的视频| 国产一区二区调教| 一级黄色片毛片| 欧美激情一区三区| avove在线播放| 欧美性猛交xxxx乱大交| 99精品视频免费看| 精品亚洲一区二区三区四区五区| yjizz视频网站在线播放| 久久成人av网站| 欧美日韩国产v| 92看片淫黄大片欧美看国产片 | 日韩电影免费在线观看网站| 亚洲热在线视频| 久久嫩草精品久久久久| 亚洲 欧美 变态 另类 综合| 天天做天天摸天天爽国产一区| 中文资源在线播放| 亚洲国产精品99久久| 一级毛片视频在线| 68精品久久久久久欧美| 91国产一区| 日本一区免费在线观看| 国产精品v日韩精品v欧美精品网站| www.日日操| 成人av网站免费观看| 老熟妇高潮一区二区三区| 色欧美日韩亚洲| 亚洲精品字幕在线观看| 最近2019免费中文字幕视频三 | 欧美视频在线观看免费| 国产熟女一区二区三区五月婷| 亚洲欧美国产另类| 波多野在线观看| 91在线免费观看网站| 波多野结衣的一区二区三区| 精品一区二区中文字幕| 国产成人免费视频网站| 国产精品国产三级国产传播| 色婷婷精品久久二区二区蜜臂av| 亚洲国产精品久久人人爱潘金莲| 久久精品2019中文字幕| 97人人做人人爽香蕉精品| 看高清中日韩色视频| 亚洲第一黄色| 免费黄视频在线观看| 亚洲欧洲精品一区二区三区| 日韩不卡高清视频| 亚洲香蕉av在线一区二区三区| 欧美freesex黑人又粗又大| 高清av免费一区中文字幕| 国产精品黑丝在线播放| 国产野外作爱视频播放| 国产午夜精品在线观看| 五月婷婷色丁香| 亚洲精品福利在线观看| 超碰97免费在线| 国产精品久久久久免费| 黄色成人91| 国产清纯白嫩初高中在线观看性色| 亚洲免费视频中文字幕| 国产精品永久久久久久久久久| 日韩视频在线观看免费| 青草综合视频| 一区二区精品在线观看| 久久97超碰色| 91麻豆免费视频网站| 欧美一级精品在线| 色yeye免费人成网站在线观看| 超碰97网站| 精品成人免费| 97香蕉碰碰人妻国产欧美| 午夜精品成人在线视频| 日本a一级在线免费播放| 青青草原成人在线视频| 国产成人一区二区三区影院| 国产视频一区二区三区在线播放| 欧美激情一区二区在线| 一区二区三区黄色片| 插插插亚洲综合网| 99久久婷婷国产综合精品青牛牛| 国产精品无码免费专区午夜| 不卡的av网站| 无码人妻aⅴ一区二区三区有奶水| 亚洲视频在线看| 欧洲午夜精品| 大地资源网在线观看免费官网| 国产成人免费视频| 一区二区三区福利视频| 一本一道久久a久久精品逆3p| 日韩专区视频网站| 日本一级黄视频| 91在线你懂得| 伊人成人在线观看| 欧美大胆a视频| 日韩av中文字幕一区| 欧美亚洲日本在线观看| 综合激情成人伊人| 五月天丁香视频| 国产精品十八以下禁看| 午夜久久黄色| 无码人妻精品一区二区三应用大全| 欧美羞羞免费网站| 成人免费观看视频大全| 国产综合色一区二区三区| 美女视频黄频大全不卡视频在线播放 | 久久久精品国产**网站| 天天干天天干天天干天天干天天干| 亚洲视频一区二区在线观看| 天堂中文在线官网| 成人午夜两性视频| 中文精品在线| √天堂中文官网8在线| 亚洲精品资源在线| 国产激情精品一区二区三区| av网站在线观看不卡| 亚洲欧美乱综合| 国产在线视频你懂得| 国产精品theporn88|