1.1. 誰(shuí)在用Nodejs?
從Nodejs官方網(wǎng)站的企業(yè)登記頁(yè)(https://github.com/joyent/node/wiki/Projects,-Applications,-and-Companies-Using-Node),包括我們熟知的公司有LinkedIn, Yahoo, Paypal, eBay, Walmart,Groupon 還有很多的中小型公司腻扇,國(guó)內(nèi)的公司如雪球屑墨、淘寶夹纫、網(wǎng)易祟滴、百度等也都有很多項(xiàng)目運(yùn)行在Node.js之上。
這些公司不僅是嘗試在用绿饵,而且都在向Nodejs遷移欠肾。截止到2014年6月本文發(fā)稿時(shí),已經(jīng)有79693包在npm.org上面發(fā)布拟赊,而且這個(gè)數(shù)字還在快速增長(zhǎng)中刺桃。
那么接下來(lái),大家肯定都會(huì)問(wèn)為什么要是用Nodejs呢吸祟?
1.2. 為什么要用Nodejs?
從我使用體會(huì)來(lái)說(shuō)瑟慈,Node有4大優(yōu)勢(shì):
1.Nodejs基于Javascript語(yǔ)言,不用再單獨(dú)新學(xué)一門陌生的語(yǔ)言屋匕,從而減低了學(xué)習(xí)的門檻葛碧。同時(shí),Javascript語(yǔ)言在Web前端開(kāi)發(fā)中至關(guān)重要过吻,特別HTML5的應(yīng)用必須要使用进泼,所以前后臺(tái)統(tǒng)一語(yǔ)言,不僅可以實(shí)現(xiàn)程序員的全棧開(kāi)發(fā)纤虽,還可以統(tǒng)一公共類庫(kù)乳绕,代碼標(biāo)準(zhǔn)化。單憑這一點(diǎn)逼纸,Nodejs就已經(jīng)贏得市場(chǎng)的青睞了洋措。
2.Nodejs并沒(méi)有重新開(kāi)發(fā)運(yùn)行時(shí)環(huán)境,而是選擇了目前最快的瀏覽器內(nèi)核V8做為執(zhí)行引擎杰刽,保證了Nodejs的性能和穩(wěn)定性菠发。
3.Nodejs的開(kāi)發(fā)非常高效,而且代碼簡(jiǎn)單贺嫂,得益于Nodejs的單線程機(jī)制滓鸠。而Nodejs的另一個(gè)特點(diǎn)異步編程,讓Nodejs處理IO密集型應(yīng)用有了明顯的優(yōu)勢(shì)涝婉。個(gè)人感覺(jué)哥力,用Nodejs比Java做Web開(kāi)發(fā)要高效10倍,比PHP的代碼還要簡(jiǎn)單墩弯。
4.Nodejs的社區(qū)在壯大吩跋,不僅包的數(shù)量在快速增加,而且包的質(zhì)量也要明顯好于其他語(yǔ)言的渔工。很多明星級(jí)的包锌钮,都是簡(jiǎn)單而靈巧的,為了開(kāi)發(fā)者的使用習(xí)慣而設(shè)計(jì)引矩。我最常用到的工具包梁丘,如socket.io, moment.js, underscore.js, async.js, express.js, bower.js, grunt.js, forever.js…,確實(shí)在改變我以前的編程習(xí)慣旺韭。
當(dāng)然氛谜,除了我使用Nodejs的理由,很多公司也都有自己的使用理由区端。
ebay選擇Nodejs的理由值漫,可以歸納為以下4點(diǎn):
動(dòng)態(tài)語(yǔ)言:開(kāi)發(fā)效率非常高,并有能力構(gòu)建復(fù)雜系統(tǒng)织盼,如ql.io杨何。
性能和I/O負(fù)載:Nodejs非常好的解決了IO密集的問(wèn)題,通過(guò)異步IO來(lái)實(shí)現(xiàn)沥邻。
連接的內(nèi)存開(kāi)銷:每個(gè)Node.js進(jìn)程可以支持超過(guò)12萬(wàn)活躍的連接危虱,每個(gè)連接消耗大約2K的內(nèi)存。
操作性:實(shí)現(xiàn)了Nodejs對(duì)于內(nèi)存堆棧的監(jiān)控系統(tǒng)唐全。
1.3. Nodejs不適合的領(lǐng)域
每一種語(yǔ)言或平臺(tái)都有不擅長(zhǎng)領(lǐng)域埃跷,對(duì)于Nodejs來(lái)說(shuō)最不擅長(zhǎng)的領(lǐng)域在于CPU和內(nèi)存的編程操作。
1. 計(jì)算密集型應(yīng)用邮利,讓Javascript和C去拼計(jì)算性能弥雹,估計(jì)是不可能贏的。
2. 內(nèi)存控制近弟,讓Javascript和Java比較復(fù)雜數(shù)據(jù)類型定義缅糟,也是很困難的。因?yàn)镴avascript的面向?qū)ο笫腔贘SON的祷愉,而Java是直接使用內(nèi)存結(jié)構(gòu)窗宦。所以,通過(guò)JSON序列化和反序列的過(guò)程控制內(nèi)存二鳄,Javascript就已經(jīng)輸了赴涵。
3. 大內(nèi)存的應(yīng)用,由于V8引擎有內(nèi)存設(shè)計(jì)的限制订讼,32位環(huán)境中最大堆是1G髓窜,64位環(huán)境中最大堆也不到2G,如果要一次讀入10G數(shù)據(jù),對(duì)于Nodejs來(lái)說(shuō)也無(wú)法實(shí)現(xiàn)寄纵。
4. 靜態(tài)服務(wù)器鳖敷,雖然Nodejs的優(yōu)勢(shì)在IO密集集應(yīng)用,但是和Nginx的處理靜態(tài)資源還是有很大的差距程拭。
5. 不需要異步的應(yīng)用:比如系統(tǒng)管理定踱,自行化腳本等,還是Python更順手恃鞋,Nodejs的異步調(diào)用可能會(huì)給編程帶來(lái)一些麻煩崖媚。
2. 15個(gè)Nodejs應(yīng)用場(chǎng)景
我們已經(jīng)對(duì)Nodejs有了初步的了解,接下來(lái)看看Nodejs的應(yīng)用場(chǎng)景恤浪。
2.1 Web開(kāi)發(fā):Express + EJS + Mongoose/MySQL
express 是輕量靈活的Nodejs Web應(yīng)用框架畅哑,它可以快速地搭建網(wǎng)站。Express框架建立在Nodejs內(nèi)置的Http模塊上水由,并對(duì)Http模塊再包裝荠呐,從而實(shí)際Web請(qǐng)求處理的功能。
ejs是一個(gè)嵌入的Javascript模板引擎绷杜,通過(guò)編譯生成HTML的代碼直秆。
mongoose 是MongoDB的對(duì)象模型工具,通過(guò)Mongoose框架鞭盟,可以進(jìn)行訪問(wèn)mongodb的操作圾结。
mysql是連接MySQL數(shù)據(jù)庫(kù)的通信API,可以進(jìn)行訪問(wèn)MySQL的操作齿诉。
通常用Nodejs做Web開(kāi)發(fā)筝野,需要3個(gè)框架配合使用,就像Java中的SSH粤剧。
2.2 REST開(kāi)發(fā):Restify
restify 是一個(gè)基于Nodejs的REST應(yīng)用框架歇竟,支持服務(wù)器端和客戶端。restify比起express更專注于REST服務(wù)抵恋,去掉了express中的template, render等功能焕议,同時(shí)強(qiáng)化了REST協(xié)議使用,版本化支持弧关,HTTP的異常處理盅安。
2.3 Web聊天室(IM):Express + Socket.io
socket.io一個(gè)是基于Nodejs架構(gòu)體系的,支持websocket的協(xié)議用于時(shí)時(shí)通信的一個(gè)軟件包世囊。socket.io 給跨瀏覽器構(gòu)建實(shí)時(shí)應(yīng)用提供了完整的封裝别瞭,socket.io完全由javascript實(shí)現(xiàn)。
2.4 Web爬蟲(chóng):Cheerio/Request
cheerio 是一個(gè)為服務(wù)器特別定制的株憾,快速蝙寨、靈活晒衩、封裝jQuery核心功能工具包。Cheerio包括了jquery核心的子集墙歪,從jQuery庫(kù)中去除了所有DOM不一致性和瀏覽器不兼容的部分听系,揭示了它真正優(yōu)雅的API。Cheerio工作在一個(gè)非常簡(jiǎn)單箱亿,一致的DOM模型之上跛锌,解析弃秆、操作届惋、渲染都變得難以置信的高效〔ぷ基礎(chǔ)的端到端的基準(zhǔn)測(cè)試顯示Cheerio大約比JSDOM快八倍(8x)脑豹。Cheerio封裝了@FB55兼容的htmlparser,幾乎能夠解析任何的 HTML 和 XML document衡查。
2.5 Web博客:Hexo
Hexo 是一個(gè)簡(jiǎn)單地瘩欺、輕量地、基于Node的一個(gè)靜態(tài)博客框架拌牲。通過(guò)Hexo我們可以快速創(chuàng)建自己的博客俱饿,僅需要幾條命令就可以完成。
發(fā)布時(shí)塌忽,Hexo可以部署在自己的Node服務(wù)器上面拍埠,也可以部署github上面。對(duì)于個(gè)人用戶來(lái)說(shuō)土居,部署在github上好處頗多枣购,不僅可以省去服務(wù)器的成本,還可以減少各種系統(tǒng)運(yùn)維的麻煩事(系統(tǒng)管理擦耀、備份棉圈、網(wǎng)絡(luò))。所以眷蜓,基于github的個(gè)人站點(diǎn)分瘾,正在開(kāi)始流行起來(lái)….
2.6 Web論壇: nodeclub
Node Club 是用 Node.js 和 MongoDB 開(kāi)發(fā)的新型社區(qū)軟件,界面優(yōu)雅吁系,功能豐富德召,小巧迅速, 已在Node.js 中文技術(shù)社區(qū) CNode 得到應(yīng)用垮抗,但你完全可以用它搭建自己的社區(qū)氏捞。
2.7 Web幻燈片:Cleaver
Cleaver 可以生成基于Markdown的演示文稿。如果你已經(jīng)有了一個(gè)Markdown的文檔冒版,30秒就可以制作成幻燈片液茎。Cleaver是為Hacker準(zhǔn)備的工具。
2.8 前端包管理平臺(tái): bower.js
Bower 是 twitter 推出的一款包管理工具,基于nodejs的模塊化思想捆等,把功能分散到各個(gè)模塊中滞造,讓模塊和模塊之間存在聯(lián)系,通過(guò) Bower 來(lái)管理模塊間的這種聯(lián)系栋烤。
2.9 OAuth認(rèn)證:Passport
Passport項(xiàng)目是一個(gè)基于Nodejs的認(rèn)證中間件谒养。Passport目的只是為了“登陸認(rèn)證”,因此明郭,代碼干凈买窟,易維護(hù),可以方便地集成到其他的應(yīng)用中薯定。Web應(yīng)用一般有2種登陸認(rèn)證的形式:用戶名和密碼認(rèn)證登陸,OAuth認(rèn)證登陸始绍。Passport可以根據(jù)應(yīng)用程序的特點(diǎn),配置不同的認(rèn)證機(jī)制话侄。本文將介紹亏推,用戶名和密碼的認(rèn)證登陸。
2.10 定時(shí)任務(wù)工具: later
Later 是一個(gè)基于Nodejs的工具庫(kù)年堆,用最簡(jiǎn)單的方式執(zhí)行定時(shí)任務(wù)吞杭。Later可以運(yùn)行在Node和瀏覽器中。
2.11 瀏覽器環(huán)境工具: browserify
Browserify 的出現(xiàn)可以讓Nodejs模塊跑在瀏覽器中变丧,用require()的語(yǔ)法格式來(lái)組織前端的代碼芽狗,加載npm的模塊。在瀏覽器中锄贷,調(diào)用browserify編譯后的代碼译蒂,同樣寫(xiě)在標(biāo)簽中。
用 Browserify 的操作谊却,分為3個(gè)步驟柔昼。1. 寫(xiě)node程序或者模塊, 2. 用Browserify 預(yù)編譯成 bundle.js, 3. 在HTML頁(yè)面中加載bundle.js。
2.12 命令行編程工具:Commander
commander 是一個(gè)輕巧的nodejs模塊炎辨,提供了用戶命令行輸入和參數(shù)解析強(qiáng)大功能捕透。commander源自一個(gè)同名的Ruby項(xiàng)目。commander的特性:自記錄代碼,自動(dòng)生成幫助,合并短參數(shù)(“ABC”==“-A-B-C”),默認(rèn)選項(xiàng),強(qiáng)制選項(xiàng),命令解析,提示符碴萧。
2.13 Web控制臺(tái)工具: tty.js
tty.js 是一個(gè)支持在瀏覽器中運(yùn)行的命令行窗口乙嘀,基于node.js平臺(tái),依賴socket.io庫(kù)破喻,通過(guò)websocket與Linux系統(tǒng)通信虎谢。特性:支持多tab窗口模型; 支持vim,mc,irssi,vifm語(yǔ)法; 支持xterm鼠標(biāo)事件; 支持265色顯示; 支持session。
2.14 客戶端應(yīng)用工具: node-webwit
Node-Webkit 是NodeJS與WebKit技術(shù)的融合曹质,提供一個(gè)跨Windows婴噩、linux平臺(tái)的客戶端應(yīng)用開(kāi)發(fā)的底層框架擎场,利用流行的Web技術(shù)(Node.JS,JavaScript几莽,html5)來(lái)編寫(xiě)應(yīng)用程序的平臺(tái)迅办。應(yīng)用程序開(kāi)發(fā)人員可以輕松的利用Web技術(shù)來(lái)實(shí)現(xiàn)各種應(yīng)用程序。Node-Webkit性能和特色已經(jīng)讓它成為當(dāng)今世界領(lǐng)先的Web技術(shù)應(yīng)用程序平臺(tái)章蚣。
2.15操作系統(tǒng): node-os
NodeOS 是采用NodeJS開(kāi)發(fā)的一款友好的操作系統(tǒng)站欺,該操作系統(tǒng)是完全建立在Linux內(nèi)核之上的,并且采用shell和NPM進(jìn)行包管理纤垂,采用NodeJS不僅可以很好地進(jìn)行包管理矾策,還可以很好的管理腳本、接口等洒忧。目前蝴韭,Docker和Vagrant都是采用NodeOS的首個(gè)版本進(jìn)行構(gòu)建的。
3. Nodejs學(xué)習(xí)路線圖
我們看到Nodejs已經(jīng)被廣發(fā)地應(yīng)用在各種的場(chǎng)景了熙侍,針對(duì)Nodejs的應(yīng)用場(chǎng)景,我們應(yīng)該如何學(xué)習(xí)Nodejs呢履磨?
以下內(nèi)容是我整理的文檔和教程蛉抓,每個(gè)軟件包對(duì)應(yīng)一篇文章,大家可以根據(jù)自己的需要進(jìn)行閱讀剃诅,完整的文章列表巷送,可以查看:從零開(kāi)始nodejs系列文章。
項(xiàng)目管理:npm,grunt, bower, yeoman
Web開(kāi)發(fā):express,ejs,hexo, socket.io, restify, cleaver, stylus, browserify,cheerio
工具包:underscore,moment,connet,later,log4js,passport,passport(oAuth),domain,require,reap,commander,retry
數(shù)據(jù)庫(kù):mysql,mongoose,reids
異步:async,wind
部署:forever,pm2
測(cè)試:jasmine,karma
跨平臺(tái):rio,tty
內(nèi)核:cluster,http,request
算法:ape-algorithm(快速排序),ape-algorithm(桶排序)
Nodejs在快速的發(fā)展著矛辕,軟件包版本升級(jí)的很快笑跛,文章有運(yùn)行不通的地方請(qǐng)參考官方文檔解決。我也會(huì)不定期更新文章聊品,盡量保持文章代碼的可用性飞蹂。
祝大家在Nodejs的世界里,享受開(kāi)發(fā)的樂(lè)趣翻屈!