go-zero学习及使用中遇到的问题
迪丽瓦拉
2025-05-31 14:12:55
0

go-zero学习及使用中遇到的问题

  • 1 go-zero入门--单体服务demo
    • 1.1 单体服务【官方示例】
      • 1.1.1 创建greet服务
      • 1.1.2 目录结构
      • 1.1.3 编写逻辑
      • 1.1.4 启动并访问服务
    • 1.2 修改GET入参
      • 1.2.1 去除options限制的入参值
      • 1.2.2 重启并访问服务
    • 1.3 添加post请求【新增方法】
      • 1.3.1 修改 `greet/greet.api` 文件
      • 1.3.2 重新生成代码
      • 1.3.3 修改`logic/greetpostlogic.go`文件
      • 1.3.4 重启并访问服务
  • 2 go-zero入门--微服务demo
    • 2.1 新建微服务
    • 2.2 API接口模块添加后端模块
  • 3 go-zero 框架下swagger使用
  • 4 goctl 相关命令整理
    • 4.1 .api生成swagger的命令
    • 4.2 .api生成api模块的命令
    • 4.3 .proto生成rpc模块的命令
    • 4.4 sql文件生成model的命令
    • 4.5 docker启动swagger的命令
  • #####################################################
  • 1 field name set
  • 2 greet.api line 25:1 expecting 'http method', found input '@handler'

1 go-zero入门–单体服务demo

参考1:go-zero入门–单体服务demo
推荐先阅读参考1。

1.1 单体服务【官方示例】

1.1.1 创建greet服务

goctl api new greet

1.1.2 目录结构

.
├── go.mod
├── go.sum
├── etc
│   └── greet-api.yaml
├── greet.api
├── greet.go
└── internal├── config│   └── config.go├── handler│   ├── greethandler.go│   └── routes.go├── logic│   └── greetlogic.go├── svc│   └── servicecontext.go└── types└── types.go

1.1.3 编写逻辑

greet/internal/logic/greetlogic.go

func (l *GreetLogic) Greet(req *types.Request) (resp *types.Response, err error) {// todo: add your logic here and delete this linereturn &types.Response{Message: "Hello go-zero:" + req.Name,}, nil
}

1.1.4 启动并访问服务

启动:在greet目录下执行:

go run greet.go -f etc/greet-api.yaml

访问:http://localhost:8888/from/you

注意

  1. 端口的设置是在etc/greet-api.yaml中。
  2. 访问地址中的最后资源只能是youme,否则会报错,这个是在 greet.api 中配置的。

1.2 修改GET入参

1.2.1 去除options限制的入参值

  1. 修改greet/greet.api文件
type Request {Name string `path:"name,options=you|me"`
}

改为

type Request {Name string `path:"name"`
}
  1. 重新生成代码
cd ~/go-zero-single_demo/greet
goctl api go -api greet.api -dir . -style gozero

注意:执行完goctl后会重新生成以下文件,如果没有新增的东西,可能会看不出来,具体可看执行日志。

  1. types/types.go
  2. handler/的文件
  3. logic/的文件

1.2.2 重启并访问服务

重启:

go run greet.go -f etc/greet-api.yaml

访问:http://localhost:8888/from/乾冠

1.3 添加post请求【新增方法】

1.3.1 修改 greet/greet.api 文件

注意:service里的api必须是handler和访问接口一一对应,放在一起,否则会报错。可看 2 greet.api line 25:1 expecting 'http method', found input '@handler'

type Request {Name string `path:"name"`
}type Response {Message string `json:"message"`
}//1、post 方法的请求内容
type RequestJson {Name string `json:"name"`
}service greet-api {@handler GreetHandlerget /from/:name(Request) returns (Response)//2、post 方法的处理器@handler GreetPostHandlerpost /from/:name(RequestJson) returns (Response)
}

1.3.2 重新生成代码

cd ~/go-zero-single_demo/greet
goctl api go -api greet.api -dir . -style gozero

注意:执行完goctl后会重新生成以下文件。

  1. types/types.go
  2. handler/routes.go:增加了的访问接口的路由。

同时会新增以下文件:

  1. handler/greetposthandler.go
  2. logic/greetpostlogic.go

1.3.3 修改logic/greetpostlogic.go文件

func (l *GreetPostLogic) GreetPost(req *types.RequestJson) (resp *types.Response, err error) {// todo: add your logic here and delete this linereturn &types.Response{Message: "Hello go-zero name:" + req.Name,}, nil
}

1.3.4 重启并访问服务

重启:

cd ~/go-zero-single_demo/greet
go run greet.go -f etc/greet-api.yaml

POST方式访问:

POST http://127.0.0.1:8888/from/乾冠 HTTP/1.1
Content-Type: application/json
{"name":"post 乾冠"
}

返回结果:

{"message": "Hello go-zero name:post 乾冠"
}

2 go-zero入门–微服务demo

2.1 新建微服务

参考1:go-zero入门–微服务demo

2.2 API接口模块添加后端模块

API接口模块添加后端模块需要改动3个地方。

  1. etc/xxx.yaml
    主要是配置后端模块的Etcd服务发现。
    示例:
Name: order
Host: 0.0.0.0
Port: 8889
UserRpc:Etcd:Hosts:- 192.168.13.3:2379Key: user.rpc
  1. internal/config/config.go
    主要是配置后端调用的模块RPC。
    示例:
package configimport ("github.com/zeromicro/go-zero/rest""github.com/zeromicro/go-zero/zrpc"
)type Config struct {rest.RestConfUserRpc zrpc.RpcClientConf
}
  1. internal/svc/servicecontext.go
    主要是将 2 配置的后端服务模块加入到 API接口模块的ServiceContext中。
    示例:
package svcimport ("github.com/zeromicro/go-zero/zrpc""go-zero-micro-demo/mall/order/api/internal/config""go-zero-micro-demo/mall/user/rpc/userclient"
)type ServiceContext struct {Config  config.ConfigUserRpc userclient.User
}func NewServiceContext(c config.Config) *ServiceContext {return &ServiceContext{Config:  c,UserRpc: userclient.NewUser(zrpc.MustNewClient(c.UserRpc)),}
}

3 go-zero 框架下swagger使用

参考1:goctl-swagger
看参考1 中README.md,里面有下载及使用的操作流程。

生成swagger.json文件的命令:

goctl api plugin -plugin goctl-swagger="swagger -filename user.json" -api user.api -dir .

4 goctl 相关命令整理

4.1 .api生成swagger的命令

示例:

goctl api plugin -plugin goctl-swagger="swagger -filename tracksourcetask.json" -api tracksourcetask.api -dir .

4.2 .api生成api模块的命令

示例:

goctl api go -api ./doc/admin.api -dir .

4.3 .proto生成rpc模块的命令

示例:

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

4.4 sql文件生成model的命令

goctl model mysql ddl -src="./rpc/doc/sql/appsystem/dsms*.sql" -dir="./rpc/model/appsystemodel"

4.5 docker启动swagger的命令

docker run -d -p 9981:8080 --name=swagger-tracksourcetask -v /root/doc:/tmp -e SWAGGER_FILE=/tmp/tracksourcetask-v2.json swaggerapi/swagger-editor

#####################################################


1 field name set

要修改设置结构体的变量,应该在greet.api中,然后再使用下面的命令生成对应的结构体和业务类。

goctl api go -api greet.api -dir . -style gozero

2 greet.api line 25:1 expecting ‘http method’, found input ‘@handler’

源码:

service greet-api {@handler GreetHandler@handler GreetCustomizedHandlerget /from/:name/:age(Request) returns (Response)get /customized/:address/:phone(CustomizedRequest) returns (CustomizedResponse)
}

错误写法:一个@handler对应一个api,但是两者需要紧挨着。@handler@handler放一块、apiapi放一块的写法是错误的。

正确写法:

service greet-api {@handler GreetHandlerget /from/:name/:age(Request) returns (Response)@handler GreetPostHandlerpost /from/:name(RequestJson) returns (Response)
}

相关内容

热门资讯

linux入门---制作进度条 了解缓冲区 我们首先来看看下面的操作: 我们首先创建了一个文件并在这个文件里面添加了...
C++ 机房预约系统(六):学... 8、 学生模块 8.1 学生子菜单、登录和注销 实现步骤: 在Student.cpp的...
A.机器学习入门算法(三):基... 机器学习算法(三):K近邻(k-nearest neigh...
数字温湿度传感器DHT11模块... 模块实例https://blog.csdn.net/qq_38393591/article/deta...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
Redis 所有支持的数据结构... Redis 是一种开源的基于键值对存储的 NoSQL 数据库,支持多种数据结构。以下是...
win下pytorch安装—c... 安装目录一、cuda安装1.1、cuda版本选择1.2、下载安装二、cudnn安装三、pytorch...
MySQL基础-多表查询 文章目录MySQL基础-多表查询一、案例及引入1、基础概念2、笛卡尔积的理解二、多表查询的分类1、等...
keil调试专题篇 调试的前提是需要连接调试器比如STLINK。 然后点击菜单或者快捷图标均可进入调试模式。 如果前面...
MATLAB | 全网最详细网... 一篇超超超长,超超超全面网络图绘制教程,本篇基本能讲清楚所有绘制要点&#...
IHome主页 - 让你的浏览... 随着互联网的发展,人们越来越离不开浏览器了。每天上班、学习、娱乐,浏览器...
TCP 协议 一、TCP 协议概念 TCP即传输控制协议(Transmission Control ...
营业执照的经营范围有哪些 营业执照的经营范围有哪些 经营范围是指企业可以从事的生产经营与服务项目,是进行公司注册...
C++ 可变体(variant... 一、可变体(variant) 基础用法 Union的问题: 无法知道当前使用的类型是什...
血压计语音芯片,电子医疗设备声... 语音电子血压计是带有语音提示功能的电子血压计,测量前至测量结果全程语音播报࿰...
MySQL OCP888题解0... 文章目录1、原题1.1、英文原题1.2、答案2、题目解析2.1、题干解析2.2、选项解析3、知识点3...
【2023-Pytorch-检... (肆十二想说的一些话)Yolo这个系列我们已经更新了大概一年的时间,现在基本的流程也走走通了,包含数...
实战项目:保险行业用户分类 这里写目录标题1、项目介绍1.1 行业背景1.2 数据介绍2、代码实现导入数据探索数据处理列标签名异...
记录--我在前端干工地(thr... 这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前段时间接触了Th...
43 openEuler搭建A... 文章目录43 openEuler搭建Apache服务器-配置文件说明和管理模块43.1 配置文件说明...