Cosmos的gRPC与Go

Cosmos与Go语言

gRPC

gRPC的基本概念(维基百科):

  1. gRPC (gRPC Remote Procedure Calls) 是一个跨平台的开源高性能远程过程调用(RPC)框架。
  2. gRPC最初由Google创建,它使用一个通用的RPC基础设施Stubby来连接其数据中心内外运行的大量微服务。
  3. gRPC基于HTTP/2协议传输数据,使用Protocol Buffers作为接口描述语言,并提供认证(authentication)、双向流(bidirectional streaming)和流量控制、阻塞或非阻塞绑定以及取消和超时(Deadlines)等功能。它为许多语言生成跨平台的客户端和服务器绑定。最常见的使用场景包括在微服务风格的架构中连接服务,或将移动设备客户端连接到后端服务。

Cosmos中的gRPC

Cosmos SDK 提供了两种主要接口与区块链交互:gRPC 和 CLI(命令行接口)。

  1. gRPC: gRPC 是一种现代化的远程过程调用协议,支持高效的数据传输。Cosmos SDK 的 gRPC 服务允许开发者通过编程语言访问区块链节点,适用于高性能应用和集成第三方服务。例如,可以使用 gRPC 查询账户余额、交易历史或提交交易。
  2. CLI: CLI 是用户通过命令行与区块链交互的工具,适合手动测试和简单任务。Cosmos 提供 cosmos-sdk-cli,支持查询链信息、管理账户、发送交易等功能。CLI 直观,适合调试和快速验证网络状态。

相比于CLI,gRPC具有更高的灵活性,gRPC 支持多种编程语言(如 Go、Python、Java、JavaScript 等),可以轻松集成到复杂系统或自动化流程中。

并且gRPC 使用二进制协议(Protocol Buffers),数据传输快,适合高频交互或实时系统,除此之外通过 gRPC,可以实现自定义客户端逻辑、复杂的交互模式(如双向流通信),不受 CLI 功能限制。

在cosmos-sdk中,client 文件中有grpc/cmtservicegrpc/nodegrpc/refection三个包用于实现grpc的不同功能

Go调用gRPC服务

  1. 首先在cosmos-sdk里simapp的配置文件中,开启grpc服务,默认位置在 ./private/.simapp/config/app.toml中

    bash 复制代码
    ###############################################################################
    ###                           gRPC Configuration                            ###
    ###############################################################################
    
    [grpc]
    
    # Enable defines if the gRPC server should be enabled.
    enable = true
    
    # Address defines the gRPC server address to bind to.
    address = "0.0.0.0:9090"

    将enable字段设置为true,即可开启grpc服务。

  2. 在Go中调用远程grpc服务
    首先,确定gRPC服务地址

    go 复制代码
    // gRPC 服务地址
    rpcEndpoint := "xxx.xxx.xxx.xxx:9090"

    建立gRPC连接

    go 复制代码
    // 建立gRPC连接
    conn, err := grpc.NewClient(rpcEndpoint, grpc.WithInsecure())
    if err != nil {
    	log.Fatalf("Failed to connect to gRPC server: %v", err)
    }
    defer conn.Close()

    创建Tendermint服务客户端

    go 复制代码
    // 创建Tendermint服务客户端
    client := cmtservice.NewServiceClient(conn)

    之后可以使用client与区块链进行交互。
    具体功能请看cosmos-sdk/client/rpc/cmtservice

相关推荐
前进的李工4 小时前
零知识证明:不泄露秘密也能自证
人工智能·web安全·区块链·零知识证明
Tony Bai4 小时前
Cloudflare 2025 年度报告发布——Go 语言再次“屠榜”API 领域,AI 流量激增!
开发语言·人工智能·后端·golang
焦点链创研究所5 小时前
以太坊基金会:以太坊状态演进路径与未来挑战
区块链
hengcaib6 小时前
赵良波:打造生鲜配送行业标杆,引领“新鲜、优质、安全”新风尚
大数据·区块链
CryptoRzz7 小时前
日本股票 API 对接实战指南(实时行情与 IPO 专题)
java·开发语言·python·区块链·maven
Wnq100729 小时前
在去中心化的边缘计算机集群中部署分布式 CORBA 及其AGENT
分布式·去中心化·区块链
小徐Chao努力9 小时前
Go语言核心知识点底层原理教程【变量、类型与常量】
开发语言·后端·golang
锥锋骚年9 小时前
go语言异常处理方案
开发语言·后端·golang
berabtc10 小时前
比特币价值稳定后参与去中心化金融活动
金融·web3·去中心化·区块链·微策略·btcfi
Moonbeam Community11 小时前
Polkadot 生态的跨链桥:Snowbridge、Hyperbridge 与未来的 REVM
区块链