RPC(一):thrift 框架 go语言开发

栏目: Go · 发布时间: 5年前

内容简介:1、写 thrift 文件定义好 service :方法、入参出参2、生成 代码并发包3、编写 server 端实现

1、写 thrift 文件定义好 service :方法、入参出参

2、生成 代码并发包

3、编写 server 端实现

4、本地启动server端,进行测试

5、打包启动 rpc 服务

具体实现:

1、写 thrift 文件定义好 service 以及 入参出参的 struct

namespace 定义生成的文件目录和名称。

namespace py test_thrift.action_card
namespace go test_thrift.action_card
namespace java test_thrift.action_card

enum ResouceCode {
    ALPHA = 1,
    BETA = 2
}

序号:类型 名称
struct BannerParams {
    1: i64 member_id;
    2: i32 num;
}

service MemberService {
    Banner get_banner(1: BannerParams params)
}

生成 py 或者 go 代码,并发布镜像

gen:

thrift -r --gen go:package_prefix=github.com/serenity/gen-go/ ./thrift_files/test/test.thrift

2、编写 server 端实现

package service

import (
   "github.com/serenity/gen-go/test_thrift/member"
   "github.com/serenity/golang/pkg/action_card/controller"
   "github.com/serenity/golang/pkg/common/model"
)

func GetMemberServiceProcessor(msgChan chan model.Message) *member.MemberServiceProcessor {
   // service - api
   memberService := controller.NewMemberService()

   // processor
   return member.NewMemberServiceProcessor(memberService)
}

3、客户端调用测试

var memberClient = member_service.NewMemberServiceClient(tc.New("MemberService", tc.Timeout(500*time.Millisecond), tc.TargetName("member")))
params := memberClient.BannerParams{0,0}
banner := memberClient.GetBanner(params)
fmt.Println(banner)

4、打包启动 rpc 服务

servicesMap := map[string]thrift.TProcessor{
   "MemberService":        memberService.GetMemberServiceProcessor(),
}
server.New(
   servicesMap,
   server.SentryDSN(conf.EnvConfig.SentryDSN),
   server.Tracing(conf.EnvConfig.ChoosedClusterAddrs),
   server.Slowlog(500*time.Millisecond),
).Run("0.0.0.0:10000")

5、git 上线


以上所述就是小编给大家介绍的《RPC(一):thrift 框架 go语言开发》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

计算机程序设计艺术:第4卷 第4册(双语版)

计算机程序设计艺术:第4卷 第4册(双语版)

Donald E.Knuth / 苏运霖 / 机械工业出版社 / 2007-4 / 42.00元

关于算法分析的这多卷论著已经长期被公认为经典计算机科学的定义性描述。迄今已出版的完整的三卷组成了程序设计理论和实践的惟一的珍贵源泉,无数读者都赞扬Knuth的著作对个人的深远影响。科学家们为他的分析的美丽和优雅所惊叹,而从事实践的程序员们已经成功地应用他的“菜谱式”的解到日常问题上,所有人都由于Knuth在书中所表现出的博学、清晰、精确和高度幽默而对他无比敬仰。   为开始后续各卷的写作并更......一起来看看 《计算机程序设计艺术:第4卷 第4册(双语版)》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

URL 编码/解码
URL 编码/解码

URL 编码/解码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具