thrift 服务端如何获取整个调用链?

2015-05-07 21:10:25 +08:00
 eightqueen

我们的设想是从移动端的请求开始,生成一个MD5,接下来每一次对请求的处理都会传递这个MD5,这样的话一旦thrift报错,我知道是哪个请求导致的.但是MD5不能放到形参里.

4076 次点击
所在节点    Java
13 条回复
Codist
2015-05-07 21:27:50 +08:00
生成一个随机字符串就好了吧
hhkbp2
2015-05-07 21:43:23 +08:00
参数可以定义为任意类型,怎么不能放入md5呢
eightqueen
2015-05-07 21:55:40 +08:00
@hhkbp2 为了向后兼容,形参绝对不能变
hhkbp2
2015-05-07 22:33:46 +08:00
@eightqueen thrift支持添加参数的呀,怎么不能变呢
eightqueen
2015-05-07 23:32:28 +08:00
@hhkbp2 比如我有个接口是find(long id),在接口不变的前提下,客户端传给我一个md5,不能增加参数,find(string md5, long id)
semicircle21
2015-05-08 07:15:00 +08:00
如果你要插入一个 md5 到最前面, 那确实是不行的.
不过你可以考虑传结构体, 想设计一个流芳百世的接口, 就是传单结构体...
你看微信 sdk 接口那样...

另外, 我现在说 thrift 不太适合做客户端到服务器端通信还来得及吗?
https://semicircle.github.io/blog/2015/01/19/thrift-get-away-from-pitfalls/
semicircle21
2015-05-08 07:16:16 +08:00
没主意你发在 java 节点, 那就是 android 移动端咯...
"不太适合"之类的当我没说吧...
hhkbp2
2015-05-08 10:31:40 +08:00
@eightqueen 可以读读http://diwakergupta.github.io/thrift-missing-guide/#_versioning_compatibility
了解一下thrift如何支持添加参数并保持向旧版本兼容
lxyu
2015-05-08 11:03:46 +08:00
eleme 自用的 thriftpy 有实现一套 tracking 功能。可以看看这里 https://github.com/eleme/thriftpy/wiki/Thriftpy-Tracking
lxyu
2015-05-08 11:08:58 +08:00
如果是 java 语言的话,可以看看 twitter 的 finagle,里面也有实现一套 tracking 机制。简单来说是定制一个向后兼容的 protocol,在每个请求里面加入一段 header。
eightqueen
2015-05-08 11:19:14 +08:00
@semicircle21 thrift服务专门用来访问数据库,前面还有一堆中间件,直接与移动端交互的是PHP
eightqueen
2015-05-08 11:30:06 +08:00
@semicircle21 thrift服务不与移动端对接,前面有PHP
garfeildma
2015-05-08 20:17:36 +08:00
最新版的还是fb版的thrift已经支持header了,可以看看

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/189299

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX