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

2020-03-11 17:43:26 +08:00
 xiadada

项目是分拆到多个仓库的那种,然后会 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 条目打出来。。。

有大佬懂得吗

4969 次点击
所在节点    Go 编程语言
23 条回复
herozzm
2020-03-12 22:57:25 +08:00
@soseek 没成熟的吧,比如我的二进制运行需要 10s 才会启动好,如果热更新?
就算用老的二进制顶住,在启动新的二进制文件的时候,老的要退出,10s 的时间访问就会有问题
soseek
2020-03-14 05:33:13 +08:00
@herozzm 可以
xfriday
2020-03-14 12:44:00 +08:00
@herozzm 参考 k8s 的 liveness、readiness 探针

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/651929

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX