并发编程和分布式微服务是我们Gopher升职加薪的关键。
毕竟Go基础很容易搞定,不管你是否有编程经验,都可以比较快速的入门Go语言进行简单项目的开发。
虽说好上手,但是想和别人拉开差距,提高自己的竞争力,搞懂分布式微服务和并发编程还是灰常重要的,这也是我今年更新文章的重点。
我会更新一系列文章,陪你一起打怪升级,升职加薪!
本文的重点是:gozero快速入门,带你了解使用gozero开发项目的整体流程,以及一些技巧。
下一篇的重点是:带你使用gozero从头到尾实现一个经典功能的开发。
后续文章还会陆续更新我们在商业项目开发中积累的项目经验,比如:如何自定义goctl提高效率;并发编程实战;devops入门和实战等等......
我想和大家说一下安利gozero的原因:
Go-zero 在GitHub中已经有27.2K的star,集成了各种工程实践的 web 和 rpc 框架。通过弹性设计保障了大并发服务端的稳定性,经受了充分的实战检验。
一个神奇的事情,如果你直接在百度搜索gozero,前几页的检索结果竟然都没有gozero官网,而是各个技术社区作者的分享。
我建议你先认真学习Go-Zero官网资料,扫清知识盲点,然后再跟着我去实践。
为了吸引你继续读下去,我先分享技巧吧:“总结一句话:用好goctl开发就是快!”
先带你了解一下整体项目目录,这样你能更好的理解下文中的开发流程,这也是新手最头疼的地方,不知道从哪里着手开发。
欢迎关注我,下期内容会共享GitHub开源地址出来。
当你把go和gozero的开发环境安装好之后,建议按照下面的顺序进行开发:
以上是整体的开发流程,请你按照这个顺序开发,会非常清晰。
使用goctl中的model命令生成即可:官网有讲,不再赘述:mysql 代码生成
为了进一步提高效率,我们对此进行了封装,方便我们更快更好的生成model,你也可以按照我们的方式来:
#!/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生成其他的代码。
goctl api go -api main.api -dir ../ --style=goZero
goctl rpc protoc lottery.proto --go_out=../ --go-grpc_out=../ --zrpc_out=../ --style=goZero
main.api
是我在api层的desc目录中定义的,我们也在同级目录执行goctl命令即可:goctl api plugin -plugin goctl-swagger="swagger -filename main.json" -api main.api -dir .
这篇文章带你梳理了使用gozero开发微服务项目的步骤和技巧,请你按我建议的方式开发和debug,会很清晰。
下一篇文章将通过一个完整的功能,带你跑通一个微服务的开发,包括:需求分析+表结构设计+api+rpc+goctl+apifox调试+细节处理。
如果你对Go语言或者微服务感兴趣,欢迎关注我的公众号:王中阳Go,也欢迎直接私信我。
gozero如何自定义goctl?本文详解和实战,通过本文你将了解goctl的妙用,提高你的开发效率。介绍如何使用goctl工具实现模板定制化,并根据实际项目业务需求进行模板定制化实现。