API 服务器搭建笔记:CentOS + Node.js + MongoDB
2015-08-06 13:42
801 查看
文章链接:http://harttle.com/2015/02/24/node-web-api.html
本文尝试在CentOS服务器上,使用js来构建整个web服务,包括nodejs运行时、MongoDB json风格数据库、redis内存数据库。首先安装这些软件:
启动redis:
启动node服务器:
首先用户发送其用户名与密码;
服务器验证
若失败返回错误
成功则返回一个Token,用于身份标识。
之后的API访问,用户需发送该Token给服务器以提供身份。
在MongoDB的数据模型中,每个document有一个表示字段
在
除了查询,还有
CRUD即增伤改查:create,read,update,delete
本文尝试在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 # 建立一个detach的screen窗口 screen -list # 查看node窗口的号 screen -r <number> # attach node窗口 sudo npm start # 启动node <C-a-d> # detach当前任务
API Token
Web API中的权限一般通过Token来识别。不同于 web page,API不方便使用 cookie 而通常通过 Token 来验证用户:首先用户发送其用户名与密码;
服务器验证
若失败返回错误
成功则返回一个Token,用于身份标识。
之后的API访问,用户需发送该Token给服务器以提供身份。
// 引入jwt var jwt = require('jwt-simple'); // 设置一个客户端不知道的secret var secret = 'hehe' // username -> Token User.methods.getToken = function(){ return jwt.encode(this.username, secret); } // Token -> username User.statics.findByToken = function(token, callback){ this.findOne({ username: jwt.decode(token, secret)}, callback); }
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,
remove操作,它们均作用于单个collection:
CRUD即增伤改查:create,read,update,delete
备份与恢复
可以直接将数据文件/data/db备份。而
mongodump和
mongorestore可以在
mongod运行时完成备份和恢复。
mongodump --db <database>, -d # 指定数据库,默认全部备份 --collection <collection>, -c # 指定集合,默认全部备份 --out <path>, -o # 输出目录,默认当前目录
相关文章推荐
- MongoDB运行状态、性能监控,分析
- MongoDB 3.0 新特性【转】
- mongodb复制集部署
- 使用mongoosejs连接mongodb collection后自动加s的问题
- MongoDB集群读优先策略
- MongoDB集群——分片
- mongodb 优化
- mongoDB add user in v3.0 问题的解决(Property 'addUser' of object admin is not a func)
- linux下安装mongodb
- MongoDB——分片
- 关于MongoDB最大连接数的查看与修改
- CentOS编译安装MongoDB
- Nutch2.3分布执行过程中Mongodb中数据的变化
- MongoDB Sharding实践
- Mongodb详解与安装
- Mongodb常用命令
- Mongodb与Elasticsearch配合使用进一步研究(二)
- 初拥Mongodb的一些小问题
- linux 下安装mongoDB(转)
- MongoDB