nodejs搭建简易的rpc服务

这里主要使用的是jayson包,使用jayson实现rpc server端十分简单,如下:

var jayson = require('jayson')

// create a server
var server = jayson.server({
  brest: function (args, callback) {
    console.log(args)
    callback(null, args[0] + args[1])
  }
})

server.http().listen(3000)

这样就简单的实现了一个json rpc2.0的服务,使用postman调用测试下:

这里的rpc调用的参数在params里面,分别包含call、args两个对象,再来看下rpc server这边打印出的请求参数,可以看出callback调用后rpc服务即可正常返回数据:

 

使用jayson的一个简单应用场景就是:

对于一些复杂应用,前后端分离后,前端要调用部分rpc服务(可能是c++或者golang写的,当前项目服务端使用的是nodejs),因为跨域问题,前端必须请求到后端(nodejs服务端),让后端去处理请求这个rpc服务,并把结果返回给前端,相当于后端相对于真正的rpc服务只不过是一个代理转发,这时候后端可以再次生成一个rpc服务,并配置cors资源共享,前端所有rpc请求均请求到这里,然后jayson里面(好比这个brest方法里面)拿到前端的请求信息,进行一次rpc请求转发,最后将请求结果callback返回给前端即可。

posted @ 2017-05-09 17:35  程序员小波与Bug  阅读(9992)  评论(0编辑  收藏  举报