擁抱大家庭,nodejs走thrift


擁抱大家庭,nodejs走thrift。最賤的例子,nodejs與nodejs之間走thrift對傳。

 

1,官網下載

http://mirrors.cnnic.cn/apache/thrift/0.9.1/thrift-0.9.1.exe 

2,編輯xuser.thrift

struct User{
     1: string uid,
     2: string uname,
     3: bool usex,
     4: i16 uage
    }
    service UserService{
     void add(1: User u),
     string adduname(1: string uname),
     User get(1: string uid)
}

3,生成IDL

thrift   --gen js:node xuser.thrift

4,目錄下會多出文件

5,編輯server.js

var thrift=require("thrift");
var UserService=require('./gen-nodejs/UserService.js');
var ttypes=require('./gen-nodejs/xuser_types');


var users={};

var server=thrift.createServer(UserService,
    {
        add:function(user,callback){
            console.log("add stored:",user.uname);
            users[user.uid]=user;
            console.log(users);
            callback();},
        adduname:function(x,callback){
            console.log("adduname stored:",x);
            callback(null,"MMMMM");
        },
        get:function(uid,callback){
            console.log("get received:", uid);
            console.log(users[uid]);
            callback(null,users[uid]);
        }
    }
);

server.listen(3000);
console.log("server start");

server.on("error",function(e){
    console.log(e);
});

6,編輯client.js

var thrift =require('thrift');


var UserService = require('./gen-nodejs/UserService.js');
var ttypes = require('./gen-nodejs/xuser_types');



var connection = thrift.createConnection('127.0.0.1', 3000);
var client = thrift.createClient(UserService, connection);

connection.on("error",function(e)
{
    console.log(e);
});


var x=new ttypes.User({
    uid:'112',
    uname:'aab',
    usex:0,
    uage:'181'
});




client.add(x,function(err, res){
    console.log("ADD OK1");
    client.get('112',function(err, res){
        if (err) {
            console.error(err);
        } else {
            console.log("Res:",res);
            connection.end();
        }
    });
    client.adduname('112',function(err, res){
        if (err) {
            console.error(err);
        } else {
            console.log("Res:",res);
            connection.end();
        }
    });
});

7,裝nodejs的thrift包

npm install thrift

8,node server.js

9,node client.js

OK,小功告成。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM