这篇文章给大家介绍利用go-zero怎么开发一个线上项目,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
golang中不提倡多余的变量。gopher都知道,golang变量不使用,直接会报编译错误!这让我刮目相看!在我看来,是把严谨提升了一个阶段,只要你是gopher,就会强迫你变得严谨。golang变量这个属性,秉承了golang的设计理念,严谨这个理念贯穿了golang的各处。
曾经有一个CTO跟我说,定义的每一个变量、每一个字段,都应该有它的作用。多余的代码,多余的变量,多余的字段,除了误导别人,弄脏代码,别无他用。我,表示绝对赞同!
golang性能好
单单靠golang的简单、严谨,当然上不了程序员的舞台。可恨的是,golang性能还很好!比C++要差点,但是就web应用的并发、资源占用来说,比java、python、php、nodejs都是要优秀的。具体数据大家上网一搜比比皆是。一个语法简单、性能又好、入门只需一周的语言,反正我是入坑了。
有段时间,我太热爱golang了导致认为golang可以做任何事情。不过慢慢,我理性了。做web应用,首选golang。做数据分析、爬虫、图片处理还是python吧。但要是有人说用java去写web后台,cms类型还好,要是面向市场用户的,spring boot那套,spring cloud那套,我觉得,远远远远远远远比不上用golang相关的框架,java还是去做那些单体应用吧。
golang轻量
golang还有另外一个属性,就是“轻”,有多轻?对比一下java的jvm那套容器,你就知道有多轻了。几行代码就能实现一个原生web服务了,docker这个跨时代的产物就是golang写的。etcd这个分布式基石也是golang写的,云原生这个跨时代的名词,很多组件都是golang贡献的。“微服务”这个面试必问的名词,golang可以对它做最好的诠释。
go-zero一见如故
后来我进入了一家直播公司,刚好遇到了公司的波动,让我有了停下来自省的时间。其间,喜欢逛逛github,稍有目的去逛一下golang的开源项目。比如gin,iris,go-micro,go-zero,sentinel-golang,gin-vue-admin等等等啦。一开始,go-zero并不是特别吸引我,可能是博客/github布局不够亮眼吧。但是,当我哪天沉下来看go-zero的文档,开始敲起第一个goctl的命令,我好像,好像!已经停不下来。
go-zero,用起来,真的很舒服!
我刚在游戏平台公司实习转正的时候,也是可以带一两个实习生的。当时我就有个想法,“如何让员工都敲出规范、高效的代码”。当时想了下用go-template,但是因为学艺未精,推进不下去。时隔几年,当我接触到go-zero的goctl后,发现,居然有大佬实现了当年我的想法!虽然我技术不大行,但是梦想还是要有的,go-zero对我来说太亲切了。搞!肝!!
一周时间,过完了go-zero的github文档以及语雀文档,中途也自己练手了几个demo。可真是越敲越舒服。迫不及待地用想找个实际项目投入生产!果真不久有个机会来了,公司想做一个简单的app做投放调研,允许重新搭建一个新的后台web项目,我!go-zero!义不容辞,开干。又花了两周时间,写完了一个后台web服务,里面有下面板块
用户板块
咨询板块
报告板块
支付板块
广告板块
截个图看看我的项目结构,由于还是公司项目,暂时不会开源啦,不过凡是go-zeroer都能看懂
简单说明一下:
api目录,就是http1.1的web服务,跟前端对接
rpc目录,rpc服务,基本和api一一对应
enum目录,枚举目录,里面存放的是各种各样的枚举值,我把它提到一等公民了
model目录,数据库model,目前都是用goctl根据mysql生成的model
utils目录,这里主要存放我的一些小工具包,例如int/string/time的一些操作,参考了下go-zero的命名方法,子目录一般会以x结尾,例如intx,timex,stringx等等
worker目录,主要是做一些消费者模型的消费者,例如kafka的消费者,google订阅通知的消费者等等
ws目录,存放websocket相关的服务,例如私聊
感谢下go-zero,让我对项目的组织结构有了一个简单的标准。worker、ws等服务,以前的项目结构都杂乱无章,目前都是参考go-zero生成api的目录结构了: