• 1、Node.Js环境准备

在win8 + vs.net 2012 环境下调试了很长时间没搞定安装编译问题,重装系统测试了2套环境,解决了编译问题:

1)Win8.1 + vs.net 2013

2) ubuntu server 64位

node.js 依赖库安装调试有点小麻烦,差点就放弃了,就以调试经验大概记录下来。

方案1)Win8.1  64位+ vs.net 2013

  • 安装node.js

http://nodejs.org/download/

  • vs.net 2013集成开发环境

http://nodejstools.codeplex.com/

  • python 2.7 (注意版本,版本过高调试问题非常多)

Our Downloads | Python.org
https://www.python.org/downloads/

  • 设置PATH环境变量

cmd 命令行:node –v 可以测试

方案2)ubuntu server 64位

sudo apt-get update
sudo apt-get install python-software-properties python g++ make
sudo add-apt-repository ppa:chris-lea/node.js
sudo apt-get update
sudo apt-get install nodejs

2.cnpm库安装

国内网络原因,npm安装插件容易出问题,使用cnpm解决。

npm install -g cnpm --registry=http://r.cnpmjs.org
cnpm install [name]

3.protobuf序列化

安装:

cnpm install protobufjs

官方API及介绍:

https://github.com/dcodeIO/ProtoBuf.js

示例google protobuf 描述proto文件:trace.proto

   1:  message Traces{
   2:      repeated Trace Items = 1;
   3:  }
   4:  message Trace {  
   5:          required    string code = 1;  
   6:      required    int32 tradeTime=2;
   7:      optional     double    amount=3;
   8:      optional     int64    volume=4;
   9:      optional     bool    buyOrSell=5;
  10:      optional     int64    deals=6;
  11:      optional     double    price=7;
  12:      enum Exchange
  13:      {        
  14:          Shse=1;
  15:           Szse=2;    
  16:      };
  17:      optional     Exchange    exchange=8;
  18:  }  

4.Zeromq通信

  • 安装Zeromq
1、在http://www.zeromq.org/area:download页面下载最新的zeromq .
wget http://download.zeromq.org/zeromq-XXXXX.tar.gz
2
、安装相关软件
$ sudo apt-get install libtool autoconf automake
$ sudo apt-get install uuid-dev g++
$ sudo apt-get install python-dev
3、编译安装zmq
$ ./configure
$ make
$ sudo make install
$ sudo ldconfig

  • 安装zmq for node

cnpm install zmq

官方API介绍:

Node.js Binding - zeromq
http://zeromq.org/bindings:node-js

测试代码:

   1:  var protoBuf = require("protobufjs");
   2:  //protobufjs test
   3:  var builder  = protoBuf.loadProtoFile("trace.proto");
   4:  var     Rtquote =builder.build();
   5:   
   6:  var zlib = require('zlib');
   7:  var zmq = require('zmq');
   8:  var socket = zmq.socket('sub');
   9:  var port = "tcp://192.168.1.16:9178";
  10:  socket.identity = 'subscriber' + process.pid;
  11:  socket.connect(port);
  12:  console.log('connected!');
  13:   
  14:  socket.subscribe('Trace');
  15:   
  16:  var  i = 0;
  17:  socket.on('message', function(data) {
  18:       /*decode*/
  19:      var buf=data;
  20:          //console.log("packetType: " + buf.toString('utf8', 0, 26));
  21:            
  22:          //2.解压缩  自定义协议部分
  23:          var bodyBuffers = buf.slice(62,data.length);
  24:          //console.log("bodylength3:"+bodyBuffers.length);
  25:      
  26:          /*
  27:          if(bodyBuffers.length!=bodyLength)
  28:          {
  29:  
  30:              console.log(bodyBuffers.length+"!="+bodyLength);
  31:          }
  32:         */
  33:         
  34:          //body Gzip解压缩
  35:          zlib.gunzip(bodyBuffers,function(err, buffer) {
  36:            if (!err) {
  37:                  //console.log("gzip:"+buffer.length);
  38:                  var items =     Rtquote.Traces.decode(buffer);      
  39:                  //console.log("len:"+items.Items.length);    
  40:                  for(var i=0;i<items.Items.length;i++)
  41:               {
  42:                                  var item=items.Items[i];
  43:                                 console.log("code: "+item.code+" tradetime: "+item.tradeTime+" amount: "+item.amount+" volume: "+item.volume+" buyOrSell: "+item.buyOrSell+" deals: "+item.deals+" price: "+item.price+" exchange: "+item.exchange);
  44:               }                        
  45:            }
  46:      });
  47:  });
  48:   
  49:  console.log('Hello world');

运行:sudo node app.js 可以实时使用Zmq 接收数据,解压 ,序列化。

参考资料:

入门知识概览 · cnodejs/nodeclub Wiki · GitHub
https://github.com/cnodejs/nodeclub/wiki/%E5%85%A5%E9%97%A8%E7%9F%A5%E8%AF%86%E6%A6%82%E8%A7%88

Node.js(2)-protobuf zeromq gzip的更多相关文章

  1. WebStorm中配置node.js(Windows)

    WebStorm中配置node.js(Windows) 一.node 1.下载安装包 32 位 : https://nodejs.org/dist/v4.4.3/node-v4.4.3-x86.msi ...

  2. 玩转Node.js(四)-搭建简单的聊天室

    玩转Node.js(四)-搭建简单的聊天室 Nodejs好久没有跟进了,最近想用它搞一个聊天室,然后便偶遇了socket.io这个东东,说是可以用它来简单的实现实时双向的基于事件的通讯机制.我便看了一 ...

  3. 玩转Node.js(三)

    玩转Node.js(三) 上一节对于Nodejs的HTTP服务进行了较为详细的解析,而且也学会了将代码进行模块化,模块化以后每个功能都在单独的文件中,有利于代码的维护.接下来,我们要想想如何处理不同的 ...

  4. 玩转Node.js(二)

    玩转Node.js(二) 先来回顾上次的内容,上一次我们使用介绍了Node.js并写了第一个服务器端的Hello World程序,在这个Hello World程序中,请求自带的http模块并将其赋给h ...

  5. 玩转Node.js(一)

    玩转Node.js(一) 在说Node.js之前,我们先来说说js,如果你也曾开发过前端,那么你一定接触到了这个叫JavaScript有趣的东西,而对于JavaScript,你只会基本的操作——为we ...

  6. windows平台 - 0基础学习node.js(一)

    首先得明白node.js做什么用的: 简单的说 Node.js 就是运行在服务端的 JavaScript. Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台. Nod ...

  7. Node.js(转) -- 临时来说还看不懂!

    转自:http://blog.jobbole.com/53736/ 本文由 伯乐在线 - Lellansin 翻译.未经许可,禁止转载!英文出处:toptal.欢迎加入翻译组. 介绍 JavaScri ...

  8. 深入浅出Node.js(一):什么是Node.js

    Node.js从2009年诞生至今,已经发展了两年有余,其成长的速度有目共睹.从在github的访问量超过Rails,到去年底Node.jsS创始人Ryan Dalh加盟Joyent获得企业资助,再到 ...

  9. Node.js(window)基础(2)——node环境下的模块,模块间调用

    参考:http://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/00143450241959 ...

随机推荐

  1. [mysql]brew 安装 配置 操作 mysql(中文问题)

    mac 下卸载mysqldmg mac下mysql的DMG格式安装内有安装文件,却没有卸载文件--很郁闷的事. 网上搜了一下,发现给的方法原来得手动去删. 很多文章记述要删的文件不完整,后来在stac ...

  2. jquery操作常用HTML控件

    设置checkbox选中: $("[id='checkbox_id3']").attr("checked", true); 设置class下所有input不可用 ...

  3. Java魔法堂:深入正则表达式API

    目录 一.前言 二.正则表达式的使用诉求 三.java.util.regex包 四.java.lang.String实例 五.最短路径实现诉求 六.Java支持的正则表达式功能语法 七.总结 八.参考 ...

  4. CART(分类回归树)原理和实现

    前面我们了解了决策树和adaboost的决策树墩的原理和实现,在adaboost我们看到,用简单的决策树墩的效果也很不错,但是对于更多特征的样本来说,可能需要很多数量的决策树墩 或许我们可以考虑使用更 ...

  5. javascript之IE版本检测

    近年来随着操作系统的升级以及各种新技术的开发普及,抛弃低版本IE已经是大势所趋,这对于前端人员来时是个好消息,可以不用花费太多的时间来做低版本的兼容,很多站点采用给予低版本IE以提示的方式(恩,很友好 ...

  6. Gradle学习系列之七——依赖管理

    在本系列的上篇文章中,我们讲到了如何使用java Plugin,在本篇文章中,我们将讲到Gradle的依赖管理. 请通过以下方式下载本系列文章的Github示例代码: git clone https: ...

  7. 重构第23天 引用参数对象(Introduce Parameter Object)

    理解:有时候我们的一个方法,需要很多个参数,太多参数,不易阅读和理解,我们就可以把多个参数封装成一个对象. 详解: 重构前代码: public class Registration { public ...

  8. 第一个app.总结

    前记: 最近想整点外快,但是又没啥子技术,唉,学了一下android,想写点游戏啥的,,唉,可惜,美工,UI始终不行,代码也勉勉强强... 不过总的来说也是收获参半吧,也是有一些新的知识学到了嘛,至少 ...

  9. 小白学Linux(二)--命令行基本操作

    安装完Ubuntu后,进入系统,呈现在眼前的是Ubuntu的界面,跟windows的差不太多.一般操作系统包含GUI和CLI.GUI就是我们现在看到的,也是windows常用的直接用拖拽,点击等操作对 ...

  10. xshell下载文件到本地/上传文件到服务器

    xshell很好用,然后有时候想在windows和linux上传或下载某个文件,其实有个很简单的方法就是rz,sz首先你的Ubuntu需要安装rz.sz(如果没有安装请执行以下命令,安装完的请跳过.其 ...