最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
GOLANG使用THRIFT的鉴权和多路复用
时间:2022-06-29 10:48:39 编辑:袖梨 来源:一聚教程网
最近梳理公司的服务时,决定把基础组件抽离出来服务化。因为公司里有多种语言开发的服务,决定使用thrift来解决跨语言通讯。
启动一个server
thrift对golang的支持已经很好了,官方包里提供了一个server基类和一个简单服务simple_server.go.自己可以实现server来做鉴权和其它统计操作.
server定义了一个TServer接口和一些方法,源码如下:
type TServer interface {
ProcessorFactory() TProcessorFactory //服务
ServerTransport() TServerTransport //连接
InputTransportFactory() TTransportFactory //输入
OutputTransportFactory() TTransportFactory //输出
InputProtocolFactory() TProtocolFactory //协议
OutputProtocolFactory() TProtocolFactory //协议
// Starts the server
Serve() error
// Stops the server. This is optional on a per-implementation basis. Not
// all servers are required to be cleanly stoppable.
Stop() error
}
Server方法进行监听,接受请求,调度处理.下面是simple_server.go的Server方法.
func (p *TSimpleServer) Serve() error {
err := p.Listen()
if err != nil {
return err
}
p.AcceptLoop()
return nil
}
func (p *TSimpleServer) AcceptLoop() error {
for {
client, err := p.serverTransport.Accept()
if err != nil {
select {
case <-p.quit:
return nil
default:
}
return err
}
if client != nil {
go func() {
if err := p.processRequests(client); err != nil {
log.Println("error processing request:", err)
}
}()
}
}
}
只要自己实现相关接口方法,在方法中就可以进行相关鉴权/统计等处理了。
关于多路复用idl写法的问题
golang的多路复用是要把service写在一个idl文件里的,而java就不需要。这个在刚开始的时候耽误了点时间。
相关文章
- 代号速降手游在哪下 代号速降下载渠道分享 06-09
- 代号莲正版手游下载地址分享 代号莲正版手游下载渠道推荐 06-09
- 恶魔轮盘最新版下载地址分享 恶魔轮盘联机版下载渠道推荐 06-09
- 开个洗脚店手游公测时间在什么时候 开个洗脚店手游怎么下 06-09
- 方舟生存进化手机版下载地址分享 方舟生存进化下载手机版渠道推荐 06-09
- 逃往南方下载地址分享 逃往南方下载渠道推荐 06-09