精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

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子目錄

2022-06-20 11:05:49

TCC模式commit
點贊
收藏

51CTO技術棧公眾號

欧美一区二区三区免费大片| 国产亚洲成aⅴ人片在线观看| 欧美大片在线看免费观看| 美国黄色一级视频| 怡红院成人在线| 亚洲欧美另类久久久精品2019| 国产高清精品一区二区三区| 亚洲大尺度在线观看| 亚洲精品国产成人影院| 日韩电影网在线| 一级 黄 色 片一| 大胆人体一区二区| 一区二区不卡在线视频 午夜欧美不卡在 | 人妻人人澡人人添人人爽| 美女av一区| 91精品国产91久久久久久一区二区| 日本福利视频在线| 超碰超碰在线| 国产日韩欧美精品在线| 国产免费一区| 91黄色在线视频| 美女尤物久久精品| 国产做受高潮69| 亚洲一区电影在线观看| 九九热线有精品视频99| 欧美成人精品福利| 中文字幕永久有效| 色综合一本到久久亚洲91| 亚洲风情在线资源站| www.亚洲一区二区| 8888四色奇米在线观看| 久久综合999| 国内精品视频在线播放| 精品女同一区二区三区| 久久成人18免费观看| 日韩免费观看网站| 一级片视频在线观看| 91久久综合| 欧美国产激情18| 国产精品成人免费观看| 天天影视天天精品| 色吧影院999| 欧美巨胸大乳hitomi| 欧美**字幕| 亚洲国产精品久久久| 国产a级片视频| 一区二区三区亚洲变态调教大结局| 欧美一区日本一区韩国一区| 夜夜夜夜夜夜操| 亚洲精品tv| 欧美日本免费一区二区三区| 五月天av在线播放| 国产一区高清| 欧美男生操女生| 日韩不卡一二三| 午夜不卡一区| 91精品国产高清一区二区三区| 狠狠操狠狠干视频| 久久亚洲人体| 日韩一级完整毛片| 日本精品一二三| 久久综合社区| 亚洲精品一区二区三区婷婷月| 国产大尺度视频| 欧美色资源站| 国产一区二区精品丝袜| 三级黄色在线观看| 午夜精品婷婷| 91成人在线观看国产| 亚洲欧美偷拍一区| 久久成人久久爱| yellow视频在线观看一区二区| 风流少妇一区二区三区91| 成人激情免费电影网址| 蜜桃成人在线| 在线视频91p| 亚洲女厕所小便bbb| 欧美国产综合在线| jk漫画禁漫成人入口| 欧美色男人天堂| 亚洲精品一二三四| 亚洲区小说区图片区qvod| 一区二区中文字幕| 黄色一级片在线| 亚洲中午字幕| 成人免费网站在线观看| 亚洲老妇色熟女老太| 久久久精品一品道一区| 老司机av福利| 成人三级高清视频在线看| 欧美制服丝袜第一页| 97超碰免费在线观看| 校园春色另类视频| 久久久999精品| 天堂网一区二区三区| 美女网站视频久久| 国产精品一区二区三区观看| 国产大片在线免费观看| 一区二区在线免费| www.xxx亚洲| 香蕉大人久久国产成人av| 精品亚洲一区二区三区四区五区| 欧洲美女女同性互添| 亚洲影院一区| 波多野结衣精品久久| 国产在线小视频| 亚洲午夜久久久| 久久99爱视频| 国产欧美日韩视频在线| 欧美国产日本在线| 国产又粗又猛视频免费| 91在线播放网址| 六月婷婷激情网| 韩国成人在线| 日韩成人小视频| 精品无码m3u8在线观看| 久久av中文字幕片| 欧美视频1区| xxx性欧美| 7777精品伊人久久久大香线蕉完整版| 中文字幕5566| 亚洲一级特黄| 亚洲最大福利网| 秋霞午夜在线观看| 在线观看亚洲成人| 丰满少妇一区二区| 99av国产精品欲麻豆| 不卡日韩av| 美女羞羞视频在线观看| 欧美视频你懂的| 日本精品在线观看视频| 美女精品在线观看| 六月婷婷久久| 色戒汤唯在线| 精品视频—区二区三区免费| 久草网视频在线观看| 国产精品一区二区不卡| 一区国产精品| www久久久| 久久精品夜夜夜夜夜久久| 一级淫片免费看| 国产精品久久久久久户外露出 | 久久精品五月天| 91蝌蚪porny成人天涯| 久久久久久久久久久99| 成人爽a毛片免费啪啪红桃视频| 欧美大片在线影院| 丰满少妇被猛烈进入| 亚洲五码中文字幕| 加勒比精品视频| 亚洲尤物影院| 欧美日韩视频在线一区二区观看视频| 精品国产免费人成网站| 亚洲欧美一区二区三区在线| 综合网在线观看| 国产日韩欧美一区二区三区乱码 | 少妇精品视频一区二区免费看| 亚洲人成电影在线播放| 男操女视频网站| 成人免费在线视频观看| 国模大尺度视频| 亚洲精选一区| 日本一区二区三区免费看| yiren22亚洲综合| 久久精品国产成人精品| www黄色网址| 精品久久久精品| 亚洲ⅴ国产v天堂a无码二区| 激情综合网最新| 亚洲精品天堂成人片av在线播放| 嫩草国产精品入口| 国产精品久久久久久久久久ktv| 99reav在线| 日韩欧美电影一二三| 69成人免费视频| 亚洲国产精品ⅴa在线观看| 男人的天堂最新网址| 亚洲天堂激情| 日韩欧美视频一区二区| 日本在线成人| 人人爽久久涩噜噜噜网站| 麻豆视频免费在线观看| 亚洲国产精品va在看黑人| 中文字幕在线2019| 一区av在线播放| 摸摸摸bbb毛毛毛片| 国产精品1区2区3区| 欧美性大战久久久久xxx | 久久视频中文字幕| 日韩一级片免费观看| 欧美视频一区在线| 久久精品视频8| 国产精品毛片a∨一区二区三区| 色欲欲www成人网站| 首页亚洲欧美制服丝腿| 99中文字幕在线观看| 国产精品嫩模av在线| 成人免费视频网站| 91成人在线| 97在线观看视频| 国产盗摄在线观看| 亚洲人成自拍网站| 国产自产一区二区| 欧美日韩aaaaa| 久久免费激情视频| 亚洲综合丝袜美腿| 女同久久另类69精品国产| 26uuu久久综合| 制服丝袜在线第一页| 久久精品国产秦先生| 麻豆av免费在线| 亚洲国产专区校园欧美| 少妇高潮大叫好爽喷水| 不卡在线一区| 欧美精品成人一区二区在线观看| 日本少妇精品亚洲第一区| 国产日韩在线一区| 国产日韩另类视频一区| 欧美性资源免费| xxx在线免费观看| 久久理论片午夜琪琪电影网| 国产高清一区二区三区视频| 中文综合在线观看| 国产在线观看精品一区| 日韩精品亚洲视频| 无码国产伦一区二区三区视频| 日韩欧美高清一区| 国产视频第一页| 91精品久久久久久蜜臀| 亚洲无码精品在线观看| 色天使色偷偷av一区二区| 久久精品视频国产| 午夜在线成人av| 国产精品白浆一区二小说| 亚洲精品老司机| 午夜国产福利一区二区| 亚洲欧美色图小说| 欧美精品入口蜜桃| 一区二区三区欧美亚洲| 欧美成人精品一区二区免费看片 | 黄色一级视频在线播放| 在线精品一区| 日韩欧美不卡在线| 日韩一区二区久久| 黄色动漫网站入口| 国产日韩免费| 18禁男女爽爽爽午夜网站免费| 国产视频亚洲| 一本久道综合色婷婷五月| 三级欧美韩日大片在线看| 男人舔女人下面高潮视频| 日本中文字幕一区| 污污网站免费看| 国产一区二三区好的| 久久无码人妻一区二区三区| 国产精品 欧美精品| 中文字幕人妻熟女在线| 99国产精品国产精品久久| www.久久av| 中文字幕乱码日本亚洲一区二区 | 中文字幕天堂网| 91亚洲男人天堂| 少妇av片在线观看| 亚洲视频中文字幕| 国产午夜免费视频| 日韩欧美亚洲成人| 91成年人视频| 日韩精品资源二区在线| 五月婷婷激情在线| 中文字幕亚洲综合久久| 欧美人与牲禽动交com| 国产69精品久久久久9| 日韩精品影院| 亚洲一区二区三区四区视频| 女仆av观看一区| 亚洲精品不卡| 极品中文字幕一区| 日韩在线第三页| 国产精品一区二区视频| 少妇精品一区二区| 亚洲视频图片小说| 一级片免费网址| 欧美日韩黄色影视| 三级视频在线看| 日韩中文在线视频| 99thz桃花论族在线播放| 国产精品视频yy9099| 哺乳一区二区三区中文视频| 欧美日韩亚洲一区二区三区四区| 国产精品久久观看| 日韩欧美国产免费| 精品一区二区影视| av在线网站观看| 国产精品美女一区二区在线观看| 国产精品二区一区二区aⅴ| 色播五月激情综合网| 国产福利视频导航| 在线观看久久av| jizz一区二区三区| 91久久嫩草影院一区二区| 国产成人ay| 妞干网在线观看视频| 精品无人区卡一卡二卡三乱码免费卡| www.男人天堂| 亚洲女性喷水在线观看一区| 精品国产www| 国产丝袜高跟一区| 黄页在线观看免费| 成人中文字幕+乱码+中文字幕| 九九在线高清精品视频| 99在线观看视频免费| 狠狠色狠狠色综合| 日本高清黄色片| 色乱码一区二区三区88| 欧洲精品久久一区二区| 欧美成人午夜视频| 亚洲日本免费电影| 欧美一区二区三区四区五区六区| 99国产精品久久久久久久成人热 | 欧美富婆性猛交| 日本国产一区| 亚洲欧洲国产日韩精品| 视频一区二区不卡| 短视频在线观看| 疯狂欧美牲乱大交777| 色婷婷av一区二区三区之红樱桃| 中文字幕精品久久久久| 亚洲风情在线资源| 国产乱码精品一区二区三区卡| 亚洲成人一区| 亚洲第一成肉网| 亚洲免费视频成人| 精品人妻一区二区三区浪潮在线| 久久国产精品免费视频 | 欧美一区二区三区人| 3d成人动漫在线| 国产精品一区二区性色av| 成人久久一区| 中文字幕免费高清在线| 中文字幕va一区二区三区| 一级特黄免费视频| 在线一区二区日韩| 91精品视频一区二区| 日韩 欧美 自拍| 国产一区激情在线| 久久久久97国产| 亚洲高清福利视频| 美女在线视频免费| 日本欧美精品久久久| 日韩精品一二区| 国产成人精品视频免费| 欧美精品自拍偷拍动漫精品| 成人在线app| 国产aⅴ精品一区二区三区黄| 亚洲国产免费看| 五级黄高潮片90分钟视频| 日本丶国产丶欧美色综合| 91高清在线视频| 91夜夜揉人人捏人人添红杏| 国产一区二区三区四区三区四| 日本国产在线视频| 欧美性xxxx在线播放| 91在线免费看| 99精彩视频| 性欧美精品高清| 免费观看特级毛片| 日韩欧美亚洲国产精品字幕久久久| 污视频免费在线观看| 久久99国产精品| 免费av网站大全久久| 日日骚一区二区三区| 亚洲国产天堂久久国产91 | 动漫一区二区在线| 午夜在线a亚洲v天堂网2018| 国产福利在线导航| 精品精品国产高清一毛片一天堂| 涩涩网在线视频| 一区二区精品免费视频| 国产.精品.日韩.另类.中文.在线.播放| 亚洲男人第一av| 久久精品电影网站| 奇米777国产一区国产二区| 在线看的黄色网址| 亚洲福利一二三区| 瑟瑟视频在线| 久久艹中文字幕| 精久久久久久久久久久| 亚洲男人的天堂在线视频| 中文字幕一精品亚洲无线一区| 成人自拍在线| 美女网站色免费| 好吊成人免视频| а√天堂在线官网| 日本一区二区三区视频在线观看 | 精品粉嫩超白一线天av| 成人自拍av| 男人添女人下部高潮视频在观看| 国产精品乱码妇女bbbb| 欧美套图亚洲一区| 国产精品久久久久久久久久直播 |