golang rpc使用thrift

今天看到不少公司都是用rpc 挺好奇的 不知道为何要用rpc?搜了一圈看一些说法是http可能性能低,而tcp要处理粘包、解包、超时等,感觉有点牵强,但无论如何还是看下rpc吧,至少以后可能会接触到,虽然我一直觉得tcp挺方便的。

go本身支持rpc,但不少是用thrift来做的,主要是thrift是跨语言的,go本身的rpc只能是go服务之间使用

看了下thrift的使用(之前主要使用protobuf),它和pb的最主要区别应该是自身实现了rpc的调用,其他和pb的区别不是特别大,甚至感觉比pb的调用还要臃肿(应该主要是他包括了rpc调用),之前用pb主要是自己解包、组包,然后发送;thrift主要是定义好IDL(类似pb的proto文件)和接口(这个是和pb比较大的区别,要提前定义好client和server之间的接口),然后用thrift工具生成对应的代码(例如go的),在代码里实现具体的cs之间的接口即可。下面大概贴个go版本的例子:

IDL文件如下,文件名为*.thrift

然后利用thrift命令来生成对应的go文件

thrift -r --gen go *.thrift

会生成一个gen-go的目录,里面包含对应的go代码


这个thrift文件包括几个部分:

首先是namespace,batu.demo,对应生成的go文件路径是在gen-go/batu/demo 下面

其次,是Article结构的定义,这部分生成是在ttypes.go文件里,生成一个go的对应结构体Article


接下来是const部分,会生成对应的constants.go文件:


constants.go

然后是接口部分,这里转换成go就是一个interface的结构了,这个interface包括CallBack和Put两个函数,这部分是在batuthrift.go文件:


batuthrift.go

这个interface的名字是thrift里service的名字。

我们已经看到thrift文件已经转成对应的go文件了,但需要注意的是,转成的go文件是interface形式的,那么我们就要有地方来实现这个interface才能使用,下面就是来实现这部分,先看服务端:

接下来实现对应的server和client

先看server端:


看server端是先声明了一个实现thrift interface的struct(实现了CallBack和Put两个函数),然后在main将这个struct对象注册起来,后续有客户端的请求就调用该对象具体的处理函数CallBack和Put

再看客户端:

客户端是先获取了服务端的句柄,然后调用服务端的接口api来完成rpc


总结下,rpc是想使用本地接口一样使用远程的api,省去了很多网络通信的过程,对应开发人员可能是简单了,但是对应想了解整个通信过程的人来说不见得是好事。这里有个rpc调用的时序图,其实底层也是tcp的通信:

下面是一些thrift的相关文章:

http://my.oschina.net/itblog/blog/289965  thrift和pb的对比

http://studygolang.com/articles/3110   go使用thrift

http://readingtrip.com/article/e3c9f920-900c-11e5-b854-a320fe3ba9ba  go使用thrift之hello world

http://www.ibm.com/developerworks/cn/java/j-lo-apachethrift/  thrift的介绍

http://blog.csdn.net/liuxinmingcode/article/details/45696237  thrift

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容