nodejs + socket.io + redis 新手上路

最近要更新网站架构了,决定转入 nodejs + socket.io + redis 方式。

战斗刚开始:

网上的文章太松散,我根据各个网友的分享进行整理 ,让大家可以方便上手。

进入node.js之路,开始整理的资料

 

为什么需要 ? node.js + socket.io

   node.js提供了高效的服务端运行环境,但是由于浏览器端对HTML5的支持不一,为了兼容所有浏览器,提供卓越的实时的用户体验,并且为程序员提供客户端与服务端一致的编程体验,于是socket.io诞生。

    socket.io设计的目标是支持任何的浏览器,任何Mobile设备。目前支持主流的PC浏览器 (IE,Safari,Chrome,Firefox,Opera等),Mobile浏览器(iphone Safari/ipad Safari/android WebKit/WebOS WebKit等)。socket.io基于node.js并简化了WebSocket API,统一了通信的API。它支持:WebSocket, Flash Socket, AJAX long-polling, AJAX multipart streaming, Forever IFrame, JSONP polling。
    socket.io解决了实时的通信问题,并统一了服务端与客户端的编程方式。启动了socket以后,就像建立了一条客户端与服务端的管道,两边可以互通有无。
 
Redis服务器

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入门指南

【转】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

 

开始使用

(转)nodeJS 中文API node.js 中文文档

中文官网最新下载 http://redis.cn/download.html

参考  Node.js+socket.io实现实时通信  http://www.cnblogs.com/SUN-PH/archive/2013/04/02/2994331.html

参考  使用node.js和socket.io实现多人聊天室

参考  Redis的探究

参考  用Redis实现Session功能

 

让nodejs后台运行

让nodejs应用后台执行,最简单的办法是:

nohup node your_app.js &

但是,forever能做更多的事情,比如分别记录输出和错误日志,比如可以在js中作为api使用。

我们只是很简单的在命令行里使用它。

使用forever运行nodejs应用  不支持windows

利用bat脚本作为windows上forever的替代品

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

 

 Node.js + Express 构建的订餐系统

 

折腾:利用Node.js+express框实现图片上传

 

Instagram的实时图片Demo:Node.js, Redis 加 Web Sockets

Instagram公布其实时图片API的演示网站(http://demo.instagram.com/)的源码,这个网站是用Node.js、RedisWeb 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链接

socket.io使用随笔

 

node.js版简单客户端和服务端通讯源码

使用node.js和socket.io实现多人聊天室

通过Socket.IO与nodeJs实现即时消息推送

基于Qt的P2P局域网聊天及文件传送软件设计

nodejs入门-静态文件服务器

日报系统 http://waltershe.github.io/ribao/

在Visual Studio中利用NTVS创建开发 nodejs         

posted @ 2013-10-13 19:12  AppleCn  阅读(7520)  评论(0编辑  收藏  举报