设为首页 收藏本站
查看: 875|回复: 0

[经验分享] nodejs + socket.io + redis 新手上路

[复制链接]

尚未签到

发表于 2015-7-20 11:33:40 | 显示全部楼层 |阅读模式
  最近要更新网站架构了,决定转入 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服务器里所有的键名都读出来




DSC0000.gif

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.iyunv.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、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链接
  socket.io使用随笔
  
  node.js版简单客户端和服务端通讯源码
  使用node.js和socket.io实现多人聊天室
  通过Socket.IO与nodeJs实现即时消息推送
  基于Qt的P2P局域网聊天及文件传送软件设计
  nodejs入门-静态文件服务器
  日报系统 http://waltershe.github.io/ribao/
  在Visual Studio中利用NTVS创建开发 nodejs

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-88668-1-1.html 上篇帖子: TWaver html5 + NodeJS + express + websocket.io + redis 快速搭建项目(三) 下篇帖子: centos 安装nodejs
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表