API 服务器搭建笔记:CentOS + Node.js + MongoDB

http://harttle.com/2015/02/24/node-web-api.html

本文尝试在CentOS服务器上,使用js来构建整个web服务,包括nodejs运行时、MongoDB json风格数据库、redis内存数据库。首先安装这些软件:

# centos
yum install git nodejs npm mongodb mongodb-server redis

# Mac OSX
brew install mongodb nodejs redis

Node

运行服务器

本文只是使用screen完成服务器软件的运行,并未完整地部署。实际的生产环境部署中,需要完整的日志记录、服务器性能监控等。

启动redis:

screen -dmS redis   # 建立一个detach的screen窗口
screen -list        # 查看redis窗口的号
screen -r <number>  # attach redis窗口
redis-server        # 启动node
<C-a-d> # detach当前任务

启动node服务器:

screen -dmS node    # 查看node窗口的号
screen -r <number>  # attach node窗口
sudo npm start      # detach当前任务

API Token

Web API中的权限一般通过Token来识别。不同于 web page,API不方便使用 cookie 而通常通过 Token 来验证用户:

  1. 首先用户发送其用户名与密码;
  2. 服务器验证
    • 若失败返回错误
    • 成功则返回一个Token,用于身份标识。
  3. 之后的API访问,用户需发送该Token给服务器以提供身份。
// 引入jwt
var jwt = require('jwt-simple');

// 设置一个客户端不知道的secret
secret = 'hehe'

// username -> Token
User.methodsgetToken = function(){
      return jwtencode(thisusername, secret);
}

// Token -> username
staticsfindByToken (tokencallback){
      findOne({ : decode)},242)">}

MongoDB

MongoDB是一种非关系型数据库(NoSQL),相比于SQL更为灵活。不同于SQL,每条记录是一个文档,而不是表中的一行。文档的概念很好的实现了面向对象思想。参见:官网文档

在MongoDB的数据模型中,每个document有一个表示字段_id:ObjectId。可以通过该字段实现文档关联,当然也可以直接使用JSON格式的嵌套。

mongoose中,_id包括引号,用户后台判断;id不包括引号,用于前台显示。

运行

# 创建数据目录,否则需要设置运行目录
mkdir -p /data/db

# 运行数据库,默认端口:27017
mongod
# centOS可以启动其init.d脚本
service mongod start

# 进入MongoDB终端
mongo

# 查看与切换数据库
show dbs
use <db_name>

# 集合操作
show collections
db.<collection_name>.drop()

# 帮助
help db.help()
db.<collection_name>.help()

CRUD

MongoDB中的document为BSON格式,即二进制的JSON表示加上类型信息,所有的document存储在collection中。每个查询将得到一个目标collection,查询需指定criteria来得到符号条件的collection,再通过modifier对集合元素进行处理(比如排序)。

除了查询,还有insert,update,221)">remove操作,它们均作用于单个collection:

CRUD即增伤改查:create,read,update,delete

备份与恢复

可以直接将数据文件/data/db备份。而mongodumpmongorestore可以在mongod运行时完成备份和恢复。

mongodump
--db <database>,-d
# 指定数据库,默认全部备份

--collection <collection>,-c
# 指定集合,默认全部备份

--out <path>,-o
# 输出目录,默认当前目录

相关文章

文章浏览阅读903次。4.清除缓存目录(/var/cache/yum)下的软件...
文章浏览阅读1.5k次。Python 是一种高级解释性编程语言,已被...
文章浏览阅读2.6k次。打开终端或控制台,以root或具有sudo权...
文章浏览阅读744次,点赞24次,收藏26次。目标:通过AppSrv为...
文章浏览阅读1.1w次,点赞8次,收藏26次。chmod命令来自于英...
文章浏览阅读1.2k次。yum源的URL地址,本例中是文件系统的路...