如何使用go-zero開(kāi)發(fā)線上項(xiàng)目
前言
說(shuō)在最前面,我是一個(gè)外表謙讓?zhuān)瑑?nèi)心狂熱,外表斯文,內(nèi)心貪玩的一個(gè)普通人。我的職業(yè)是程序員,是一個(gè)golang語(yǔ)言愛(ài)好者,一半是因?yàn)間olang好用,一半是因?yàn)槠渌Z(yǔ)言學(xué)不好。我是從phper轉(zhuǎn)為gopher的,寫(xiě)php的時(shí)候我認(rèn)識(shí)了互聯(lián)網(wǎng)軟件,寫(xiě)go的時(shí)候感覺(jué)自己終于在編程。
初見(jiàn)golang
我大學(xué)專(zhuān)業(yè)是軟件。第一門(mén)編程語(yǔ)言是C++,知道了指針,知道了加減乘除,知道了編程去控制軟硬件。后來(lái)選修了java,被ssh框架戲耍了一個(gè)暑假。再后來(lái)進(jìn)入了一個(gè)社團(tuán)技術(shù)部,再被html/css/js打擊了自己信心。高中年級(jí)總能排名前幾的我,真的開(kāi)始懷疑人生了。再再后來(lái)進(jìn)入了一家游戲平臺(tái)公司,開(kāi)始了php的編寫(xiě)之旅?!班?!”,終于,我知道了什么是互聯(lián)網(wǎng),折磨我的編程語(yǔ)言c++/java/html/css,原來(lái)還可以這樣子“變現(xiàn)”。
剛?cè)腴T(mén)了互聯(lián)網(wǎng)的我,心里是真的喜悅。不過(guò),重復(fù)的東西做多了,總是少不了厭倦。每天都是寫(xiě)php,都是那些增刪改查,都是修改數(shù)據(jù)表,增加字段,增加臨時(shí)表。真的,開(kāi)始膩了?!奥?tīng)說(shuō)最新公司在用新的編程語(yǔ)言golang”,我,想去試試。但,我不敢,心里有對(duì)自己和對(duì)golang的懷疑,因此我不是第一個(gè)去拜師的。當(dāng)golang在公司流行了兩個(gè)月,我的leader讓我去用一下golang。終于,我?guī)煶鲇忻?。淺嘗了一周的golang之后,我??!發(fā)現(xiàn)!!
- golang是有指針的,這不是大學(xué)熟悉的C++那樣的指針嗎
- golang是編譯語(yǔ)言,原來(lái)客戶端的“打包、打包”,原來(lái)是這么一回事
- golang是可以做定時(shí)器的,換用php該怎么搞啊?很麻煩的吧。
- golang不用寫(xiě)分號(hào),不用寫(xiě)括號(hào),看起來(lái)很簡(jiǎn)單啊,性能又很好??!
- golang原生支持web服務(wù),原來(lái)不用nginx也可以起一個(gè)web服務(wù)啊
- .......還有很多很多
喜歡golang
嘗試了golang之后,我發(fā)現(xiàn)我喜歡上了golang了。
golang嚴(yán)謹(jǐn)
golang中不提倡多余的變量。gopher都知道,golang變量不使用,直接會(huì)報(bào)編譯錯(cuò)誤!這讓我刮目相看!在我看來(lái),是把嚴(yán)謹(jǐn)提升了一個(gè)階段,只要你是gopher,就會(huì)強(qiáng)迫你變得嚴(yán)謹(jǐn)。golang變量這個(gè)屬性,秉承了golang的設(shè)計(jì)理念,嚴(yán)謹(jǐn)這個(gè)理念貫穿了golang的各處。
曾經(jīng)有一個(gè)CTO跟我說(shuō),定義的每一個(gè)變量、每一個(gè)字段,都應(yīng)該有它的作用。多余的代碼,多余的變量,多余的字段,除了誤導(dǎo)別人,弄臟代碼,別無(wú)他用。我,表示絕對(duì)贊同!
golang性能好
單單靠golang的簡(jiǎn)單、嚴(yán)謹(jǐn),當(dāng)然上不了程序員的舞臺(tái)。可恨的是,golang性能還很好!比C++要差點(diǎn),但是就web應(yīng)用的并發(fā)、資源占用來(lái)說(shuō),比java、python、php、nodejs都是要優(yōu)秀的。具體數(shù)據(jù)大家上網(wǎng)一搜比比皆是。一個(gè)語(yǔ)法簡(jiǎn)單、性能又好、入門(mén)只需一周的語(yǔ)言,反正我是入坑了。
有段時(shí)間,我太熱愛(ài)golang了導(dǎo)致認(rèn)為golang可以做任何事情。不過(guò)慢慢,我理性了。做web應(yīng)用,首選golang。做數(shù)據(jù)分析、爬蟲(chóng)、圖片處理還是python吧。但要是有人說(shuō)用java去寫(xiě)web后臺(tái),cms類(lèi)型還好,要是面向市場(chǎng)用戶的,spring boot那套,spring cloud那套,我覺(jué)得,遠(yuǎn)遠(yuǎn)遠(yuǎn)遠(yuǎn)遠(yuǎn)遠(yuǎn)遠(yuǎn)比不上用golang相關(guān)的框架,java還是去做那些單體應(yīng)用吧。
golang輕量
golang還有另外一個(gè)屬性,就是“輕”,有多輕?對(duì)比一下java的jvm那套容器,你就知道有多輕了。幾行代碼就能實(shí)現(xiàn)一個(gè)原生web服務(wù)了,docker這個(gè)跨時(shí)代的產(chǎn)物就是golang寫(xiě)的。etcd這個(gè)分布式基石也是golang寫(xiě)的,云原生這個(gè)跨時(shí)代的名詞,很多組件都是golang貢獻(xiàn)的。“微服務(wù)”這個(gè)面試必問(wèn)的名詞,golang可以對(duì)它做最好的詮釋。
go-zero一見(jiàn)如故
后來(lái)我進(jìn)入了一家直播公司,剛好遇到了公司的波動(dòng),讓我有了停下來(lái)自省的時(shí)間。其間,喜歡逛逛github,稍有目的去逛一下golang的開(kāi)源項(xiàng)目。比如gin,iris,go-micro,go-zero,sentinel-golang,gin-vue-admin等等等啦。一開(kāi)始,go-zero并不是特別吸引我,可能是博客/github布局不夠亮眼吧。但是,當(dāng)我哪天沉下來(lái)看go-zero的文檔,開(kāi)始敲起第一個(gè)goctl的命令,我好像,好像!已經(jīng)停不下來(lái)。
go-zero,用起來(lái),真的很舒服!
我剛在游戲平臺(tái)公司實(shí)習(xí)轉(zhuǎn)正的時(shí)候,也是可以帶一兩個(gè)實(shí)習(xí)生的。當(dāng)時(shí)我就有個(gè)想法,“如何讓員工都敲出規(guī)范、高效的代碼”。當(dāng)時(shí)想了下用go-template,但是因?yàn)閷W(xué)藝未精,推進(jìn)不下去。時(shí)隔幾年,當(dāng)我接觸到go-zero的goctl后,發(fā)現(xiàn),居然有大佬實(shí)現(xiàn)了當(dāng)年我的想法!雖然我技術(shù)不大行,但是夢(mèng)想還是要有的,go-zero對(duì)我來(lái)說(shuō)太親切了。搞!肝!!
一周時(shí)間,過(guò)完了go-zero的github文檔以及語(yǔ)雀文檔,中途也自己練手了幾個(gè)demo??烧媸窃角迷绞娣?。迫不及待地用想找個(gè)實(shí)際項(xiàng)目投入生產(chǎn)!果真不久有個(gè)機(jī)會(huì)來(lái)了,公司想做一個(gè)簡(jiǎn)單的app做投放調(diào)研,允許重新搭建一個(gè)新的后臺(tái)web項(xiàng)目,我!go-zero!義不容辭,開(kāi)干。又花了兩周時(shí)間,寫(xiě)完了一個(gè)后臺(tái)web服務(wù),里面有下面板塊
- 用戶板塊
- 咨詢板塊
- 報(bào)告板塊
- 支付板塊
- 廣告板塊
截個(gè)圖看看我的項(xiàng)目結(jié)構(gòu),由于還是公司項(xiàng)目,暫時(shí)不會(huì)開(kāi)源啦,不過(guò)凡是go-zeroer都能看懂
簡(jiǎn)單說(shuō)明一下:
- api目錄,就是http1.1的web服務(wù),跟前端對(duì)接
- rpc目錄,rpc服務(wù),基本和api一一對(duì)應(yīng)
- enum目錄,枚舉目錄,里面存放的是各種各樣的枚舉值,我把它提到一等公民了
- model目錄,數(shù)據(jù)庫(kù)model,目前都是用goctl根據(jù)mysql生成的model
- utils目錄,這里主要存放我的一些小工具包,例如int/string/time的一些操作,參考了下go-zero的命名方法,子目錄一般會(huì)以x結(jié)尾,例如intx,timex,stringx等等
- worker目錄,主要是做一些消費(fèi)者模型的消費(fèi)者,例如kafka的消費(fèi)者,google訂閱通知的消費(fèi)者等等
- ws目錄,存放websocket相關(guān)的服務(wù),例如私聊
感謝下go-zero,讓我對(duì)項(xiàng)目的組織結(jié)構(gòu)有了一個(gè)簡(jiǎn)單的標(biāo)準(zhǔn)。worker、ws等服務(wù),以前的項(xiàng)目結(jié)構(gòu)都雜亂無(wú)章,目前都是參考go-zero生成api的目錄結(jié)構(gòu)了:
- main.go入口
- etc存放配置,
- internal內(nèi)部目錄
config:配置
handler:處理器
logic:邏輯處理
types:中間類(lèi)型
go-zero理念
“工具大于約定和文檔”,這,就是go-zero的理念。我,表示極度贊同!
go-zero的最大特點(diǎn),就是goctl。goctl是什么?就是能根據(jù)協(xié)議文檔,生成代碼的一個(gè)神器。例如
- 定了a.proto文件,goctl rpc proto a.proto -dir . 即可生成rpc服務(wù)
- 定了b.sql文件,goctl model mysql ddl -c -src b.sql -dir . 即可生成模板model文件
- 定了c.api文件(go-zero出品),goctl api go -api ad-api.api -dir . 即可生成api文件
再配合上golang的jb IDE,代碼提醒,代碼格式化,一個(gè)go-zero的生態(tài),就出來(lái)了。一個(gè)字:舒服!!
go-zero小工具
除了goctl神器,另外一個(gè)讓我拜服的點(diǎn)是,go-zero的一些小工具。
流數(shù)據(jù)處理利器:fx。聽(tīng)說(shuō)java8的lambda很炫酷,go-zero也有了!fx.Filter().Sort().Head() ,讓數(shù)組的復(fù)雜處理變得簡(jiǎn)單mapReduce降低服務(wù)相應(yīng)時(shí)間:mr.Finish(), mr.Map().Reduce(), 跟并發(fā)處理waitGroup說(shuō)拜拜!etcd服務(wù)發(fā)現(xiàn)的集成:p2c的算法發(fā)現(xiàn)服務(wù),免卻了開(kāi)發(fā)們點(diǎn)對(duì)點(diǎn)或nginx的轉(zhuǎn)發(fā)服務(wù),安裝一個(gè)etcd就完事了jwt集成api:輕松擁有一個(gè)jwt的后臺(tái)服務(wù)集成Prometheus:輕松擁有一個(gè)帶監(jiān)控的golang后臺(tái)服務(wù)等等等
二次感謝go-zero,還有很多小工具,等待我去看源碼,時(shí)間輪/調(diào)度器等等啦。go-zero有點(diǎn)像我學(xué)習(xí)的導(dǎo)師一樣。
go-zero拓展
go-zero為小白如我的gopher們,提供了一個(gè)功能完備、性能可觀、開(kāi)發(fā)迅速的web框架。然而,它不像其他框架那樣約束著我,我還是能里面做很多發(fā)揮的。雖然不是大牛級(jí)別的發(fā)揮,但是,個(gè)性化操作還是支持的:
- model層,完全可以接入gorm代替掉內(nèi)置的sqlx,雖然就沒(méi)了大佬辛苦做的緩存擊穿等防護(hù)的功能。當(dāng)然也可以兩者并存。
- rpc層,不必約定要api層去調(diào)用。例如我上面截圖的worker/ws層去調(diào)用完全沒(méi)問(wèn)題。
- api層自己生成的middleware,可以抽離出到公共目錄,那就可以多個(gè)api目錄使用同一個(gè)middlerware了。
- 等等等啦
go-zero 很輕量、很便捷、很博學(xué)。里面蘊(yùn)藏的著很多知識(shí)以及理念。目前我只是用了皮毛,go-zero的k8s部署,目前我沒(méi)開(kāi)始接入。繼續(xù)努力努力學(xué)習(xí)啦!
再次感謝https://www.yuque.com/tal-tech/go-zero/yaoehb
go-zero語(yǔ)雀文檔https://github.com/tal-tech/go-zero go-zero源碼
項(xiàng)目地址:
https://github.com/tal-tech/go-zero
到此這篇關(guān)于如何使用go-zero開(kāi)發(fā)線上項(xiàng)目的文章就介紹到這了,更多相關(guān)go-zero開(kāi)發(fā)線上項(xiàng)目?jī)?nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從零封裝Gin框架實(shí)現(xiàn)數(shù)據(jù)庫(kù)初始化GORM
這篇文章主要為大家介紹了從零封裝Gin框架實(shí)現(xiàn)數(shù)據(jù)庫(kù)初始化GORM,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01golang interface判斷為空nil的實(shí)現(xiàn)代碼
這篇文章主要介紹了golang interface判斷為空nil的實(shí)現(xiàn)代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04Golang?Compare?And?Swap算法詳細(xì)介紹
CAS算法是一種有名的無(wú)鎖算法。無(wú)鎖編程,即不使用鎖的情況下實(shí)現(xiàn)多線程之間的變量同步,也就是在沒(méi)有線程被阻塞的情況下實(shí)現(xiàn)變量的同步,所以也叫非阻塞同步Non-blocking?Synchronization2022-10-10gtoken替換jwt實(shí)現(xiàn)sso登錄的排雷避坑
這篇文章主要為大家介紹了gtoken替換jwt實(shí)現(xiàn)sso登錄的排雷避坑,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Go語(yǔ)言實(shí)現(xiàn)配置熱加載的方法分享
web項(xiàng)目,經(jīng)常需要熱啟動(dòng)各種各樣的配置信息,一旦這些服務(wù)發(fā)生變更,我們需要重新啟動(dòng)web server,以使配置生效,實(shí)現(xiàn)配置熱加載,本文為大家整理了幾個(gè)方法實(shí)現(xiàn)這個(gè)需求,需要的可以參考下2023-05-05Golang?RPC的原理與簡(jiǎn)單調(diào)用詳解
RPC(Remote?Procedure?Call),主要是幫助我們屏蔽網(wǎng)絡(luò)編程細(xì)節(jié)?,使我們更專(zhuān)注于業(yè)務(wù)邏輯,所以本文主要來(lái)和大家聊聊RPC的原理與簡(jiǎn)單調(diào)用,希望對(duì)大家有所幫助2023-05-05