目录
- 几点杂谈
- 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#的老式语言。