nodejs + socket.io + redis 新手上路
最近要更新网站架构了,决定转入 nodejs + socket.io + redis 方式。
战斗刚开始:
网上的文章太松散,我根据各个网友的分享进行整理 ,让大家可以方便上手。
进入node.js之路,开始整理的资料
为什么需要 ? node.js + socket.io
node.js提供了高效的服务端运行环境,但是由于浏览器端对HTML5的支持不一,为了兼容所有浏览器,提供卓越的实时的用户体验,并且为程序员提供客户端与服务端一致的编程体验,于是socket.io诞生。
Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。有字符串,链表,集 合和有序集合。支持在服务器端计算集合的并,交和补集(difference)等,还支持多种排序功能。所以Redis也可以被看成是一个数据结构服务 器。
Redis的所有数据都是保存在内存中,然后不定期的通过异步方式保存到磁盘上(这称为“半持久化模式”);也可以把每一次数据变化都写入到一个append only file(aof)里面(这称为“全持久化模式”)。
安装Node.js
操作系统是XP和Win7都可以安装的。
登录Node.js的官方网站下载:http://www.nodejs.org/,点击download按钮
下载最新的windows版本,注意选择对应的版本,之后安装就可以了
安装路径默认是当前用户的有权限的目录。win8,win7等对目录安全控制较多的系统最好不要放在系统盘,以免后续的npm安装失败。
重点注意你的安装路径,后期需要用到。尽量放其它盘路径简短,方便后续 cmd
安装完后 在开始>程序>Node.js >Node.js command prompt 输入相关命令
验证node.js 安装是否成功
打开cmd,进入node目录,输入node -v
如果我们使用webstorm开发,配置开发环境。在Run/Debug Configuration中,加入环境变量:“NODE_PATH=C:\Program Files\nodejs\node_modules”。除了编辑器的各种功能外,webstorm对Node.js有很好的调试功能。操作简单,多尝试就能学会。
安装下载 webstorm http://www.jetbrains.com/webstorm/
【转】Webstorm 序列号和证书
WebStorm注册码
User Name:
EMBRACE
License Key:
===== LICENSE BEGIN =====
24718-12042010
00001h6wzKLpfo3gmjJ8xoTPw5mQvY
YA8vwka9tH!vibaUKS4FIDIkUfy!!f
3C"rQCIRbShpSlDcFT1xmJi5h0yQS6
===== LICENSE END =====
安装Redis
是安装Redis的Node.js客户端,这样Node.js程序就可以连接到Redis服务器并进行操作
下面我们再来看一下通过客户端访问node.js进行redis存储的过程
如果你的电脑处于联网状态,那么安装可以把redis-node以npm模块的形式安装到node中,以后在引用时直接使用require("redis")就可以了,不需要写相对路径了,呵呵,安装它的方法如下:
npm install redis
npm install hiredis redis
换用 npm install connect-redis
这时,如果安装成功,就可以做实例了,呵呵!注意,我们的npm install redis这种安装模块的命令,是把模块安装到当前目录的,即你的工作项目如果需要redis,需要在工作项目中进行安装,如果你的工作项目目录是c:\noderedis,那么安装模块后,你的目
录会多一个node_modules文件夹
https://github.com/mranney/node_redis
下面我们写一个实例,用来向redis服务器发set和hset串,然后再把redis服务器里所有的键名都读出来
var redis = require("redis"); var client = redis.createClient(); client.on("error", function (err) { console.log("Error " + err); }); client.set("string key", "string val", redis.print); client.hset("hash key", "hashtest 1", "some value", redis.print); client.hset(["hash key", "hashtest 2", "some other value"], redis.print); client.hkeys("hash key", function (err, replies) { console.log(replies.length + " replies:"); replies.forEach(function (reply, i) { console.log(" " + i + ": " + reply); }); client.quit(); });
安装错误提示:
can't find python
貌似只兼容 Python2.50 到 3.0 的版本 这个最新的3.3 就不行了
环境变量
PATH D:\nodejs\npm;D:\Python27
开始使用
中文官网最新下载 http://redis.cn/download.html
参考 Node.js+socket.io实现实时通信 http://www.cnblogs.com/SUN-PH/archive/2013/04/02/2994331.html
参考 Redis的探究
让nodejs后台运行
让nodejs应用后台执行,最简单的办法是:
nohup node your_app.js &
但是,forever能做更多的事情,比如分别记录输出和错误日志,比如可以在js中作为api使用。
我们只是很简单的在命令行里使用它。
使用forever运行nodejs应用 不支持windows
node.js应用生成windows service的plugin——winser
安装很简单:
sudo npm install forever -g
使用forever启动守护进程:
forever start server.js
关闭守护进程:
forever stop server.js
如果需要记录输出日志和错误:forever start -l forever.log -o out.log -e err.log server.js
下次再运行时会提示forever.log日志已经存在,使用-a追加。
forever start -l forever.log -o out.log -e err.log -a server.js
node服务器开机自启动
是指要开机自动执行node app.js
吗?
那就需要把它注册一个windows service,然后设置这个服务为开机自动启动。
方法1. 直接使用nssm工具,或者它的node.js包装程序Winser。
方法2. 直接使用node.js程序,如windows-service或者node-windows。
实现简单的路由机制
高效率的RESTful请求都倾向于使用HTTP GET方法。GET请求的所有信息都携带在请求地址url中。在Node.js里读取request.url可以获得请求的url,我们需要对不同的url做路由处理,返回不同的响应数据。Node.js有一个轻量级框架Express,它实现了一个比较好的路由机制,只是他不在我们的学习范围之中。我们需要的是能够处理下面路由表的高效的路由机制。
安装express
npm install express -d
#-g代表安装到NODE_PATH的lib里面,而-d代表把相依性套件也一起安装。如果沒有-g的话会安装目前所在的目录(会建立一个node_modules的文件夹),结果显示如下则安装成功:
验证express是否安装成功
安装完成后,关闭cmd,在重新打开
进入cmd,直接输入express -V
注意我这里用的大写V
Instagram的实时图片Demo:Node.js, Redis 加 Web Sockets
Instagram公布其实时图片API的演示网站(http://demo.instagram.com/)的源码,这个网站是用Node.js、Redis和Web Sockets,主要使用了Redis的pub/sub机制来进行消息推送。
官方源码: https://github.com/Instagram/Realtime-Demo
好事者的更新: https://github.com/asalant/Realtime-Demo
Materials:
使用 Node.js 作为完整的云环境开发堆栈
http://www.ibm.com/developerworks/cn/cloud/library/cl-nodejscloud/index.html
Reds:一个Redis加Node.js的全文搜索引擎
http://blog.nosqlfan.com/html/2676.html
Node.js与服务端模板引擎
http://ittechnical.sinaapp.com/node-js-and-server-side-template/
客户端 var socket = io.connect(host,options);
io.on
-> connect : socket.on('connect',function(){});当socket与后端成功建立链接后 -> connecting : socket.on('connecting',function(){});socket正在与服务器建立链接 -> disconnect : socket.on('disconnect',function(){});当与服务器断开链接s -> connect_failed : socket.on('connect_failed',function(){});与服务器链接失败 -> error : socket.on('error',function(){});当一个错误发生而且不能被处理 -> message : socket.on('message',function(message,[callback]){});通过send方法发送到服务器端,并且被服务器接受并返回到客户端接受后处理的数据 -> anything : socket.on('anything',function(data,[callback]){});可以是任意事件,除了保留的事件之外 -> reconnect_failed : socket.on('reconnect_failed',function(){});socket再次链接失败 -> reconnect : socket.on('reconnect',function(){});重新链接并且成功 -> reconnecting : socket.on('reconnecting',function{});重新链接还在链接中..
服务器
var io = require('socket.io');
io.on
->connection : io.on('connection',function(socket){});初始化一个socket ->message : io.on('message',function(message,callback){});接受客户端send()方法发送过来服务器的数据 ->anything : io.on('anything',function(data){});除了库保留的事件外任意自定义事件 ->disconnect : io.on('disconnect',function(){});中端socket链接
日报系统 http://waltershe.github.io/ribao/
在Visual Studio中利用NTVS创建开发 nodejs