Node.js+Express.js+Redis+MySQL=Restful Server

目录

  1. 几点杂谈
  2. Node + Express 环境配置略述+开源库的选择
  3. Express.js 框架
  4. Node + MySQL 实例 (换成了mongodb)
  5. Node + Redis 实例
  6. Node的同步实现

(希望有幸可以慢慢把过去遇到的坑都记录下来)

1. 几点杂谈

今日博主还要再开第二个大项,使用 Node.js+Express.js+Redis+MySQL 开发Restful Server。

为什么使用Node
  1. 对于IO密集型任务有很高的效率。
  2. 天然对于JSON的良好支持
  3. 不用造太多轮子,配以(贴一下我的package.json)(一些库直接使用npm安装,例如bluebird)+ES6(CoffeScript)足以将Node.js 变成一个快速开发神器。
  4. 配置简单!!!!!!以后可以开一个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

为了解决以下三个问题。

  1. 不同进程、不同服务器共享Session。(防止用户断线重连,换了服务器与进程)
  2. 关系运算、排名。(代码也很好写)
  3. 热数据的缓存。
为什么使用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#的老式语言。

    原文作者:Tony_HQ
    原文地址: https://www.jianshu.com/p/5955b6a57e8f
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞