zoukankan      html  css  js  c++  java
  • Ubuntu 14.04 Server 上安装git源 mono 3.6.1 错误记录及成功步骤

        看到ASP.NET vNext要支持Linux后,终于按捺不住折腾的心,决定先架个环境出来,只是实在没想到,因为相对熟悉点才选择的Ubuntu 14.04,会让过程会如此坎坷,有时呆看着屏幕上提示的种种error,真有点别人碰到的错都被我碰到了的荣幸,所以目标达成后,回头将这些错误回顾一遍,记录下来,以为将来鉴。

        安装时主要参照的教程,是宇内流云写的《在Ubuntu操作系统上安装mono的具体方法,简称文1;在排错过程中,还有参考园子里 逆水寒龙 的《Ubuntu Server(Ubuntu 14.04 LTS 64位)安装libgdiplus2.10.9出错问题记录》,简称文2.

        首先是参照文1的一、二、三步来,因为Ubuntu版本的差异,其中有些包小数字上不同,然后就是安装libgdiplus,我当时选择的是更新一点的libgdiplus-2.10.9.tar.bz2:

    wget http://download.mono-project.com/sources/libgdiplus/libgdiplus-2.10.9.tar.bz2
    tar jvxf libgdiplus-2.10.9.tar.bz2
    cd libgdiplus
    -2.10.9
    ./configure --prefix=/usr
    make

        首先会很快得到一个错误,基本就是:

    ../libtool: line xxxx: X-xxx command not found

        这个可以先执行  export echo=echo 再 make来解决;另外,还在某E文中找到个办法,用 libgdiplus目录下的libtool 替换掉 其下 pixman/libtool,试了下貌似也能解决问题。

        继续 make,报错,如同文2中的一样,主要就是:

    gdiplus-private.h:33:31: fatal error: freetype/tttables.h: No such file or directory
     #include <freetype/tttables.h>
                                   ^

        按文2中的办法即:

    ln -s /usr/include/freetype2 /usr/include/freetype

        依旧error,第二个要改动的地方也照抄,结果再报错就是 *** DSO missing from command line。

        然后不知怎么想的,下了个版本老一点的 libgdiplus-2.10.tar.bz2 ,一试竟然编译成功了!

        在安装mono时,问题又来了,编译3.X以后版本的mono需要一个至少先有一个2.10版的mono,但记得园子里的张善友在博文里说过,从哪个版本开始好像也可以不要,因为是3个月前看过的,记不大清,于是直接行动,结果当然是缺少一个 mcs。

        之后尝试好几种办法:

    1、按文1回复中,宇内提到办法,先 sudo apt-get install mono-gmcs,编译再 remove掉

    2、文2回复中,alienblog提到的用 sudo apt-get build-dep mono 来解决依赖问题;

    3、干脆直接先装个ubuntu自带的mono: sudo apt-get install mono-complete

        尝试的结果,都是报错称XXXX 与 GAC 中的XXX冲突云云, 我当时猜想可能因为这3种办法都会装上 mono-runtime,所以又想找找不预装mono的办法。

        经过N多折腾,最终好歹还是编译装上了git源的 mono3.6.1,以下为安装记录:

    # 系统环境:vbox中安装的Ubuntu 14.04 Server,内存分配 2G,locale直接选了en_US

    # 以下为安装成功后,重复测试通过的全部步骤


    sudo apt-get install build-essential automake autoconf
    sudo apt-get install bison gettext libtool libglib2.0-dev libfreetype6-dev libfontconfig1-dev 
    sudo apt-get install libgif-dev libtiff4-dev libpng12-dev libx11-dev libxft-dev libjpeg-dev

    # 照抄 http://www.rocko.me/install-mono-3-4-ubuntu/ 提到的依赖包,编译成功后
    # 回头重复测试时,发现去掉libgtk-3-dev,在github源的libgdiplus运行 autogen.sh 后,
    # 会提示 依赖cairo,需要 >=1.6.4,也懒得去单独解决 cairo 了,直接照搬;
    # 至于 xorg-dev 没再测试,有没有用就不知道了,留着先 - -!
    sudo apt-get install xorg-dev libgtk-3-dev

    sudo apt-get install git

    git clone git://github.com/mono/mono.git
    cd mono

    # 为了整齐,把 libgdiplus 放在了mono目录下
    git clone git://github.com/mono/libgdiplus.git
    cd libgdiplus/
    ./autogen.sh --prefix=/usr
    make
    sudo make install

    # 中场休息
    sudo ldconfig


    #回到mono目录
    cd ..
    ./autogen.sh --prefix=/usr

    # 参考 http://www.mono-project.com/Compiling_Mono_From_Git
    # 这是不预装mono编译的好办法,不过文中提到,要先执行过 ./autogen.sh
    make get-monolite-latest

    # 同样,make也需要额外参数
    make EXTERNAL_MCS="${PWD}/mcs/class/lib/monolite/gmcs.exe"

    sudo make install
    sudo ldconfig
    mono -V

        最后,感谢文中提到各位作者,这些经验对我帮助良多。


    2014.7.22 补录:

        2014.7.15 以前git的mono源码编译安装的,在一个Asp.Net vNext工程里,可能会出现 kpm restore 失败的问题,类似这样:

    Attempting to resolve dependency Microsoft.CSharp >= 
    Attempting to resolve dependency ConsoleApp >= 1.0.0
    Attempting to resolve dependency System.Console >= 4.0.0.0
    ...
    System.AggregateException:  ---> System.IO.FileFormatException: The specified archive is invalid.
      at System.IO.Packaging.Package.OpenCore (System.IO.Stream stream, FileMode packageMode, FileAccess packageAccess, Boolean ownsStream) [0x00000] in <filename unknown>:0 
      at System.IO.Packaging.Package.Open (System.IO.Stream stream, FileMode packageMode, FileAccess packageAccess, Boolean ownsStream) [0x00000] in <filename unknown>:0 
      at System.IO.Packaging.Package.Open (System.IO.Stream stream, FileMode packageMode, FileAccess packageAccess) [0x00000] in <filename unknown>:0 
      at Microsoft.Framework.PackageManager.Restore.NuGet.PackageFeed+<OpenNuspecStreamAsync>d__1.MoveNext () [0x00000] in <filename unknown>:0 
    --- End of stack trace from previous location where exception was thrown ---

        我在笔记本上正好是7.14号编译安装的,结果kpm restore始终无法下载依赖的库,一度以为源被XX了。

        解决办法很多,不过mono 7.15 的一个commit直接解决了这个问题,“Merge pull request #1064 from ranma42/fix-config-paths

        将mono代码更新到这个commit之后,重新编译安装后就省心了。


    2014.7.22 补录2:

        2014.7.17 到目前无止,无法编译mono git最新源码的,是因为 kumpera 在7.17提交的几个unit-test下关于hashtable的改动,导致最终无法编译成功:

    /usr/bin/ld: test-conc-hashtable: hidden symbol `mono_thread_get_abort_signal' isn't defined
    /usr/bin/ld: final link failed: Bad value
    collect2: error: ld returned 1 exit status
    make[3]: *** [test-conc-hashtable] Error 1

        昨晚的测试依旧,试了下,退回他提交前的随便哪个commit都没问题,不过考虑到上一个问题,建议不要退太远,比如git clone了最新源码后,可以执行这个命令:

    git reset --hard d959941265aa7c63dfca3608cc182cca4a29e49f

        再编译就OK了

  • 相关阅读:
    How to Use .Net Remoting Using C#
    How to: Build a Client Application
    C# 禁用鼠标中间键
    秒杀系统:设计方案与实现思路
    JDBC连接数据库
    Java调用webService示例
    spring MVC
    rust贪吃蛇
    初识智遥工作流软件——表单开发篇2
    初识智遥工作流软件——表单开发篇1
  • 原文地址:https://www.cnblogs.com/honedream/p/Compiling_Mono_From_Git_On_Ubuntu-14-04-Server.html
Copyright © 2011-2022 走看看