Go1.22: fastrand 变成 slowrand 了 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
nickxudotme
V2EX    Go 编程语言
Go1.22: fastrand 变成 slowrand 了
  •  1
     
  •   nickxudotme 2024-03-10 01:41:49 +08:00 2970 次点击
    这是一个创建于 580 天前的主题,其中的信息可能已经有所发展或是发生改变。

    今天在写 Kitex 框架关于负载均衡算法的源码解析,在跑 Benchmark 的时候突然发现我之前贡献的一个负载均衡算法性能有很大的倒退,折腾了好久都没明白,甚至把我当时本地的几个 commit 都签出测试还是一样

    排查来排查去,感觉可能是依赖的 fastrand 有问题,框架里依赖的是字节的 fastrand

    import "github.com/bytedance/gopkg/lang/fastrand" 

    但是我过去一看,这个 fastrand 已经两年没动过了,但是这个 fastrand 又依赖 runtimex 包里的 Fastrand(),这个包更是三年没动过了(

    我就去看这个 runtimex 是什么东西

    package runtimex import ( _ "unsafe" // for linkname ) //go:linkname Fastrand runtime.fastrand func Fastrand() uint32 

    啊,原来是直接搬来的 runtime 里的 fastrand ,我一想,难道是 Go 的版本问题吗?

    于是我写了个 Benchmark ,再把 Go 从 1.22 调到 1.21 ,卧槽,的确是这个原因

    于是我在 Kitex 里也改成了 1.21 ,的确和当时一模一样了

    我去 issue 和 PR 里找相关的内容,但是没找到,但这个 fastrand 肯定很多人都在用吧,怎么我成了第一个发现的了

    于是我自己交了一个 PR bytedance/gopkg#206 ,但这个仓库好像已经不怎么维护了,一堆 issue 和 PR 挂着()

    原因就是 1.22 的更新导致的,找到了一篇文章 https://zhuanlan.zhihu.com/p/673906980

    7 条回复    2024-03-16 11:35:39 +08:00
    lesismal
        1
    lesismal  
       2024-03-10 01:54:13 +08:00   1
    kitex-benchmark 后来按默认的脚本也跑不起来,不知道现在能不能跑了,kitex 代码太复杂我表示“看不懂”,所以不玩了,还是玩我自己的吧

    连同 grpc ,都挺难用的
    MIUIOS
        2
    MIUIOS  
       2024-03-10 10:26:53 +08:00
    有可能在维护这个仓库的人被开源节流了
    sealingpp
        3
    sealingpp  
       2024-03-10 11:44:20 +08:00
    牛的
    thevita
        4
    thevita  
       2024-03-10 14:05:51 +08:00
    然后呢,是不是可以直接用 math/rand 了?
    nickxudotme
        5
    nickxudotme  
    OP
       2024-03-10 15:11:28 +08:00
    @thevita 没对比,你可以自己性能测试一下
    dyllen
        6
    dyllen  
       2024-03-11 14:01:56 +08:00
    1.22 版本不是上了个 v2 版本的 rand 吗?估计改了不少内容。
    xiaocaiji111
        7
    xiaocaiji111  
       2024-03-16 11:35:39 +08:00
    go1.22 中有不少跟以前不兼容的地方,看官方的 ISSUE 就知道,破坏了不少兼容性
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5843 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 30ms UTC 06:35 PVG 14:35 LAX 23:35 JFK 02:35
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86