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

2020 年 3 月 11 日
 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 条目打出来。。。

有大佬懂得吗

5577 次点击
所在节点    Go 编程语言
23 条回复
reus
2020 年 3 月 11 日
30 秒还想怎样?换成是 llvm / gcc 的,这么大的项目,可能得 30 分钟。
Erskine
2020 年 3 月 11 日
366M ?这是把一些资源都内置进去了?
rrfeng
2020 年 3 月 11 日
366M 的话 30s 真的很快了…
cmdOptionKana
2020 年 3 月 11 日
一直在想,如果 linux 软件大部分用 go 重写(当然不可能),那肯定是 Gentoo 的春天。
my3157
2020 年 3 月 11 日
可能被 golang 惯坏了, 试试 rust // golang 有编译缓存的, 应该是大量 pb 的原因
dog82
2020 年 3 月 11 日
begoo 有个 fsnotify
Leigg
2020 年 3 月 11 日
import 了什么玩意儿,三百兆,好好检查一下,少用私人库
DonaidTrump
2020 年 3 月 11 日
很想知道什么项目编译完要 300 多 M
LokiSharp
2020 年 3 月 11 日
想知道你源码多大
guonaihong
2020 年 3 月 11 日
你这至少要 100w 行代码编译吧?
herozzm
2020 年 3 月 11 日
web 项目才是痛苦 改点东西就得重启,没法热更新
chenset
2020 年 3 月 11 日
golang 也有 plugin, https://golang.org/pkg/plugin/
xfriday
2020 年 3 月 11 日
rust release 模式的话得 2 小时不止
janxin
2020 年 3 月 12 日
@herozzm web 项目基本无状态,重启就重启吧,反正可以自动实现
ytll21
2020 年 3 月 12 日
@xfriday 什么项目居然要 2 小时。。。厉害厉害
Sasasu
2020 年 3 月 12 日
c++ 界的解决办法:动态链接
TangMonk
2020 年 3 月 12 日
估计编译了一堆 assets
GeminiPro
2020 年 3 月 12 日
感觉比 cpp 快。。。
GreyYang
2020 年 3 月 12 日
拆成 go plugin 用链接 so 的方法可能可以把需要重新编译的部分减少
soseek
2020 年 3 月 12 日
@herozzm 可以呀,为什么不能热更新?

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

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

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

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

© 2021 V2EX