一次艰难的mono环境部署
继上篇文章《Mono的兼容性问题》之后,现在总结一下我在suse 10中部署mono环境遇到的一些问题及其处理办法。
腾讯社区开放平台提供的体验区的服务器环境是这样的:
操作系统:Linux version 2.6.16.60 (gcc version 4.1.2 20070115 (SUSE Linux))
这个Linux内核的版本号应该是SLES(SUSE Linux Enterprise Server 10 SP2)的操作系统。mono原来的版本号是1.2.2,而我们需要2.8.2的mono。所以,第一步的工作就是升级mono。
通过腾讯的跳板机登录到服务器后,需要跟腾讯的运维人员申请root权限,这个就不用多说了。
部署mono环境的具体步骤如下:
1、下载mono并上传到腾讯的服务器上。
腾讯的服务器是没有配置dns解析功能的,所以不能直接用yast2来通过更新源来升级mono;对于可以用yast2安装的,可以参考我的《在openSUSE中部署基于apache的mono环境》。而用rpm手工安装,太多的程序依赖处理起来很麻烦,只好用通过编译mono源码的方式来安装了。
在这里可以下载到mono的源码,我们只需要mono-2.8.tar.bz2/xsp-2.8.tar.bz2/mod_mono-2.8.tar.bz2。mono-2.8.tar.bz2当然是mono的核心了,xsp-2.8.tar.bz2是一个轻量级的web服务器,而mod_mono-2.8.tar.bz2是apache的模块,使用这个来解析.net开发的网站。
上传文件到腾讯的服务器需要分2部走,首先用rz -be把文件上传到腾讯的跳板机,然后再用scp命令把文件传到目标服务器。
2、安装mono-2.8.tar.bz2。
切换到mono-2.8.bar.bz2的目录,执行
1 |
tar xf mono-2.8. tar .bz2 |
解压mono源码包。之后再
1 |
cd mono-2.8 |
进入解压出来的文件夹后,执行配置命令,这里都使用默认配置,如果使用–prefix指定目录的话,需要修改很多配置,操作起来非常麻烦。
1 |
. /configure |
之后就是最常规的
1 |
make |
进入漫长的编译过程。中间过程如果出错,根据它的提示安装相当的文件。然后直接进行安装。
1 |
make install |
到这里,mono就安装完成了。这步非常简单。我走的弯路是腾讯要求要把软件都安装到/usr/local/services/目录,而mono指定安装目录后,需要设置系统变量及在后面的软件安装过程都要显式的指定mono目录,一直都没有折腾好,最后只好使用默认安装,结果一次就好了。
3、安装xsp-2.8.tar.bz2。
一样解压文件并执行configure,
1
2
3 |
tar xf xsp-2.8. tar .bz2 cd xsp-2.8 . /configure |
到这里一直都是正确的,但是执行
1 |
make |
的时候,就不能进行下去了。会有这样一个提示:
Your sqlite3 version is old – please upgrade to at least v3.5.0!
Unhandled Exception:System.EntryPointNotFoundException: sqlite3_next_stmt
…….
提示这个错误是因为linux本身的sqlite3版本号不够,默认的是3.1.3。你要么升级sqlite要么修改xsp的文件。查看xsp的安装文件发现是在编译xsp的demo文件时产生的错误。在$XSP_PATH/test/1.1/webcontrols目录下有dbpage1.aspx/dbpage1.sqlite/dbpage2.aspx/dbpage2.sqlite/dbpage_test_setup.cs这几个文件,错误就是在编译这些文件的时候产生的。于是我修改了这个目录下的Makefile/Makefile.am/Makefile.in这三个文件,把和sqlite有关的都删除掉了。
分别编辑这三个文件,找到:
1 |
samples_Data = |
把这个值的
1
2 |
dbpage1.aspx \ dbpage2.aspx \ |
把这两个删掉,还有:
1
2
3
4
5
6
7
8
9 |
sqlitedir = $(pkglibdir) /test/1 .1 /webcontrols sqlite_DATA = dbpage.sqlite \ dbpage2.sqlite samplesbindir = .... samplesbin_SCRIPTS = ... dbpage_test_setup_build = ... EXTRA_Dist = $(sqlite_DATA) ... all: all-am |
这些都删掉。在页面的底部还有:
1
2
3
4 |
dbpage_test_setup.exe :$(dbpage_test_setup_build).... # ...... 一直到 ...... dbpage2.sqlite: dbpage_test_setup.exe $(RUNTIME) dbpage_test_setup.exe |
全部都需要删掉。三个页面都执行这样的删除操作。删除完后,再make,就能成功编译了。完了再
1 |
make install |
安装mono最麻烦的问题就是这里编译出错。网上查这个编译错误,貌似很多人都有遇到,但是又都没有说怎么解决。期间我还尝试升级sqlite3,可是没有升级成功。最后一个文件一个文件打开来看,才发现Makefile文件的秘密。主要是第一次折腾linux系统,所以多走了很多弯路。
4、安装mod_mono-2.8.tar.bz2。
安装这个也没有遇到什么问题,主要是如果你的apache文件不是安装在默认目录的,需要在configure命令时指定apache的bin目录。
5、都安装好后,剩下的就是配置apache了。
编辑$APACHE_PATH/conf/httpd.conf文件,增加一个配置:
1
2 |
#Mono module Include conf /mod_mono .conf |
安装mod_mono之后,这个mod_mono.cnf是自动生成的,和apache的httpd.conf在相同的目录。
对于网站的配置,Mono的官方网站有一个mod_mono的配置生成工具,建议使用里面的Virtual Host的方式来生成配置文件。它能帮我们生成这样的配置文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41 |
<VirtualHost *:80> ServerName mono.moozi.net ServerAdmin moozi@moozi.net DocumentRoot /srv/www/mono .moozi.net # MonoServerPath can be changed to specify which version of ASP.NET is hosted # mod-mono-server1 = ASP.NET 1.1 / mod-mono-server2 = ASP.NET 2.0 # For SUSE Linux Enterprise Mono Extension, uncomment the line below: # MonoServerPath mono.moozi.net "/opt/novell/mono/bin/mod-mono-server2" # For Mono on openSUSE, uncomment the line below instead: MonoServerPath mono.moozi.net "/usr/bin/mod-mono-server2" # To obtain line numbers in stack traces you need to do two things: # 1) Enable Debug code generation in your page by using the Debug="true" # page directive, or by setting <compilation debug="true" /> in the # application's Web.config # 2) Uncomment the MonoDebug true directive below to enable mod_mono debugging MonoDebug mono.moozi.net true # The MONO_IOMAP environment variable can be configured to provide platform abstraction # for file access in Linux. Valid values for MONO_IOMAP are: # case # drive # all # Uncomment the line below to alter file access behavior for the configured application MonoSetEnv mono.moozi.net MONO_IOMAP=all # # Additional environtment variables can be set for this server instance using # the MonoSetEnv directive. MonoSetEnv takes a string of 'name=value' pairs # separated by semicolons. For instance, to enable platform abstraction *and* # use Mono's old regular expression interpreter (which is slower, but has a # shorter setup time), uncomment the line below instead: # MonoSetEnv mono.moozi.net MONO_IOMAP=all;MONO_OLD_RX=1 MonoApplications mono.moozi.net "/:/srv/www/mono.moozi.net" <Location "/" > Allow from all Order allow,deny MonoSetServerAlias mono.moozi.net SetHandler mono < /Location > < /VirtualHost > |
为了提高apache的处理性能,我们需要对这个配置再做一些修改,最后的配置如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23 |
<VirtualHost *:80> ServerName mono.moozi.net ServerAdmin mono@moozi.net DocumentRoot /srv/www/mono .moozi.net/ MonoServerPath mono.moozi.net "/usr/local/bin/mod-mono-server4" #这里我用.net 4.0 MonoDebug mono.moozi.net true MonoSetEnv mono.moozi.net MONO_IOMAP=all MonoApplications mono.moozi.net "/:/srv/www/mono.moozi.net/" <Location "/" > Allow from all Order allow,deny MonoSetServerAlias mono.moozi.net SetHandler mono < /Location > <Location ~ "^/(styles|scripts|images)/" > SetHandler default-handler < /Location > <Location ~ "^/[^/]+\.(txt|html|ico|js|css|jpg|jpeg|gif|png)" > SetHandler default-handler < /Location > < /VirtualHost > |
这里我们增加了两个<Location />配置节,让静态资源文件使用apache的默认handler处理。
最后,重启apache就好了。
经过了近一周时间的折腾,终于成功地在腾讯社区开放平台部署好MONO环境。
我们的应用是腾讯社区开放平台的首个.NET应用,测试了一下午,程序运行状态良好。从感官上来看,响应比IIS还快…当然,事实还有待于验证。
杯具的是腾讯体验区的web服务器今天封网了,要年后初九才能上线到体验区…