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

相关推荐
007php0072 小时前
某游戏大厂 Java 面试题深度解析(四)
java·开发语言·python·面试·职场和发展·golang·php
꒰ঌ 安卓开发໒꒱4 小时前
Go高并发在企业级项目中的实战应用:数据库访问与GIN+GORM深度实践
数据库·golang·gin
请你喝好果汁6415 小时前
python入门到编程第三章
golang
数据知道7 小时前
Go语言设计模式:抽象工厂模式详解
设计模式·golang·抽象工厂模式·go语言
数据知道8 小时前
Go语言设计模式:组合模式详解
设计模式·golang·组合模式·go语言
周杰伦_Jay11 小时前
【网络编程、架构设计与海量数据处理】网络编程是数据流转的血管,架构设计是系统扩展的骨架,海量数据处理是业务增长的基石。
网络·golang·实时互动·云计算·腾讯云·语音识别
Web3_Daisy11 小时前
消除链上气泡图:为什么换仓正在成为新的链上生存策略?
大数据·人工智能·安全·web3·区块链
岁忧13 小时前
Go channel 的核心概念、操作语义、设计模式和实践要点
网络·设计模式·golang
许强0xq16 小时前
Solidity 的十年与重生:从 Classic 到 Core
web3·区块链·智能合约·solidity·以太坊
Tony Bai16 小时前
从 Python 到 Go:我们失去了什么,又得到了什么?
开发语言·后端·python·golang