优化Thrift客户端代码,分离连接、协议和调用逻辑
为了避免Thrift客户端代码中连接、协议和调用逻辑的冗余,建议采用以下分离策略,提升代码可维护性和可重用性。
1. 创建工具类 (util 目录)
在util目录下新建thriftserviceclient.go文件,封装通用的连接和协议创建逻辑:
package util import ( "fmt" "net" "os" "github.com/apache/thrift/lib/go/thrift" "your_project/fundinfo" // 替换为你的 fundinfo 包路径 ) func FundInfoServiceClient(ip, port string) (*fundinfo.FundInfoServiceClient, thrift.TTransport, error) { transportFactory := thrift.NewTFramedTransportFactory(thrift.NewTTransportFactory()) protocolFactory := thrift.NewTBinaryProtocolFactoryDefault() transport, err := thrift.NewTSocket(net.JoinHostPort(ip, port)) if err != nil { return nil, nil, fmt.Errorf("error resolving address: %w", err) } tTransport := transportFactory.GetTransport(transport) client := fundinfo.NewFundInfoServiceClientFactory(tTransport, protocolFactory) if err := tTransport.Open(); err != nil { return nil, nil, fmt.Errorf("error opening socket to %s:%s: %w", ip, port, err) } return client, tTransport, nil }
2. 简化客户端调用逻辑
在客户端方法中,只需调用工具类获取客户端对象和传输对象,然后执行所需的方法:
package main import ( "context" "your_project/util" // 替换为你的 util 包路径 ) func main() { client, tTransport, err := util.FundInfoServiceClient("your_ip", "your_port") // 替换为你的IP和端口 if err != nil { // 处理错误 } defer tTransport.Close() ctx := context.Background() res, err := client.GetFundInfo(ctx, "fundcode") // 替换为实际的 fundcode if err != nil { // 处理错误 } // 处理结果 res }
改进说明:
通过这种方式,连接、协议和调用逻辑被清晰地分离,提高了代码的可读性、可维护性和可重用性。 当需要调用其他Thrift服务方法时,只需修改调用client对象的相应方法即可,无需重复编写连接和协议创建代码。 记住替换your_project/fundinfo和your_ip, your_port为你的实际项目路径和服务器地址。
以上就是如何优雅地分离Thrift客户端连接、协议和调用逻辑?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号