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

相关推荐
小羊在睡觉1 小时前
Go与MySQL锁:索引失效陷阱
数据库·后端·mysql·golang
cch89182 小时前
易语言 vs Go:初学者与专业开发之选
开发语言·后端·golang
Joy T2 小时前
【Web3】深度解析 NFT 跨链智能合约开发:原生资产与衍生包装合约架构实战
git·架构·web3·区块链·node·智能合约·hardhat
m0_694845573 小时前
RevelGo搭建教程:类Rails开发体验的Go Web框架
服务器·开发语言·后端·docker·golang·开源·github
cch89184 小时前
易语言VS Go语言:编程语言大对决
开发语言·后端·golang
捧 花4 小时前
全面掌握数据结构:Java 与 Go 定义方式 + 原理 + 使用场景
java·开发语言·数据结构·golang
abcefg_h4 小时前
go定时器的底层原理和应用
java·数据库·golang
王家视频教程图书馆4 小时前
【保姆级】Go Fyne GUI 开发环境搭建(Windows 全流程避坑)
开发语言·windows·golang
Flandern11114 小时前
Go程序员学习AI大模型项目实战:从环境管理到核心架构抽象
人工智能·python·学习·ai·golang
普通网友18 小时前
数据加密与零知识证明在区块链中的应用解析
区块链·零知识证明