V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
xiadada
V2EX  ›  Go 编程语言

Go 改一行文件也要编译一次要 30s

  •  
  •   xiadada · 2020-03-11 17:43:26 +08:00 · 5033 次点击
    这是一个创建于 1774 天前的主题,其中的信息可能已经有所发展或是发生改变。

    项目是分拆到多个仓库的那种,然后会 import 很多公共的 pb, 编译完之后的文件有 366M。。。我看 import 的包都被 cache 了,卡在 link 的时间比较长。这个是什么原因?符号太多?

    go build -v -x -ldflags="-v=2" .

    最后的输出

    12.08 symsize = 0 14.13 pclntab=96705222 bytes, funcdata total 22521356 bytes 14.73 dodata 14.94 symsize = 0 15.10 symsize = 0 15.73 dynreloc 16.19 dwarf 22.82 asmb 22.82 codeblk 23.84 datblk 23.93 reloc 25.26 sym 25.26 headr 25.36 cpu time 4611380 symbols 3060492 liveness data

    然后会有很多 mark text, 和 removing method 条目打出来。。。

    有大佬懂得吗

    23 条回复    2020-03-14 12:44:00 +08:00
    reus
        1
    reus  
       2020-03-11 18:17:12 +08:00   ❤️ 2
    30 秒还想怎样?换成是 llvm / gcc 的,这么大的项目,可能得 30 分钟。
    iRiven
        2
    iRiven  
       2020-03-11 19:01:44 +08:00 via Android
    366M ?这是把一些资源都内置进去了?
    rrfeng
        3
    rrfeng  
       2020-03-11 19:03:37 +08:00
    366M 的话 30s 真的很快了…
    cmdOptionKana
        4
    cmdOptionKana  
       2020-03-11 19:54:12 +08:00   ❤️ 1
    一直在想,如果 linux 软件大部分用 go 重写(当然不可能),那肯定是 Gentoo 的春天。
    my3157
        5
    my3157  
       2020-03-11 19:59:51 +08:00
    可能被 golang 惯坏了, 试试 rust // golang 有编译缓存的, 应该是大量 pb 的原因
    dog82
        6
    dog82  
       2020-03-11 20:14:56 +08:00
    begoo 有个 fsnotify
    Leigg
        7
    Leigg  
       2020-03-11 20:24:16 +08:00
    import 了什么玩意儿,三百兆,好好检查一下,少用私人库
    tulongtou
        8
    tulongtou  
       2020-03-11 20:26:39 +08:00 via iPhone
    很想知道什么项目编译完要 300 多 M
    LokiSharp
        9
    LokiSharp  
       2020-03-11 20:27:52 +08:00 via iPhone
    想知道你源码多大
    guonaihong
        10
    guonaihong  
       2020-03-11 21:54:33 +08:00
    你这至少要 100w 行代码编译吧?
    herozzm
        11
    herozzm  
       2020-03-11 22:10:02 +08:00 via Android
    web 项目才是痛苦 改点东西就得重启,没法热更新
    chenset
        12
    chenset  
       2020-03-11 22:35:50 +08:00
    golang 也有 plugin, https://golang.org/pkg/plugin/
    xfriday
        13
    xfriday  
       2020-03-11 22:52:02 +08:00
    rust release 模式的话得 2 小时不止
    janxin
        14
    janxin  
       2020-03-12 08:44:53 +08:00
    @herozzm web 项目基本无状态,重启就重启吧,反正可以自动实现
    ytll21
        15
    ytll21  
       2020-03-12 09:20:37 +08:00
    @xfriday 什么项目居然要 2 小时。。。厉害厉害
    Sasasu
        16
    Sasasu  
       2020-03-12 09:35:44 +08:00
    c++ 界的解决办法:动态链接
    TangMonk
        17
    TangMonk  
       2020-03-12 14:07:40 +08:00
    估计编译了一堆 assets
    tyrantZhao
        18
    tyrantZhao  
       2020-03-12 14:25:11 +08:00
    感觉比 cpp 快。。。
    GreyYang
        19
    GreyYang  
       2020-03-12 15:51:23 +08:00   ❤️ 1
    拆成 go plugin 用链接 so 的方法可能可以把需要重新编译的部分减少
    soseek
        20
    soseek  
       2020-03-12 19:40:58 +08:00 via Android
    @herozzm 可以呀,为什么不能热更新?
    herozzm
        21
    herozzm  
       2020-03-12 22:57:25 +08:00
    @soseek 没成熟的吧,比如我的二进制运行需要 10s 才会启动好,如果热更新?
    就算用老的二进制顶住,在启动新的二进制文件的时候,老的要退出,10s 的时间访问就会有问题
    soseek
        22
    soseek  
       2020-03-14 05:33:13 +08:00 via Android
    @herozzm 可以
    xfriday
        23
    xfriday  
       2020-03-14 12:44:00 +08:00
    @herozzm 参考 k8s 的 liveness、readiness 探针
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1976 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 16:15 · PVG 00:15 · LAX 08:15 · JFK 11:15
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.