目錄
- 幾點雜談
- Node + Express 環境配置略述+開源庫的選擇
- Express.js 框架
- Node + MySQL 實例 (換成了mongodb)
- Node + Redis 實例
- Node的同步實現
(希望有幸可以慢慢把過去遇到的坑都記錄下來)
1. 幾點雜談
今日博主還要再開第二個大項,使用 Node.js+Express.js+Redis+MySQL 開發Restful Server。
為什么使用Node
- 對于IO密集型任務有很高的效率。
- 天然對于JSON的良好支持
- 不用造太多輪子,配以(貼一下我的package.json)(一些庫直接使用npm安裝,例如bluebird)+ES6(CoffeScript)足以將Node.js 變成一個快速開發神器。
- 配置簡單!!!!!!以后可以開一個docker+node實戰。
"dependencies": {
"aliyun-sdk": "1.6.2",
"async": "2.0.0-rc.6",
"body-parser": "~1.13.2",
"connect-multiparty": "2.0.0",
"connect-redis": "3.0.2",
"cookie-parser": "~1.3.5",
"debug": "~2.2.0",
"express": "~4.13.1",
"express-session": "1.13.0",
"hiredis": "1.0.0",
"morgan": "~1.6.1",
"redis": "2.6.1",
"request": "2.72.0",
"serve-favicon": "~2.3.0",
"socket.io": "1.4.5",
"socket.io-express-session": "0.1.3",
"urllib": "2.13.0",
"mysql":"2.11.1"
}
為什么使用Redis
為了解決以下三個問題。
- 不同進程、不同服務器共享Session。(防止用戶斷線重連,換了服務器與進程)
- 關系運算、排名。(代碼也很好寫)
- 熱數據的緩存。
為什么使用mongodb
redis太貴,mysql 太麻煩,documentdb奇奇怪怪,table storage更是不懂是什么鬼。
版本迭代之后對舊數據很友好,不用修改schema寫腳本做數據轉換。一般產品速度瓶頸不會在db上。
我對Restful的理解。
Restful用于規范Api,使用四種Method--PUT, POST, DELETE, GET,來實現。對應數據庫里,CREATE,UPDATE,DELETE,READ。
顧名思義,四種皆是動詞,所以核心在于URL結尾是名詞。
以User為例,創建用戶
POST host:port/user
更新IP地址
PUT host:port/user/id/IPAddress
刪除用戶
DELETE host:port/user/id
讀取用戶昵稱
GET host:port/user/id/nickname
個人喜好把參數放在body里去處理,如果是DELETE與GET,就放在query里。最重要的便是整個小組/公司達成一致。有了規范是不是Restful都沒有那么重要!
后續
人還是懶的,有空多寫兩行代碼也懶得寫blog。
近來一直在C#的技術棧,偶爾切換到Angular2,偶爾用用Node.js.
Node.js是很有前景的語言,做快速開發,中間件,等等,有奇效。建議輔修一門類似Java, C#的老式語言。