Distributions
Ubuntu
Fedora
CentOS
中文资源站
网易开源镜像站
lvhuiyang
V2EX  ›  Linux

为什么手动编译后的 MongoDB 比官方提供的(包管理器下载)二进制版文件大这么多?

  •  
  •   lvhuiyang ·
    lyu-huiyang · Jan 4, 2020 · 5226 views
    This topic created in 2319 days ago, the information mentioned may be changed or developed.

    公司提供的开发机是没有 root 权限的,所以考虑用手动编译的方式来装个软件。在弄 MongoDB 的时候发现编译后的文件巨大,按照之前经验来说包管理器下载的二进制文件也就是几十 M 吧。有没有老哥了解手动编译后的二进制文件跟官方提供的二进制文件差异在哪?或者是有什么关键字我去 Google 搜一下。

    total 3.1G
    -rwxr-xr-x 1 lvhuiyang lvhuiyang 903M Jan  4 18:15 mongo
    -rwxr-xr-x 1 lvhuiyang lvhuiyang 2.2G Jan  4 18:30 mongod
    
    18 replies    2020-08-03 17:35:11 +08:00
    zhuangzhuang1988
        1
    zhuangzhuang1988  
       Jan 4, 2020   ❤️ 1
    是不是编译的 debug 版本?
    hwenwur
        2
    hwenwur  
       Jan 4, 2020 via Android   ❤️ 2
    可能是没 strip 吧,关键词 linux strip
    lolizeppelin
        3
    lolizeppelin  
       Jan 4, 2020   ❤️ 1
    开发就喜欢瞎几把编译
    tinkerer
        4
    tinkerer  
       Jan 4, 2020   ❤️ 1
    这么大也不像是 debug 版的大小啊,静态链接了?
    katsusan
        5
    katsusan  
       Jan 4, 2020   ❤️ 1
    linux 下用 readelf,其次就是看编译的时候有没有指定参数比如"-g"这种。
    lvhuiyang
        6
    lvhuiyang  
    OP
       Jan 4, 2020
    @zhuangzhuang1988 @tinkerer

    我是根据 Wiki https://github.com/mongodb/mongo/wiki/Build-Mongodb-From-Source

    buildscripts/scons.py mongod mongo

    上述命令编译的,Wiki 好像没有 debug 相关的说明,感谢回复,我再看下。
    lvhuiyang
        7
    lvhuiyang  
    OP
       Jan 4, 2020
    @hwenwur @katsusan 感谢回复,我去查下相关的关键词
    lvhuiyang
        8
    lvhuiyang  
    OP
       Jan 4, 2020
    @lolizeppelin 老哥消消火,确实对编译这块不熟悉,这不是正在学习么 = =
    CEBBCAT
        9
    CEBBCAT  
       Jan 4, 2020   ❤️ 1
    楼主说的几十兆是 apt install 时提示的几十兆吗?那个提示的好像是下载体积
    expy
        10
    expy  
       Jan 4, 2020   ❤️ 1
    可以看看发行版的打包脚本,里面有编译参数。
    lvhuiyang
        11
    lvhuiyang  
    OP
       Jan 4, 2020
    @CEBBCAT 感谢回复,是类似 apt install 时提示的的文件大小,这个应该是(可能压缩过的)下载体积,确实不能把这个跟最终执行的二进制的相比较。
    lvhuiyang
        12
    lvhuiyang  
    OP
       Jan 4, 2020
    @expy 感谢回复,居然还有这种信息,去查下。
    lihongjie0209
        13
    lihongjie0209  
       Jan 4, 2020   ❤️ 1
    mikeguan
        14
    mikeguan  
       Jan 5, 2020 via Android   ❤️ 1
    很明显没有去掉调试信息啊,一二楼都指明问题了,为啥后面还有疑惑呢?
    有没有调试信息 file path_to_file_name 看下如果是 no strip 就代表包含调试信息,直接 strip path_to_file_name 去掉调试信息
    ipwx
        15
    ipwx  
       Jan 5, 2020   ❤️ 1
    编译安装是无计可施的最后一个选项。老哥你这么着急上这招么。。。
    lwp2070809
        16
    lwp2070809  
       Jan 5, 2020 via Android   ❤️ 1
    让你们运维安装 docker,把你添加进 docker 组,用 docker 安装 MongoDB
    hiyang
        17
    hiyang  
       Aug 3, 2020
    我编译的 4.2.6,情况和你一样,使用 strip 后恢复正常体积

    编译时可以通过什么参数直接去掉调试信息吗
    lvhuiyang
        18
    lvhuiyang  
    OP
       Aug 3, 2020
    @hiyang 这个不是很清楚 ...
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3992 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 182ms · UTC 05:05 · PVG 13:05 · LAX 22:05 · JFK 01:05
    ♥ Do have faith in what you're doing.