国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Go etcd 的依賴問題終于解決了......

開發 前端
細心的同學會發現,歸根到底還是和 etcd v3.3 扯上關系,grpc 就沒法升級到 v1.27 以上。其他所有關聯的 protoc、grpc-gateway 的版本都沒法繼續推進。 當你想用 go module 來做各種兼容管理時,會發現 etcd v3.3 根本沒有 go module...

大家好,我是煎魚。

前幾年非常高頻的接觸到這一堆微服務相關組件:grpc + grpc-gateway + etcd + protobuf + protoc-gen-go,一開始都是相安無事,逐步跟進新版本。

這不,幺蛾子就來了。寫這些組件的開發大佬(或公司)都不在一起,各自為政,各有各的想法、喜歡、規范...因此會出互相不兼容,甚至出現了卡脖子的情況。

圖片圖片

各種兼容問題

當 etcd 是 v3.3/v3.4,grpc > v1.27 時,經常會遇到各種看著腦殼痛的兼容性問題。

至少但不限于如下幾個場景。只是例舉幾個比較常見的三個兼容錯誤。

找不到 grpc/naming

找不到 grpc-go 庫中的google.golang.org/grpc/naming 包。原因是什么?原因之一是 go.etcd.io/etcd/client 引用到 grpc-go 庫中的實驗包。

在 go mod tidy 時,會遇到如下報錯:

go: finding module for package google.golang.org/grpc/naming
go: finding module for package google.golang.org/grpc/examples/helloworld/helloworld
go: found google.golang.org/grpc/examples/helloworld/helloworld in google.golang.org/grpc/examples v0.0.0-20231026203026-8cb98464e599
go: finding module for package google.golang.org/grpc/naming
go: git.xxx.cn/xxx/xxx-common/jy imports
 go.etcd.io/etcd/client tested by
 go.etcd.io/etcd/client.test imports
 github.com/coreos/etcd/integration imports
 github.com/coreos/etcd/proxy/grpcproxy imports
 google.golang.org/grpc/naming: module google.golang.org/grpc@latest found (v1.59.0), but does not contain package google.golang.org/grpc/naming

看到最后的 but does not contain package google.golang.org/grpc/naming。以為是 grpc-go 亂刪庫,做了不兼容變更。

想著找官方解決一下問題。印象很深刻,人家 grpc-go 表示:我這庫早就聲明了是實驗性,隨時可能刪除,你不應該依賴他。(不會支持的意思)

找不到 etcd/clientv3/balancer/picker

還是由于 grpc-go 庫的實驗包在新版本去掉了。會導致 etcd v3.3 出現:undefined: balancer.PickOptions 和 undefined: resolver.BuildOption 的相關錯誤信息:

$ go get go.etcd.io/etcd/clientv3
# github.com/coreos/etcd/clientv3/balancer/resolver/endpoint
../../go/pkg/mod/github.com/coreos/etcd@v3.3.18+incompatible/clientv3/balancer/resolver/endpoint/endpoint.go:114:78: undefined: resolver.BuildOption
../../go/pkg/mod/github.com/coreos/etcd@v3.3.18+incompatible/clientv3/balancer/resolver/endpoint/endpoint.go:182:31: undefined: resolver.ResolveNowOption
# github.com/coreos/etcd/clientv3/balancer/picker
../../go/pkg/mod/github.com/coreos/etcd@v3.3.18+incompatible/clientv3/balancer/picker/err.go:37:44: undefined: balancer.PickOptions
../../go/pkg/mod/github.com/coreos/etcd@v3.3.18+incompatible/clientv3/balancer/picker/roundrobin_balanced.go:55:54: undefined: balancer.PickOptions

不得不說,這個 BUG 我還給 etcd 提了 issues 和 pr:

圖片圖片

最終合并了。(但是 etcd v3.5 當年發布的太慢了,沒等到...)

找不到 grpc.SupportPackageIsVersion6

protoc-gen-go 與 grpc 版本不兼容。會出現如下報錯:

Getting error undefined: grpc.SupportPackageIsVersion6 and undefined: grpc.ClientConnInterface

本身這個問題,只需要升級 grpc >= 1.27 就可以了。但如果你使用了 etcd sdk,又會前面的 etcd 版本依賴問題,程序會陷入麻煩的升又升不得,降也降不了。

最后還是將 protoc(protoc-gen-go) 降級為 v1.3.2,grpc 保持在 v1.26,這樣 etcd v3.3 的依賴才能正常使用。

背后緣由

細心的同學會發現,歸根到底還是和 etcd v3.3 扯上關系,grpc 就沒法升級到 v1.27 以上。其他所有關聯的 protoc、grpc-gateway 的版本都沒法繼續推進。

當你想用 go module 來做各種兼容管理時,會發現 etcd v3.3 根本沒有 go module...

etcd v3.4 雖然有 go.mod,但也無法拉取和使用(原因詳見:etcd-io/etcd/issues/11154[1])。

圖片圖片

etcd 官方的響應也是不太積極的。猜測是積重難返,比較難解決。

解決方案

社區等了許多年,現在終于有了解決辦法。etcd v3.5 已經正式支持了 go module!

etcd 將之前的模塊按功能做了領域劃分,把之前各種的低版本依賴、循環依賴等問題都處理了。

如下圖所示:

圖片圖片

圖片圖片

拆分為了 api、client、raft、server、etcdctl、bbolt 等獨立的 Go 模塊。不會像老版本一樣交叉影響。

如果你是新項目,建議無腦使用 etcd v3.5 以上版本。千萬別用 v3.3/v3.4 及更低的!

比較無奈的一點

可能有的同學以為皆大歡喜了?其實并不。

他的模塊化改造成功僅限于 etcd v3.5 的版本。而歷史項目,如果你是使用 etcd v2 store,那么很抱歉。

etcd 老版本(v3.3/v3.4 等)是沒有變動的,在 v3.5 的新版本(包含最新的文檔)中都在開始在逐步去除 etcd v2 的相關支持。

圖片圖片

如果仍然在使用 etcd v2 的同學,建議進行數據遷移用 v3。這樣可以避免很多技術上的問題。

遷移不方便的話,除了各種 replace 和鎖版本外。如果你使用的 etcd 功能非常基礎,也可以自己實現一個簡易版的 SDK。

總結

etcd 的這個歷史問題已經存在了好幾年,一直處理的慢慢吞吞。甚至影響到了 Go 生態圈的一些技術選型問題。

前幾天有同學反饋 tidb 里引用了 cloud.google.com/go/pubsub 庫,而該庫又依賴了 grpc 的較高的版本。從而導致原有卡在 grpc v1.26 的應用又出現了問題。才回過頭來看看。

在新版本中,etcd 的依賴問題終于解決了。真的是,這值得被我們記住!雖然他老版本依然沒處理...

責任編輯:武曉燕 來源: 腦子進煎魚了
相關推薦

2021-12-13 20:09:33

GoElasticsearJava

2025-10-28 01:00:00

GoRecordertrace 格式

2025-04-28 05:00:00

2021-03-05 14:40:49

Chrome瀏覽器內存

2024-06-05 14:35:26

2022-08-01 09:43:19

程序員Googlefacebook

2020-03-30 16:18:02

代碼開發工具

2025-05-22 08:35:00

Go開發編程

2025-10-31 09:01:37

2022-11-08 08:29:43

Goslog 庫工具

2021-08-09 10:24:21

技術分類數學

2019-11-26 14:30:20

Spring循環依賴Java

2023-10-30 19:51:52

ESlint檢測工具代碼

2025-11-07 00:00:00

2023-10-05 18:49:12

.Net?Newtonsof源碼

2021-09-15 09:31:39

前端開發工具

2018-11-22 15:07:17

代碼github程序

2025-07-21 11:49:44

GoGit子目錄

2020-08-06 16:55:37

虛擬化底層計算機
點贊
收藏

51CTO技術棧公眾號

av电影在线地址| 精品三级av| 亚洲综合丁香婷婷六月香| 亚洲欧美日产图| 日韩av自拍| 国产精品高潮视频| 另类春色校园亚洲| 久久久久九九九九| av在线精品| 精品自拍视频在线观看| 国产乱码精品一区二区三区亚洲人 | 婷婷精品在线| 免费av一区二区| 99久久999| 日韩视频一区在线| 亚洲成人高清| 欧美日本黄视频| 久久久久久毛片免费看| **欧美日韩vr在线| 久久综合色占| 成人久久一区二区三区| 欧美日韩国产探花| 黄色国产精品一区二区三区| 99riav国产精品| 欧美一级二级三级| 国产一区视频在线看| 老汉色影院首页| av综合在线播放| 999精彩视频| 亚洲女同ⅹxx女同tv| 伊人国产在线看一| 欧美另类videos死尸| wwww亚洲| 久久在精品线影院精品国产| a看欧美黄色女同性恋| 国产精品美女免费看| 亚洲激情一区| 17c丨国产丨精品视频| 国产农村妇女毛片精品久久麻豆| 午夜av电影| 91麻豆精品国产无毒不卡在线观看| 国内小视频在线看| 中文字幕久热精品在线视频| 青青草这里只有精品| 91中文精品字幕在线视频| 亚洲欧美日本日韩| 黄色www网站| 亚洲妇女屁股眼交7| 羞羞视频在线免费国产| 久久久91精品| 色天天久久综合婷婷女18| 欧洲久久久久久| 99久久久国产精品免费蜜臀| 老司机在线免费视频| 3d成人h动漫网站入口| 色诱色偷偷久久综合| 成人久久久久爱| 国产真实乱对白精彩久久| 国产二区三区四区| 日韩精品资源二区在线| 婷婷综合国产| 成人资源视频网站免费| 99综合电影在线视频| 中文在线三区| 国产小视频国产精品| 日韩国产欧美| 欧美少妇一级片| 精品福利在线观看| 国产一区高清| 国产欧美综合精品一区二区| 不卡的av电影| 毛片免费在线观看| 久久久久北条麻妃免费看| 亚洲国产高清一区| 日韩av卡一卡二| 91精品国产欧美一区二区18| 九色丨蝌蚪丨成人| 一区二区三区在线视频111| 樱花草国产18久久久久| 刘亦菲一区二区三区免费看| 91色p视频在线| 26uuu精品一区二区| 国产三级在线播放| 日本高清视频一区| 高清久久久久久| 麻豆网站在线观看| 国产成人精品在线观看| 丁香五精品蜜臀久久久久99网站| 韩国三级av在线免费观看| 久久6精品影院| 美女看a上一区| 欧美色18zzzzxxxxx| 欧美二区乱c黑人| 蜜臀久久久久久久| 九色视频在线观看免费播放| 欧美日韩成人网| 麻豆精品在线看| 欧美偷拍视频| 日韩av片电影专区| 99久久久国产精品| 川上优av中文字幕一区二区| 91嫩草视频在线观看| 中文字幕精品—区二区四季| 超碰aⅴ人人做人人爽欧美| 国产精品区一区二区三在线播放| 亚洲日本成人在线观看| 国产人妖一区| 欧美aaa在线观看| 欧美精品三级在线观看| 中文视频一区| 偷偷要 色偷偷| 欧美综合激情网| 国产三级欧美三级| 日韩黄色三级| av影院在线播放| 亚洲激情第一页| 日韩高清一区二区| 菠萝蜜视频国产在线播放| 91视频免费进入| 色婷婷亚洲一区二区三区| 日韩av在线播放网址| 五月天婷婷综合社区| 国产91精品在线播放| 亚洲欧美日韩中文播放| 欧美变态网站| 黄网站免费入口| 欧美在线日韩在线| 亚洲丝袜美腿综合| 欧美激情在线精品一区二区三区| 亚洲欧美国产中文| 久久久久久com| 国产欧美一区二区精品性色超碰| 日韩毛片网站| 成人免费观看视频在线观看| 久久精彩免费视频| 久久久午夜精品理论片中文字幕| 国产日本亚洲| 免费看国产黄色片| 57pao成人国产永久免费| 一区二区三区中文在线观看| 国产成人高清| 激情视频在线观看免费| 精品视频一区在线| 亚洲精品在线观看网站| 国产福利一区二区| 欧美视频二区欧美影视| 成人免费在线观看视频网站| 日韩av男人的天堂| 欧美中文字幕一区二区三区亚洲 | 国产做受69高潮| 国产精品不卡在线观看| 最新黄网在线观看| 国产主播欧美精品| 午夜精品福利在线| 国产精品久久久久久久久妇女| 最近中文字幕在线| 92看片淫黄大片看国产片| 在线观看欧美黄色| 亚洲欧美日本日韩| 乡村艳史在线观看| 91专区在线观看| 久久久伊人欧美| 亚洲激情校园春色| 中文一区一区三区免费在线观看| 蜜芽在线免费观看| 日韩成人午夜影院| 欧美美最猛性xxxxxx| 一区二区激情小说| 极品少妇一区二区三区| 欧美xxxhd| 天天干天天玩天天操| 91免费看网站| 精品亚洲一区二区三区在线观看 | 欧美电影精品一区二区| 国产乱码精品一区二区三区忘忧草 | 国产成人免费视频精品含羞草妖精| 免费视频观看成人| 在线免费看黄av| 日本一区二区三区视频在线播放| 国产午夜精品一区理论片飘花| 亚洲精品自拍动漫在线| 国产精品最新自拍| 成人免费观看49www在线观看| 香蒸焦蕉伊在线| 国产在线无码精品| 国产日韩精品在线观看| 亚洲乱码国产乱码精品精天堂| 亚洲综合一区二区三区| 蜜臀久久久久久久| 日韩精品免费一区二区夜夜嗨| 成人在线app| 久久国产情侣| 制服国产精品| 91精品国产自产在线| 日韩在线激情视频| 欧美区一区二区三区| 亚洲丝袜精品丝袜在线| 国产一区二区美女| 亚洲特级毛片| 国产精品免费不|