
提升Go语言Thrift客户端代码可维护性:解耦连接、协议和服务调用
Go语言开发的Thrift客户端代码常常将连接、协议定义和服务调用混杂在一起,导致代码冗长且难以维护。本文介绍如何通过分离这些组件,提升代码的可读性和可维护性。
一、分离连接和协议定义:构建客户端工厂
为了解耦连接和协议定义,我们可以创建一个客户端工厂函数。该函数负责处理连接和协议的初始化工作,并返回一个包含已初始化连接和协议的Thrift客户端对象。
立即学习“go语言免费学习笔记(深入)”;
示例代码:
import ( "net" "os" "fmt" "github.com/apache/thrift/lib/go/thrift")func newFundInfoServiceClient(ip string, port int) (*fundinfo.FundInfoServiceClient, thrift.TTransport, error) { transportFactory := thrift.NewTFramedTransportFactory(thrift.NewTTransportFactory()) protocolFactory := thrift.NewTBinaryProtocolFactoryDefault() transportSocket, err := thrift.NewTSocket(net.JoinHostPort(ip, fmt.Sprint(port))) if err != nil { return nil, nil, fmt.Errorf("无法解析地址: %w", err) } transport, err := transportFactory.GetTransport(transportSocket) if err != nil { return nil, nil, fmt.Errorf("创建传输失败: %w", err) } client := fundinfo.NewFundInfoServiceClientFactory(transport, protocolFactory) if err := transport.Open(); err != nil { return nil, nil, fmt.Errorf("打开套接字失败: %w", err) } return client, transport, nil}
二、服务方法调用:简洁高效
使用客户端工厂创建的客户端对象,可以更简洁地调用服务方法。调用代码只关注服务方法本身,无需处理连接和协议细节。
示例代码:
func main() { client, transport, err := newFundInfoServiceClient("localhost", 9090) if err != nil { fmt.Fprintf(os.Stderr, "连接失败: %vn", err) os.Exit(1) } defer transport.Close() res, err := client.GetFundInfo(context.Background(), fundcode) if err != nil { fmt.Fprintf(os.Stderr, "调用服务失败: %vn", err) os.Exit(1) } // 处理结果 res}
通过将连接、协议初始化和服务调用分离,我们可以显著简化Thrift客户端代码,提高代码的可读性、可维护性和可测试性。 这种模式也更易于进行错误处理和资源管理。
以上就是如何优化Go语言Thrift客户端代码,分离连接、协议和服务调用?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1383527.html
微信扫一扫
支付宝扫一扫