其實早就該寫這篇博客了,一直說忙于工作沒有時間,其實時間擠擠總會有的,可能就是因為懶吧!從2013年11月一直拖到現在,其實我是不怎么擅長寫技術博客的,因為語言表達能力和文采不是很好,每次寫博客都不知道自己在寫啥,作為一開始就參與 Worktile 開發的技術人員,今天就簡單談談 Worktile 的技術架構吧 。
Worktile 自上線到現在收到了很多用戶的喜歡,我們倍感欣慰,自己做的產品得到了用戶的認可是件幸福的事情,其中有很多來自IT的用戶,經常在官方群或者知乎上問一些關于Worktile的技術問題:
Worktile 采用的是怎么樣的架構?
Worktile 前后端采用了哪些技術?
...
Worktile 是企業協同辦公軟件,所以一開始注定就應該是單頁應用(SPA),因為使用SPA后,用戶在瀏覽器端可以像操作原生客戶端程序一樣的體驗(速度和流暢度),對于開發者來說,前后端分離,服務端只提供RESTful API服務,移動端集成也非常的方便,具體可以看下面這張草圖。
Angular.js(客戶端MV*)
Bootstrap (CSS基礎庫和一些Javascript組件)
UI Bootstrap (Bootstrap 的 Angular.js版本)
jQuery (取代Angular.js中的jqLite,并作為其他第三方jQuery插件的基礎類庫)
Worktile的服務端基本上只是提供API數據服務的,不會渲染HTML,前端的代碼在發布之前會使用 Grunt 工具打包合并壓縮成一個js文件。
既然是SPA程序,前端必然要選擇一個MVC(或者MVVM)框架,關于前端MVC框架有很多,當時面臨選擇的時候也是比較猶豫,因為在此之前我們只初略的使用過 Knockoutjs 。
其實我們當時就是急切的希望一個框架能做到:
數據能夠雙向綁定(或者只單向綁定)
前端路由功能
簡單易學的模板語言
最終我們選擇了 Angular.js,具體其中選擇的細節就不一一描述了(之前在知乎上也回答過關于Angular.js 的問題:Angular.js 在實際應用中有哪些優缺點?),從開始使用到現在已經快2年了,事實證明當初的選擇還是沒有錯的, Angular.js的確很適合 Worktile。
選擇Bootstrap主要是為了使用它的基礎CSS功能,在它的基礎之上很容寫出規范的樣式代碼,當然我們也需要使用其中的部分Javascrip組件功能,因為原生的 Bootstrap是基于 jQuery的,為了在Angular.js中也能很好的使用它,我們引入了 UI Bootstrap、關于jQuery大家再熟悉不過了,我們使用的很多第三方插件是jQuery的,所以也一并引入了。
上面只是列出了 Worktile 主要使用的幾個Javascript框架和類庫,真正使用的類庫遠不止上面列出的這些。比如日歷庫 ui-calendar、underscorejs 等等...
Node.js
Redis
MongoDB
服務端是構建在Node.js之上的,我們的服務端MVC框架采用的是 Expressjs,剛開始是 Express 3.x版本,現在已經升級到 4.x,Expressjs提供了 Route和模板引擎的功能,由于我們的服務端基本只提供數據服務,所以關于服務端模板引擎這塊基本不使用(只有布局和一些配置項輸出到界面時需要用到)。
選擇 Node.js 是因為它簡單,適合高并發的Web服務,而且我們的開發人員能夠熟練使用它,關于Node.js的優缺點我在知乎上也曾經回答過:使用 Node.js 的優勢和劣勢都有哪些?。
Worktile 用戶的登錄狀態,一些臨時使用的數據、部分業務數據緩存 都是放在 Redis 里面的,關于Node.js怎么和 Redis 連接采用 Node Redis 模塊。
Worktile 并不是那種高度事物性的系統或者傳統的商業智能應用,所以MongoDB非常適合,性能非常高,集群方便,而且以BSON結構存儲,和Node.js完美集成。
Worktile 的數據層和MongoDB之間并不是使用 原生的驅動 ,而采用了 mongoosejs,類似Java或者C#上的ORM框架,使用 mongoose 可以很方面的定義數據 Schema,讀取操作 MongoDB。
前面也說了 Worktile 是 SPA程序,用戶登錄到系統之后,基本上所有的操作都不需要刷新瀏覽器,因為是一個協同辦公軟件,其他用戶多數據進行操作需要實時更新,所以客戶端必然要和服務端保持一種長連接,方面進行數據交互,我們的實時推送服務是采用 Erlang 語言編寫的,感興趣的可以查看:https://worktile.com/tech/basic/worktile-real-time-notice
采用 Erlang 是因為我們的開發人員有這方面的經驗,并且Erlang非常適合做這個高并發實時推送服務。
如果你熟悉 Node.js 肯定知道 Sockiet.IO,我們最初的實時推送其實是采用 Sockiet.IO的,后來由于訪問量的增張,原有的Sockiet.IO 是基于Worktile Web站點的,沒有獨立成單獨的服務,重構的時候徹底采用Erlang重寫了。
其實這2種技術都非常優秀,選擇哪種主要取決于你擅長什么。
使用過 Worktile 的人肯定都知道,在系統中上傳一些文件,比如:word、excel、txt、pdf、ppt等等,都是可以在線預覽的,關于 txt、pdf這些文件的預覽其實好辦,txt直接讀取文件內容即可,pdf采用瀏覽器自帶的預覽或者使用一些Js類庫都很方便的做到,但是對于 Ofiice 文件,是不可以直接讀取的,所以我們自己搭建了一套 Ofiice的預覽服務,這個服務主要是基于微軟的 Office Web App服務
Worktile 中所有的文件存儲在阿里云的OSS上,為了做一些權限的認證和安全問題,我們通過一個Box服務做中轉,所有文件的上傳下載都是走 Box 服務。這要感謝 5樓的Box之父 @Shaun Xu 寫出了這么好的Box 服務。
以上是Worktile用的所有技術和架構簡單介紹。
Worktile 自上線以來用戶的增長也是非常迅速的,所以 Web服務器從原先的1臺變成多臺,數據庫從單實例到現在的集群,等等,關于目前Worktile的服務器結構圖參考如下:
另外有需要云服務器可以了解下創新互聯cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網頁名稱:Worktile技術架構概要-創新互聯
文章路徑:http://vcdvsql.cn/article32/ddjdsc.html
成都網站建設公司_創新互聯,為您提供網站建設、網站維護、外貿網站建設、網站制作、外貿建站、關鍵詞優化
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯