C++GO语言微服务基础技术②

目录

[01 protobuf语法回顾](#01 protobuf语法回顾)

[02 protobuf的编译、和其他序列化比较](#02 protobuf的编译、和其他序列化比较)

[03 查看protoc编译文件对比自定义封装](#03 查看protoc编译文件对比自定义封装)

[04 grpc安装简介](#04 grpc安装简介)

[05 grpc服务远程调用作业布置](#05 grpc服务远程调用作业布置)

[06 作业-grpc-server端](#06 作业-grpc-server端)

[07 作业-grpc-client端](#07 作业-grpc-client端)


01 protobuf语法回顾

复制代码
## 编译 protobuf

> 回顾:C++ 编译 命令:
>
> protoc --cpp_out=./  *.proto		---> xxx.pb.cc   和  xxx.pb.h   文件

- go 语言中 编译命令:

`protoc --go_out=./ *proto`      --->  xxx.pb.go 文件。



## 添加 rpc 服务

- 语法:

    ```protobuf
    service 服务名 {
    	rpc 函数名(参数:消息体) returns (返回值:消息)
    }
    message People {
    	string name = 1;
    }
    message Student {
    	int32 age = 2;
    }
    例:
    service hello {
    	rpc HelloWorld(People) returns (Student);
    }
    ```

02 protobuf的编译、和其他序列化比较

复制代码
- 知识点:

    - 默认,protobuf,编译期间,不编译服务。 要想使之编译。 需要使用 gRPC。
    - 使用的编译指令为:
        - `protoc --go_out=plugins=grpc:./ *.proto`

- 生成的 xxx.pb.go 文件 与 我们自己封装的 rpc 对比:

```go
客户端:

type bj38Client struct {} ----- type MyClient struct {} 类

func NewBj38Client()  ----- InitCient() 函数

func (c *bj38Client) Say() ---- HelloWorld() 方法

服务端:

type Bj38Server interface {}  ---- type MyInterface interface{} 接口。

func RegisterBj38Server() ---- func RegisterService() 函数。

03 查看protoc编译文件对比自定义封装

复制代码
## 作业:grpc 远程调用。

- 服务端 grpc 
    1. 初始一个 grpc 对象
    2. 注册服务
    3. 设置监听, 指定 IP、port
    4. 启动服务。---- serve()

04 grpc安装简介

复制代码
- 客户端 grpc
    1. 连接 grpc 服务
    2. 初始化 grpc 客户端
    3. 调用远程服务。

05 grpc服务远程调用作业布置

06 作业-grpc-server端

07 作业-grpc-client端

相关推荐
WBluuue10 分钟前
数据结构与算法:树上倍增与LCA
数据结构·c++·算法
lsx20240624 分钟前
MySQL WHERE 子句详解
开发语言
Tony Bai32 分钟前
【Go模块构建与依赖管理】09 企业级实践:私有仓库与私有 Proxy
开发语言·后端·golang
Lucky小小吴42 分钟前
开源项目5——Go版本快速管理工具
开发语言·golang·开源
Mr.Jessy1 小时前
Web APIs 学习第五天:日期对象与DOM节点
开发语言·前端·javascript·学习·html
呆瑜nuage1 小时前
C++之红黑树
c++
杨福瑞1 小时前
数据结构:单链表(2)
c语言·开发语言·数据结构
进化中的码农1 小时前
Go中的泛型编程和reflect(反射)
开发语言·笔记·golang
音符犹如代码2 小时前
Java并发List实战:CopyOnWriteArrayList原理与ArrayList常见面试题
java·开发语言·面试·list
又是忙碌的一天2 小时前
抽象类和接口
java·开发语言