使用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所对应的服务,最终处理请求

相关推荐
我命由我123452 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
liulilittle2 小时前
C++ TAP(基于任务的异步编程模式)
服务器·开发语言·网络·c++·分布式·任务·tap
武子康4 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
caolib4 小时前
无需云服务器的内网穿透方案 -- cloudflare tunnel
运维·服务器·内网穿透·tunnel·cloudflared
誰能久伴不乏5 小时前
Linux系统调用概述与实现:深入浅出的解析
linux·运维·服务器
程序员学习随笔5 小时前
Linux进程深度解析(2):fork/exec写时拷贝性能优化与exit资源回收机制(进程创建和销毁)
linux·运维·服务器
-SGlow-5 小时前
MySQL相关概念和易错知识点(2)(表结构的操作、数据类型、约束)
linux·运维·服务器·数据库·mysql
代码改变世界ctw6 小时前
Linux内核设计与实现 - 第14章 块I/O层
linux·运维·服务器
Hello.Reader6 小时前
Go-Elasticsearch v9 安装与版本兼容性
elasticsearch·golang·jenkins
Dreams_l6 小时前
网络编程2(应用层协议,传输层协议)
运维·服务器·网络