首页 > 其他分享 >Go-Zero技能提升:深度探究goctl的妙用,轻松应对微服务开发挑战!(三)

Go-Zero技能提升:深度探究goctl的妙用,轻松应对微服务开发挑战!(三)

时间:2024-05-07 10:22:22浏览次数:27  
标签:demo rpc 生成 goctl go Zero api Go

前言

有位同学在群里说:“Go-Zero官方文档太简洁了,对小白有点不友好。好奇你们是怎么学习的?项目是怎么封装的?有什么提高开发效率的技巧吗?”。

来来来,这期内容给你安排上,先教你goctl的妙用!

前两篇文章分享了 Go-Zero微服务快速入门和最佳实践(一)Go-Zero从0到1实现微服务项目开发(二)

本文将继续深入探讨Go-Zero的强大,并带你从0到1学会使用goctl。

通过本文的教程,你将能够亲自实践并完成goctl生成模板代码,进一步提升你的开发效率。

概述

goctl 是 go-zero 的内置脚手架,是提升开发效率的一大利器,可以一键生成代码、文档、部署 k8s yaml、dockerfile 等。

官方文档:goctl 安装 | go-zero Documentation

goctl安装

go install github.com/zeromicro/go-zero/tools/goctl@latest

验证

goctl --version

goctl使用实战

接下来和我使用goctl实现快速搭建api服务、rpc服务脚手架以及model代码的生成:

goctl api

goctl api是goctl中的核心模块之一,通过该命令可以快速生成一个api演示项目。

我们可以通过goctl api --help查看goctl api的所有指令。

goctl api --help

goctl api new

用于快速生成 Go HTTP 服务,需要指定服务名称,输出目录为当前工作目录。

  • 创建demo服务
goctl api new demo

这样在当前目录下就能够生成demo的api服务了。

下图为生成的项目目录结构:

  • 在logic下面的demologic.go编写逻辑
func (l *DemoLogic) Demo(req *types.Request) (resp *types.Response, err error) {
        // todo: add your logic here and delete this line
        return &types.Response{
                Message: "hello world",
        }, nil
}
  • 启动服务
# 跳到demo服务根目录
cd demo
# 启动服务(默认8888端口,可在etc/demo-api.yaml配置)
go run demo.go -f etc/demo-api.yaml
  • 访问服务
http://localhost:8888/from/you

至此一个Go-Zero的单体服务就完成啦。

goctl api doc

  • 根据 api 文件生成 markdown 文档。
  • -dir表示文档输出目录
goctl api doc -dir ./

goctl api go

根据api文件生成Go HTTP代码。-api表示api文件路径,-dir表示代码输出目录,--style表示输出文件和目录的命名风格格式化符号。

详情见 文件风格

--home表示自定义模板文件目录(自定义模板我们会在后续进行讲解,别忘了关注我)

  • 修改demo.api文件内容,增加一个post接口
type PostDemoReq {
        Message string `json:"message"`
}

type PostDemoResp {
        Message string `json:"message"`
}

service demo-api {
        @handler PostDemoHandler
        post /postDemo(PostDemoReq) returns (PostDemoResp)
}
  • 重新生成代码
cd demo
goctl api go -api demo.api -dir . -style gozero

会生成这两个文件

  • 修改logic逻辑
func (l *PostDemoLogic) PostDemo(req *types.PostDemoReq) (resp *types.PostDemoResp, err error) {
        // todo: add your logic here and delete this line
        return &types.PostDemoResp{
                Message: req.Message,
        }, nil
}
  • 重新启动服务
go run demo.go -f etc/demo-api.yaml
  • 使用ApiFox发起请求

至此我们已经学会怎么创建单体服务,并创建get和post接口啦,已经能应对大多数单体项目的开发需求。

当然我们做接口测试的时候一个个手动输入到ApiFox十分麻烦,这时候我们可以借助goctl api的插件生成swagger导入到ApiFox当中。

生成swagger文档

goctl-swagger 用于一键生成 api 的 swagger 文档

安装goctl-swagger

  1. 编译goctl-swagger插件
GOPROXY=https://goproxy.cn/,direct go install github.com/zeromicro/goctl-swagger@latest
  1. 配置环境
    将$GOPATH/bin中的goctl-swagger添加到环境变量

使用goctl-swagger生成swagger.json

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

生成如下文档

  1. 导入ApiFox

  1. 导入demo.json

  1. 配置开发环境路由前缀

6.进行接口测试

goctl rpc

goctl rpc 是 goctl 中的核心模块之一,其可以通过 .proto 文件一键快速生成一个 rpc 服务,如果仅仅是启动一个 go-zero 的 rpc 演示项目, 你甚至都不用编码,就可以完成一个 rpc 服务开发及正常运行。

goctl rpc new

  • 快速生成一个 rpc 服务,其接收一个终端参数来指定服务名称。
goctl rpc new RPCDemo
  • 生成项目目录结构如下图所示

goctl rpc -o

用于快速生成一个 proto 模板文件,其接收一个 proto 文件名称参数。

goctl rpc -o demoProto.proto
  • 会在相同目录下生成proto模板文件

goctl rpc protoc

  • 根据 protobufer 文件生成 rpc 服务。
cd .\RPCDemo
goctl rpc protoc RPCDemo.proto --go_out=./ --go-grpc_out=./  --zrpc_out=./ --style=goZero

  • 由于没安装Etcd,因此我们把etc/rpcdemo.yaml的Etcd相关配置注释掉

  • 在logic/pingLogic.go修改为如下逻辑
func (l *PingLogic) Ping(in *rPCDemo.Request) (*rPCDemo.Response, error) {
        // todo: add your logic here and delete this line

        return &rPCDemo.Response{
                Pong: in.Ping,
        }, nil
}
  • 运行服务
cd .\RPCDemo
go run .
  • 项目默认跑在8080端口,可根据需求修改

将proto导入ApiFox进行测试

  • 新建项目

  • 新建gRPC项目

  • 添加项目中的RPCDemo.proto

  • 右上角选择环境

  • 测试接口

  • 至此,我们已经能够根据proto文件生成gRPC接口并进行测试啦。

goctl model

goctl model 为 goctl 提供的数据库模型代码生成指令,目前支持 MySQL、PostgreSQL、Mongo 的代码生成,MySQL 支持从 sql 文件和数据库连接两种方式生成,PostgreSQL 仅支持从数据库连接生成。

本文主要以MySQL为数据表来源生成代码,其他数据库类似。

  • 创建genModel文件夹

  • 生成代码。对应位置的MySQL连接参数改为你的即可。-table表示你的表名,-dir表示生成代码的输出目录 -cache表示是否生成带缓存的代码
goctl model mysql datasource -url="root:PXDN93VRKUm8TeE7@tcp(127.0.0.1:33069)/lottery" -table="lottery" -dir="./genModel" -cache=true --style=goZero
  • 显示Done.说明成功。

至此我们成功使用goctl model根据数据库中的数据表生成了model 代码。

后续通过修改模板代码我们可以实现生成代码的定制化需求,记得关注我!

总结

这篇文章相比官方文档,详细介绍了如何使用Go-Zero的goctl工具进行api服务、rpc服务和model层代码的生成,以及生成swagger文件,并提供了Demo进行实际操作。

我将继续更新Go-Zero系列文章,如果你对Go语言或者微服务感兴趣,欢迎关注我,也欢迎直接私信我。

微信:wangzhongyang1993

标签:demo,rpc,生成,goctl,go,Zero,api,Go
From: https://www.cnblogs.com/wangzhongyang/p/18176657

相关文章

  • Django高级表单处理与验证实战
    title:Django高级表单处理与验证实战date:2024/5/620:47:15updated:2024/5/620:47:15categories:后端开发tags:Django表单验证逻辑模板渲染安全措施表单测试重定向管理最佳实践引言:在Web应用开发中,表单是用户与应用之间进行交互的重要方式,它承载着用户......
  • 【go】【mongo】
    @目录写在前面[install][connection]createmanycreatedeleteonedeletemanyupdateoneupdatemanyfindonefindmanyNextfindmanyAllfindmanyfilter建立索引查询单条索引查询全部索引创建索引查询全部索引分页索引正则表达索引检索mongobson动态数据难度参考资料基础/......
  • 跨域请求解决办法(Django)
    跨域请求解决办法(Django)1.安装第三方扩展:pipinstalldjango-cors-headerssettings.py里面操作2.添加应用:INSTALLED_APPS=(...'corsheaders',...)3.第三步,添加中间件,注意放在第一条,第一时间进行处理:MIDDLEWARE=['corsheaders.middleware.......
  • 【go】【Elasticsearch】
    @目录写在前面[install][connection][low-level]index[createindex][updateindex][indexingdocuments][deleteindex]document[insertdocuments][searchdocuments][updatedocument][deletedocument][full-type][connection][common]index[createindex][deleteindex][upda......
  • django 表单
    实现方式一:将具体的search操作放到views首先,在app下面新建一个forms.py文件,用于定义表单。创建了一个名为"SearchCaseForm"的表单,并定义了一个名为“case_name”的CharFieldfromdjangoimportformsclassSearchCaseForm(forms.Form): case_name=forms.CharField()创建......
  • golang 获得一个结构体的字节大小
    golang的内存占用是如何构成的呢?unsafe.SizeOf()转载:如何在Go中获取变量的内存大小?--CSDN问答如果传递一个未初始化的变量,unsafe.Sizeof()与reflect.Type.Size()将只返回传递的变量的类型的大小,并不递归地遍历数据结构并增加所指向变量的大小。切片是一个相对简单的结构体st......
  • 我用 GitHub 9.8k 的 Go 语言 2D 游戏引擎写了个游戏
    前言hi,大家好,这里是白泽。今天给大家分享一个GitHub......
  • [992] Remove holes within polygons in a shapefile
    Toremoveholeswithinpolygonsinashapefile,youcanusethegeopandaslibraryinPython.Here'showyoucandoit:importgeopandasasgpd#Readtheshapefilegdf=gpd.read_file('path_to_shapefile.shp')#Removeholeswithinpolygon......
  • uwsgi+nginx启动Django静态文件设置
    总体思路:设置好STATIC_ROOT后使用pythonmanager.pycollectstatic命令将django下所有的静态文件搜集到STATIC_ROOT下,然后让nginx的static路由指向这个目录1.Django的settings.py文件中设置如下STATIC_URL='/static/'STATIC_ROOT=os.path.join(BASE_DIR,'staticfiles'......
  • 用Golang做一个永久阻塞,有哪些小技巧 ?
    用Golang做一个永久阻塞,有哪些小技巧?磊丰 Go语言圈 2024-05-0608:30 广东 听全文Go语言圈Go语言开发者的学习好助手,分享Go语言知识,技术技巧,学习与交流Go语言开发经验,互动才有助于技术的提升,每天5分钟,助你GO语言技术快乐成长159篇原创内容公众号......