Go-Zero微服务快速入门和最佳实践(一)
前言
并发编程和分布式微服务是我们Gopher升职加薪的关键。
毕竟Go基础很容易搞定,不管你是否有编程经验,都可以比较快速的入门Go语言进行简单项目的开发。
虽说好上手,但是想和别人拉开差距,提高自己的竞争力,搞懂分布式微服务和并发编程还是灰常重要的,这也是我今年更新文章的重点。
更文计划
我会更新一系列文章,陪你一起打怪升级,升职加薪!
本文的重点是:gozero快速入门,带你了解使用gozero开发项目的整体流程,以及一些技巧。
下一篇的重点是:带你使用gozero从头到尾实现一个经典功能的开发。
后续文章还会陆续更新我们在商业项目开发中积累的项目经验,比如:如何自定义goctl提高效率;并发编程实战;devops入门和实战等等......
Go-Zero
我想和大家说一下安利gozero的原因:
Go-zero在GitHub中已经有27.2K的star,集成了各种工程实践的 web 和 rpc 框架。通过弹性设计保障了大并发服务端的稳定性,经受了充分的实战检验。
官网
一个神奇的事情,如果你直接在百度搜索gozero,前几页的检索结果竟然都没有gozero官网,而是各个技术社区作者的分享。
我建议你先认真学习Go-Zero官网资料,扫清知识盲点,然后再跟着我去实践。
技巧 & 整体开发流程
为了吸引你继续读下去,我先分享技巧吧:“总结一句话:用好goctl开发就是快!”
先说技巧
goctl
- 能使用 goctl 的一定要用 goctl , goctl 是 go-zero 的内置脚手架,是提升开发效率的一大利器,可以一键生成代码、文档、部署 k8s yaml、dockerfile 等。
- gozero和go一样也强调“少即是多”的思想,能用goctl生成的千万不要手写,不仅开发速度慢;在团队开发中也难以保证统一的开发规范。
- 更重要的 goctl 支持我们自定义,后面我也会单独整理文章出来,和你分享如何结合你的项目,定制适合自己的goctl,进一步提高效率。
那具体goctl能生成什么呢?
- api
- grpc
- MySQL
- MongoDB
- 格式化
- 接口文档
- 还支持自定义
- 甚至还支持生成php、Android等代码
目录结构
先带你了解一下整体项目目录,这样你能更好的理解下文中的开发流程,这也是新手最头疼的地方,不知道从哪里着手开发。

- app 所有的微服务目录
- user
- cmd
- api api接口层 对外提供服务,可以用goctl生成
- desc
- xxx.api
- etc
- internal
- main.go
- desc
- rpc rpc层 内部服务 可以用goctl生成
- etc
- internal
- pb
- 服务包名 由goctl生成
- main.go
- api api接口层 对外提供服务,可以用goctl生成
- model model层 方便cmd目录中api和rpc调用
- cmd
- mqueue 等不同的服务
- user
- common 服务共享的常量、工具类等统一封装到这里
- deploy 项目部署配置等 比如Nginx配置
- go.mod
欢迎关注我,下期内容会共享GitHub开源地址出来。
Go-Zero微服务项目开发流程
当你把go和gozero的开发环境安装好之后,建议按照下面的顺序进行开发:
- 首先设计数据库和数据表
- 使用工具先生成model
- 先开发api层
- 再开发rpc层
- 在api层注册rpc服务,调用rpc方法,对外提供接口
- 生成接口文档
以上是整体的开发流程,请你按照这个顺序开发,会非常清晰。
详解
1)首先设计数据库和数据表
- 微服务进行服务拆分一个最好理解并且最基本的原则就是:每个服务对应一个单独的数据库。做到服务与服务之间的解耦,划清边界。
- 这就要求我们明确项目(服务)需求之后,做好表结构设计。
3.** 我们后续项目中用到的model、proto、甚至api层的结构体都可以通过工具根据数据库生成,所以数据库的设计至关重要!**
2)使用工具先生成model
使用goctl中的model命令生成即可:官网有讲,不再赘述:mysql 代码生成
为了进一步提高效率,我们对此进行了封装,方便我们更快更好的生成model,你也可以按照我们的方式来:
- 在项目根目录下创建了script目录,专门用于封装各种常用的脚本
- 在script目录下,我们创建了genModel目录,用于生成model文件。
- 封装genModel.sh脚本,内容如下:
#!/usr/bin/env bash
# 使用方法:
# ./genModel.sh 数据库名 表名称
# 比如:
# ./genModel.sh lottery lottery
# 再将./genModel下的生成的文件剪切到对应服务的model目录中即可
#生成的表名
tables=$2
#表生成的genmodel目录
modeldir=./genModel
# 数据库配置
host=127.0.0.1
port=3306
dbname=$1
username=root
passwd=xxxxx
echo "开始创建库:$dbname 的表:$2"
goctl model mysql datasource -url="${username}:${passwd}@tcp(${host}:${port})/${dbname}" -table="${tables}" -dir="${modeldir}" -cache=true --home="${template}" --style=goZero
这样,我们就可以很方便的使用./genModel.sh生成model,而不是需要拼接冗长的goctl命令
这个思路也同样适用你使用goctl生成其他的代码。
3)先开发api层
- 先定义xxx.api文件,可以参考 api demo 代码生成
- 使用goctl生成代码:
goctl api go -api main.api -dir ../ --style=goZero - 配置生成代码中的config目录以及yaml文件,弄清它们两者之间的联系
- 配置生成代码svc目录中的文件(比如jwt之类的中间件)
4)再开发rpc层
- 再告诉你一个提效利器 sql2pb,这个工具适合我们开发新服务时使用。见名之意,也就是可以把sql转成pb文件
- 注意:一旦我们的xx.proto文件有自定义修改之后,就不建议使用sql2pb了。如果不使用sql2pb的话,就直接修改xxx.proto文件
- 使用goctl生成pb.go文件:
goctl rpc protoc lottery.proto --go_out=../ --go-grpc_out=../ --zrpc_out=../ --style=goZero - 配置svc,注册model
- 编写logic,调用model,写业务代码
5)在api层注册rpc服务,调用rpc方法
- api层配置svc,注册rpc客户端
- 调用rpc方法
- 返回restful api
6)生成接口文档
- 注意:虽然goctl不直接支持生成swagger,但是goctl的插件支持。- goctl-swagger 通过 api 文件生成 swagger 文档
- 安装好goctl-swagger插件之后,我们就可以在api层的xxx.api同级目录下生成swagger了
- 参考命令如下:其中
main.api是我在api层的desc目录中定义的,我们也在同级目录执行goctl命令即可: goctl api plugin -plugin goctl-swagger="swagger -filename main.json" -api main.api -dir .

- 执行之后,就会出现如下图所示的main.json,这就是swagger文件

- 你可以直接使用swagger进行测试,也可以导入到其他工具中,比如我习惯导入到Apifox中,可以自动生成参数,方便我们进行测试:


总结
这篇文章带你梳理了使用gozero开发微服务项目的步骤和技巧,请你按我建议的方式开发和debug,会很清晰。
下一篇文章将通过一个完整的功能,带你跑通一个微服务的开发,包括:需求分析+表结构设计+api+rpc+goctl+apifox调试+细节处理。
如果你对Go语言或者微服务感兴趣,欢迎关注我的公众号:王中阳Go,也欢迎直接私信我。
Go-Zero微服务快速入门和最佳实践(一)的更多相关文章
- Consul 快速入门 - Kong最佳实践
Consul是什么 Consul是一个服务网格(微服务间的 TCP/IP,负责服务之间的网络调用.限流.熔断和监控)解决方案,它是一个一个分布式的,高度可用的系统,而且开发使用都很简便.它提供了一个功 ...
- 微服务(入门四):identityServer的简单使用(客户端授权)
IdentityServer简介(摘自Identity官网) IdentityServer是将符合规范的OpenID Connect和OAuth 2.0端点添加到任意ASP.NET核心应用程序的中间件 ...
- 微服务(入门二):netcore通过consul注册服务
基础准备 1.创建asp.net core Web 应用程序选择Api 2.appsettings.json 配置consul服务器地址,以及本机ip和端口号信息 { "Logging&qu ...
- 微服务(入门三):netcore ocelot api网关结合consul服务发现
简介 api网关是提供给外部调用的统一入口,类似于dns,所有的请求统一先到api网关,由api网关进行指定内网链接. ocelot是基于netcore开发的开源API网关项目,功能强大,使用方便,它 ...
- 微服务(入门一):netcore安装部署consul
环境准备 vs开发环境:vs2017 consul版本: 1.4.4 netcore版本:2.1 安裝Consul 1.从官网下载consul到本地,选择系统对应的版本进行下载到本地,下载地址:h ...
- 【SFA官方翻译】使用 Kubernetes、Spring Boot 2.0 和 Docker 的微服务快速指南
[SFA官方翻译]使用 Kubernetes.Spring Boot 2.0 和 Docker 的微服务快速指南 原创: Darren Luo SpringForAll社区 今天 原文链接:https ...
- AG-Admin微服务框架入门
AG-Admin微服务框架入门 @qq群:一群: 837736451 二群 169824183 一 概要介绍 AG-Admin后台地址:https://gitee.com/minull/ace-s ...
- 微服务(入门学习五):identityServer4+ocelot+consul实现简单客户端模式
简介 主要是采用identity Server4 和ocelot 加上consul 实现简单的客户端模式 开发准备 环境准备 下载并安装Consul具体请参考前几篇的内容 项目介绍 创建ocelot ...
- 异数OS 星星之火(三)--异数OS-织梦师云 微服务编写入门
. 异数OS 星星之火(三)–异数OS-织梦师云 微服务编写入门 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 6 ...
- spring cloud微服务快速教程之(七) Spring Cloud Alibaba--nacos(一)、服务注册发现
0.前言 什么是Spring Cloud Alibaba? Spring Cloud Alibaba 是阿里开源的,致力于提供微服务开发的一站式解决方案.此项目包含开发分布式应用微服务的必需组件,方便 ...
随机推荐
- BWO白鲸优化算法
白鲸算法 白鲸算法(BWO)是一种新的元启发式算法,是一种基于群体的算法,其灵感来自于白鲸的行为,包括游泳,猎物和鲸落.在BWO的数学模型中构建了勘探,开发和鲸落阶段,并在开发阶段利用Levy飞行 ...
- Boruta特征选择
Boruta特征选择 官方github地址:https://github.com/scikit-learn-contrib/boruta_py?tab=readme-ov-file 论文地址:http ...
- verilog之预编译
verilog之预编译 1.基本作用 预编译,就是在verilog进入编译器前的准备工作.一般是完成一些文件的调用,一些编译器的设置,一些参数的定义.一般使用include,define,timesc ...
- YOLOv4: 虽迟但到,大型调优现场,43mAP/83FPS | 论文速递
YOLOv4在速度和准确率上都十分优异,作者使用了大量的trick,论文也写得很扎实,在工程还是学术上都有十分重要的意义,既可以学习如何调参,也可以了解目标检测的trick. 来源:晓飞的算法工程 ...
- KingbaseES Json 系列二:Json对象函数
KingbaseES Json 系列二--Json对象函数(JSONB_BUILD_OBJECT,JSONB_OBJECT,JSON_BUILD_OBJECT,JSON_OBJECT) JSON 数据 ...
- WPF中动画教程(DoubleAnimation的基本使用)
实现效果 今天以一个交互式小球的例子跟大家分享一下wpf动画中DoubleAnimation的基本使用.该小球会移动到我们鼠标左键或右键点击的地方. 该示例的实现效果如下所示: 页面设计 xaml如下 ...
- #笛卡尔树,构造#洛谷 7726 天体探测仪(Astral Detector)
题目传送门 分析 考虑每个数字一定会影响一定的范围, 那么可以记录每个数影响的最长区间和产生的个数, 那么通过这个可以解方程求出对于这个最长区间这个数的所在位置, 可以发现它可以满足一个树形结构,直接 ...
- #李超线段树 or 斜率优化+CDQ分治#洛谷 4655 [CEOI2017]Building Bridges
题目 分析 列出方程即为\(dp[i]=\min\{dp[j]+(h[i]-h[j])^2+s[i-1]-s[j]\}\) \(dp[j]+h[j]^2-s[j]=2*h[i]*h[j]+dp[i]- ...
- Numpy结构化数组
Numpy结构化数组 Numpy的结构化数组和记录数组为复合的.异构的的数据提供了非常有效的存储. 结构化数组 In [1]: import numpy as np In [2]: name = [' ...
- c++ 暂停2秒,等待2秒
std::chrono::milliseconds stopTime(2000); std::this_thread::sleep_for(stopTime);