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

前端之家收集整理的这篇文章主要介绍了API 服务器搭建笔记:CentOS + Node.js + MongoDB前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

  1. # centos
  2. yum install git nodejs npm mongodb mongodb-server redis
  3.  
  4. # Mac OSX
  5. brew install mongodb nodejs redis

Node

运行服务器

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

启动redis:

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

启动node服务器:

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

API Token

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

  1. 首先用户发送其用户名与密码;
  2. 服务器验证
    • 若失败返回错误
    • 成功则返回一个Token,用于身份标识。
  3. 之后的API访问,用户需发送该Token给服务器以提供身份。
  1. // 引入jwt
  2. var jwt = require('jwt-simple');
  3.  
  4. // 设置一个客户端不知道的secret
  5. secret = 'hehe'
  6.  
  7. // username -> Token
  8. User.methodsgetToken = function(){
  9. return jwtencode(thisusername, secret);
  10. }
  11.  
  12. // Token -> username
  13. staticsfindByToken (tokencallback){
  14. findOne({ : decode)},242)">}

MongoDB

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

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

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

运行

  1. # 创建数据目录,否则需要设置运行目录
  2. mkdir -p /data/db
  3.  
  4. # 运行数据库,默认端口:27017
  5. mongod
  6. # centOS可以启动其init.d脚本
  7. service mongod start
  8.  
  9. # 进入MongoDB终端
  10. mongo
  11.  
  12. # 查看与切换数据库
  13. show dbs
  14. use <db_name>
  15.  
  16. # 集合操作
  17. show collections
  18. db.<collection_name>.drop()
  19.  
  20. # 帮助
  21. help db.help()
  22. 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运行时完成备份和恢复。

  1. mongodump
  2. --db <database>,-d
  3. # 指定数据库,默认全部备份
  4.  
  5. --collection <collection>,-c
  6. # 指定集合,默认全部备份
  7.  
  8. --out <path>,-o
  9. # 输出目录,默认当前目录

猜你在找的CentOS相关文章