看到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了
所有评论(0)