IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> go grpc 完整实例 -> 正文阅读

[网络协议]go grpc 完整实例

最近开始完整的学go , 这里简单记录下用go 开发的grpc demo。这里主要实现的是client 传id参数,rpc调用getUser 方法获取server 结果。

1. 开发配置

2. 开发代码

  • 新建项目目录,一般是在gopath下面
  • user.proto 文件内容如下

syntax = "proto3";

package user;

//新版本需要的配置
option go_package = "./user";

message UserRequest {
    int32 id = 1;
}

message UserResponse {
    int32 id = 1;
    string name = 2;
}

service UserService {
    rpc getUser(UserRequest) returns (UserResponse) {};
}

  • 生成grpc 代码
protoc user.proto --go_out=./protobuf --go-grpc_out=./protobuf --go-grpc_opt=require_unimplemented_servers=false

require_unimplemented_servers=false 这个配置不加,会存在兼容问题,有个接口需要实现

  • 编写 server 代码
package main

import (
	"context"
	"demo/grpc/protobuf/user"
	"fmt"
	"google.golang.org/grpc"
	"net"
)

type UserServiceInterface interface {
	GetUser(ctx context.Context, req *user.UserRequest) (*user.UserResponse, error)
}

type UserServiceStruct struct {

}

func NewUserService() UserServiceInterface {
	return &UserServiceStruct{}
}

func (userService *UserServiceStruct) GetUser(ctx context.Context, req *user.UserRequest) (*user.UserResponse ,error) {
	response := &user.UserResponse {
		Id: req.Id,
		Name: "Hello World",
	}

	return response,nil
}

func main()  {
	l,err := net.Listen("tcp", "127.0.0.1:8889")

	if err != nil {
		panic(err)
	}

	fmt.Println("listen on 127.0.0.1:8889")

	grpcServer := grpc.NewServer()

	var userService UserServiceInterface

	userService = NewUserService()
	user.RegisterUserServiceServer(grpcServer, userService)

	err = grpcServer.Serve(l)

	if err != nil {
		println(err)
	}


}

  • 编写 client 代码
package main

import (
	"context"
	"demo/grpc/protobuf/user"
	"encoding/json"
	"fmt"
	"google.golang.org/grpc"
)

func main(){
	conn, err := grpc.Dial("127.0.0.1:8889", grpc.WithInsecure())

	if err != nil {
		panic(err)
	}

	defer conn.Close()

	client := user.NewUserServiceClient(conn)

	req := &user.UserRequest{
		Id: 1,
	}

	response, _ := client.GetUser(context.Background(), req)

	resp,err := json.Marshal(response)

	fmt.Printf("%s", resp)

}


  • 完整代码结构,仓库地址:https://github.com/hufeng903/go-demo/tree/master/grpc
    .
    ├── client.go
    ├── go.mod
    ├── go.sum
    ├── protobuf
    │ └── user
    │ ├── user.pb.go
    │ └── user_grpc.pb.go
    ├── server.go
    └── user.proto

3. 安装依赖运行

  • go mod tidy 安装相关依赖
  • go run server.go

运行结果:listen on 127.0.0.1:8889

  • go run client.go

运行结果:{“id”:1,“name”:“Hello World”}

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-03-13 22:11:44  更:2022-03-13 22:11:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 6:33:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码