当前位置:首页 > 短网址资讯 > 正文内容

使用PHP和Node.js连接dubbo短网址服务

www.ft12.com8年前 (2017-05-03)短网址资讯2187
DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000+个服务提供3,000,000,000+次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

不巧的是我司也在用,之前的解决方案是JAVA包装成HTTP的restful API给中间层Node.js或者PHP调用,但是其实有时候需求比较紧急的情况下,直接RPC远程调用可能能解决一些燃眉之急。

由于技术栈是PHP和Node.js,前一阵子研究了一下,总结一下,希望能帮助到有类似场景的同学,也分享一下遇到这种根本不了解的问题是如何去解决的过程,PS,我之前没有JAVA开发背景和PHP开发背景。

一,了解dubbo和他的RPC远程调用原理。

首先是这张图分了几个角色,是从官网拿来的:

Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。

说的通俗一点,我们要拿PHP或者NodeJs实现一个Consumer,而Consumer与Monitor和Registry是有关联的,与Provider是有调用关系的。

这个图和上面这段话理解后,简单分析下,dubbo服务的Registry一般使用的都是zookeeper作为注册中心,Monitor需要在消费方和服务提供方进行监控统计,这里只需要实现Monitor消费方的通知即可。

二,实现方案。

上面只是简单的分析出来需求,那么如何实现这个Consumer呢,通过查看几个已经存在的开源项目,比如node.js比较有名的,很多人都在用的,支持hessian协议的 p412726700/node-zookeeper-dubbo,还有支持jsonrpc调用的hufeng/node-jsonrpc-dubbo,他们的实现基本上思路是一样的,包括几个PHP的项目:quickj/dubbo-php-client

既然大家都已经实现了,我讲讲我看到的源码和一些关键代码吧。

三,Node.js连接原理

1,基本所有的库都是使用alexguan/node-zookeeper-client来连接的Registry,使用zookeeper.createClient方法来创建zookeeper实例。

2,从zookeeper连接后的实例中拿到对应服务提供者提供的的dubbo协议集合,使用getChildren方法。

3,对拿到的集合遍历,记得要decodeURIComponent,然后对URL做解析,比如是http开头的dubbo协议,还是dubbo开头的协议,需要分别保存。

4,协议中是包含了RPC调用的所有dubbo方法的,此时需要把对应的方法进行保存,有的框架对方法做了属性拷贝,属性对应的方法内容就是一个invoke调用,有的则是对invoke做了API,你自己去传入RPC调用的方法名。

5,对不同协议编写不同的调用实现方法,如HTTP的调用使用node-json-rpc,而dubbo协议则使用hessian的库。

6,分析dubbo协议原理,简单概括就是基于hessian协议,传输前需要序列化,传输成功后使用hessian的反序列化方法拿到结果,传输使用socket方法连接短网址服务

7,序列化使用github.com/node-modules 自带js-to-java功能,但是这里需要注意,拿到成功返回结果后,如果decode失败,一定要检查java服务方法返回的最好是List,Map,Array这种常规JAVA数据类型,否则可能反序列化失败解析不出js对象。

8,完成调用,缓存实例,对Monitor做通知,详细格式参见dubbo Monitor源码:github.com/alibaba/dubb

四,PHP连接原理

因为我是先了解了NodeJs的大概一个调用和实现过程的,那么再看PHP的,其实就不难了。我这里做一个最小化的解释,我PHP并不太好……属于现学现卖。

1,先找能连zookeeper的类,ZooKeeper - Manual

2,同样使用getChild方法解析出dubbo的协议集合,并且urldecode,再分析保存住对应可以invoke的方法名,协议调用地址。

3,php中的invoke方法实现为先socket_create方法创建一个连接,connect之后socket_write发送请求,然后读回结果,再json_decode(包含中文结果记得转编码)。

4,write参数格式为:invoke com.xx.xx.interfaces.service.method("args")

5,发送Monitor通知,生成短链接

总结:

其实总结一下,理论上Node.js也是可以转写成PHP的实现方式,PHP也可以转写成Node.js的实现方式,语言虽然不一样,原理和调用方式都是相同,如果之后有时间,业务中经常使用这种场景,还是要自己亲自实现一个的好。

做前端真难。。所以我如果上面有说错的地方,大家指正,后续我再修改,希望帮助到想了解的朋友。


扫描二维码推送至手机访问。

版权声明:本文由短链接发布,如需转载请注明出处。

本文链接:https://www.ft12.com/article_29.html

分享给朋友:

相关文章

希望大家活得像朋友圈里一样好

希望大家活得像朋友圈里一样好

Photograph by Mária ?varbová来源丨十点读书作者丨文长长文长长,十点读书签约作者,烈酒小清新一枚,坚信美少女的征途永远是星辰和大海,新浪微博@文长长winnie,公众号:文长长(ID:wenchangchanga)...

FT12短网址:惊爆一个用肉眼几乎无法分辨的钓鱼网站

FT12短网址:惊爆一个用肉眼几乎无法分辨的钓鱼网站

近期FT12短网址小编发现钓鱼网址越来越多,所以旧事重提,将这片很久以前的旧闻发出来,给广大用户提个醒,凡是多个心眼。这应该是用肉眼最难分辨的钓鱼网站,没有之一,不信你试试,能看出端倪吗?网站的 URL 地址显示的是苹果官网,网址旁边是安全...

FT12短网址:新一轮全球数字竞争中制造业转型升级是关键

FT12短网址:新一轮全球数字竞争中制造业转型升级是关键

[ FT12短网址 ] 腾讯董事会主席兼首席执行官马化腾8月25日在“2017中国两化融合大会”上表示,未来20年,中国制造要走向中国创造,需要互联网与制造业深度融合,成功的关键在于,中国能否形成软件、硬件与服务三位一体的智能平台...

林肯公园主唱自杀:这个世上有人正承受着你所不能理解的痛苦

林肯公园主唱自杀:这个世上有人正承受着你所不能理解的痛苦

昨天刷微博的时候看见一条新闻,林肯公园主唱切斯特上吊自杀,那时候我心里只是微微一惊,毕竟这是一个麻木的时代,死亡换来人们一次短暂的叹息,然后大家又陷入彼此庸碌的一生,虽然我们不知道灾难和明天哪一个会先来,但我们终究学会的只是在麻木里等待明天...

FT12短网址:未来汽车迭代的核心是大数据AI

8月5日音讯,在今日举行的Rebuild大会2017上,蔚来轿车创始人、董事长李斌发表了《轿车行业的迭代思想》的主题讲演,他表示,大数据AI、用户效劳理念会成为推进未来轿车迭代的中心力气。在开始主题讲演前的简略介绍中,李斌透露,除了受主办方...

亚马逊137亿美元收购Whole Foods

亚马逊137亿美元收购Whole Foods

北京时间6月16日晚间消息,亚马逊周五宣布,将以约137亿美元收购全食超市(Whole Foods)。亚马逊称,将以每股42美元的现金收购这家有机食品连锁超市。全食超市创建于1980年,现有187家连锁店,遍布于全美各地。这也是迄今为止亚马...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。