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

相关推荐
leijiwen18 分钟前
AI × RWA 本地生活品牌数字资产管理与增长平台
人工智能·web3·区块链
半路程序员4 小时前
Go语言学习(四)
开发语言·学习·golang
秦禹辰4 小时前
轻量级开源文件共享系统PicoShare本地部署并实现公网环境文件共享
开发语言·后端·golang
数据知道8 小时前
Go基础:一文掌握Go语言泛型的使用
开发语言·后端·golang·go语言
brave_zhao11 小时前
业务知识:强制平仓
区块链
QX_hao11 小时前
【Go】--数据类型
开发语言·后端·golang
h79971011 小时前
redis lua脚本(go)调用教程以及debug调试
redis·golang·lua
趣味编程11111 小时前
go的学习2---》并发编程
学习·golang·perl
我菜我有理11 小时前
使用python爬取BSC链上交易(玩具版)
区块链
taxunjishu20 小时前
DeviceNet 转 Modbus TCP 协议转换在 S7-1200 PLC化工反应釜中的应用
运维·人工智能·物联网·自动化·区块链