使用api和rpc的一个综合使用

复制代码
type (
	LoginRequest {
		Username string `json:"username"`
		Password string `json:"password"`
	}
	RegistRequest {
		Username string `json:"username"`
		Password string `json:"password"`
	}
	RegistResponse {
		UserId uint   `json:"userId"`
		Err    string `json:"err"`
	}
)

@server (
	prefix: /api/users
)
service users {
	@handler login
	post /login (LoginRequest) returns (string)

	@handler register
	post /regist (RegistRequest) returns (RegistResponse)
}

type (
	UserInfoRequest {
		Id uint `json:"id"`
	}
	UserInfoResponse {
		Username string `json:"username"`
	}
)

@server (
	prefix: /api/users
	jwt:    Auth //开启jwt认证
)
service users {
	@handler userInfo
	get /info (UserInfoRequest) returns (UserInfoResponse)
}

首先是api文档,然后通过命令

复制代码
//goctl api go -api user.api -dir .

去生成对应的go项目

在etc/users.yaml中添加myslq的链接信息和jwt

在config/config.go中添加相应的配置内容

在svc中配置数据库的初始化和Context信息

最后就是logic/loginlogic.go中对于具体服务的一个处理

在login中进行token的生成,其他的响应根据业务写出相应的代码

然后是rpc的引入,首先是写一个和前面的api比较相似的proto

复制代码
syntax = "proto3";

package user;


option go_package="./user";

message LoginRequest{
  string Username=1;
  string Password=2;
}

message LoginResponse{
  uint32 UserId =1;
  string Token=2;
}


message RegisterRequest{
  string username=1;
  string password=2;
}

message RegisterResponse{
  uint32 user_id=1;
  string err=2;
}

service user{
  rpc UserLogin(LoginRequest) returns(LoginResponse);
  rpc UserRegister(RegisterRequest)returns(RegisterResponse);
}

//goctl rpc protoc user.proto --go_out=./types --go-grpc_out=./types --zrpc_out=.

然后通过命令去生成对应的go文件,同时将所有的处理业务从api转移到proto中,

最后api通过etcd获取rpc所对应的服务,最终处理请求

相关推荐
哈利路亚胡辣汤6 分钟前
spring多数据源配置
java·spring·mybatis
卷Java8 分钟前
智慧停车大屏数据分析与设计文档
java·大数据·人工智能·数据分析
弗里德姆15 分钟前
DIY主机无网络安装PVE全记录:手机热点+笔记本网络共享实战
服务器·网络·pve
wanhengidc38 分钟前
云手机服务器多开需要注意哪些
运维·服务器·智能手机
聪明的笨猪猪41 分钟前
Java SE “JDK1.8新特性”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
赋创小助手43 分钟前
Supermicro NVIDIA Grace Superchip存储服务器超微ARS-121L-NE316R开箱评测
运维·服务器·人工智能·深度学习·机器学习·自然语言处理
Excuse_lighttime44 分钟前
除自身以外数组的乘积
java·数据结构·算法·leetcode·eclipse·动态规划
Vahala0623-孔勇1 小时前
Redisson分布式锁源码深度解析:RedLock算法、看门狗机制,以及虚拟线程下的锁重入陷阱与解决
java·开发语言·分布式
fbbqt1 小时前
go语言数据结构与排序算法
数据结构·golang·排序算法
Coision.1 小时前
Linux C: 函数
java·c语言·算法