CentOS Linux上使用Apache/mono搭建.NET运行环境

Mono是一个跨平台的、开源的.NET开发框架。支持Linux系统,它是Novell公司基于SUSE Linux操作系统开发的。
 官网: http://mono-project.com/Main_Page
 
网上查了下,在Linux上要使用ASP.NET环境的Web服务器可以使用Apache+mod_mono方式或Mono+Jexus方式(Jexus是国人开发的一个免费软件),当然Nginx也可以支持。 http://www.mono-project.com/ASP.NET
 
官方软件包下载地址: http://ftp.novell.com/pub/mono/sources-stable/
 
Apache+mod_mono方式
 安装必备软件:
 

yum install bison make gcc gcc-c++ libstdc++-devel gettext pkgconfig glib2-devel
 
1、安装libgdiplus
 libgdiplus是mono中的System.Drawing依赖的一个组件,用于显示web页面基本颜色等。目前最新是libgdiplus-2.10。
 

cd /tmp
 wget  http://ftp.novell.com/pub/mono/sources/libgdiplus/libgdiplus-2.10.tar.bz2
 tar -xjvf libgdiplus-2.10.tar.bz2
 cd libgdiplus-2.10
 ./configure --prefix=/usr/local
 
生成makefile时提示失败:
 configure: WARNING: *** TIFF plug-in will not be built (TIFF library not found) ***
 checking for jpeg_destroy_decompress in -ljpeg... no
 configure: WARNING: *** JPEG loader will not be built (JPEG library not found) ***
 checking for DGifOpenFileName in -lgif... no
 configure: WARNING: *** GIF loader will not be built (giflibrary not found) ***
 checking for DGifOpenFileName in -lungif... no
 configure: WARNING: *** GIF loader will not be built (ungiflibrary not found) ***
 checking for libpng12... no
 checking for png_read_info in -lpng... no
 configure: error: *** libpng12 not found. See  http://www.libpng.org/pub/png/libpng.html.
 
缺少libtiff、libjpeg、libgif、libpng库。补了这些库之后还会提示有库缺少,一起装了:
 

yum install libtiff libtiff-devel libjpeg libjpeg-devel giflib giflib-devel libpng libpng-devel libX11 libX11-devel freetype freetype-devel fontconfig fontconfig-devel libexif libexif-devel
 
继续安装libgdiplus:
 

./configure --prefix=/usr/local
 make
 make install
 
2、安装Mono
 

cd /tmp
 wget  http://ftp.novell.com/pub/mono/sources/mono/mono-2.10.2.tar.bz2
 tar -xjvf mono-2.10.2.tar.bz2
 cd mono-2.10.2
 ./configure --prefix=/usr/local
 make
 make install
 
Mono安装之后,可以用命令mono -V查看一下mono的安装情况,如果能够看到mono版本号等信息,说明Mono安装成功。
 

3、安装Apache
 

cd /tmp
 wget  http://labs.renren.com/apache-mirror//httpd/httpd-2.2.21.tar.gz
 tar -xzvf httpd-2.2.21.tar.gz
 cd httpd-2.2.21
 ./configure --prefix=/usr/local/apache --enable-mods-shared=most
 make
 make install
 
4、安装mod_mono
 

cd /tmp
 wget  http://ftp.novell.com/pub/mono/sources/mod_mono/mod_mono-2.10.tar.bz2
 tar -xjvf mod_mono-2.10.tar.bz2
 cd mod_mono-2.10
 ./configure
 make
 make install
 
5、安装xsp
 xsp就是mod-mono-server。
 

cd /tmp
 wget  http://ftp.novell.com/pub/mono/sources/xsp/xsp-2.10.2.tar.bz2
 tar -xjvf xsp-2.10.2.tar.bz2
 cd xsp-2.10.2
 ./configure --prefix=/usr/local
 make
 make install
 
如果生成makefile时提示:
 checking for MONO_MODULE... configure: error: Package requirements (mono >= 2.10.0) were not met:
 
No package 'mono' found
 
Consider adjusting the PKG_CONFIG_PATH environment variable if you
 installed software in a non-standard prefix.
 
Alternatively, you may set the environment variables MONO_MODULE_CFLAGS
 and MONO_MODULE_LIBS to avoid the need to call pkg-config.
 See the pkg-config man page for more details.
 
需要设置环境变量,就能编译通过了:
 

export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig
 
6、配置Apache
 查看/usr/local/apache/conf里已经有mod_mono.conf文件了。
 
编辑httpd.conf:
 

vim /usr/local/apache/conf/httpd.conf
 
1)添加mod_mono.conf配置文件
 找到
 

# Server-pool management (MPM specific)
 #Include conf/extra/httpd-mpm.conf
 
在前面加入:
 

Include /usr/local/apache/conf/mod_mono.conf
 
2)将以下一句前的注释去掉:
 

#ServerName www.example.com:80
 
不设置ServerName,Apache在启动时会因为domain name报错。
 
3)建立测试页面:
 

vim /usr/local/apache/htdocs/test.aspx
 
输入: 

<%@ Page Language="C#" %>
 <html>
 <head>
 <title>hello world</title>
 </head>
 <body>
 <%
 for (int i=1; i<=7; i++)
 {
 Response.Write("<font size=" + i.ToString() + ">");
 Response.Write("hello world");
 Response.Write("</font><br />");
 }
 %>
 </body>
 </html>
 
4)重启Apache:
/usr/local/apache/bin/apachectl restart
 
5)访问测试页面:
 
http://IP/test.aspx
 
显示出以下内容表示成功。
 

6)设置Apache开机自启动:
 

vim /etc/rc.local
 
加入:
 

/usr/local/apache/bin/apachectl start
 
7)原理说明:
 上面所搭建asp.net运行环境,是以apache作为通讯框架,mod_mono作为接口桥(apache的插件),连接apache与xsp的通讯,xsp最终负责asp.net的服务处理,xsp会监听本地端口用来与mod_mono通讯,后者将处理结果返回给apache,apache再返回给客户端。

注意:默认情况下centos的防火墙是开启的,80端口访问不了。
下面是防火墙相关的问题:

对CentOS防火墙的设置问题,有很多的网友一直存在着不少的疑问,下面,就是我找到设置CentOS防火墙的方法,给大家展示一下。

看了好几个页面CentOS防火墙内容都有错,下面是正确方法:

#/sbin/iptables -I INPUT -p tcp --dport 80 -j ACCEPT  #/sbin/iptables -I INPUT -p tcp --dport 22 -j ACCEPT  
然后保存:#/etc/rc.d/init.d/iptables save 这样重启计算机后,防火墙默认已经开放了80和22端口

对CentOS防火墙设置已经完成了很重要的部分

这里应该也可以不重启计算机:#/etc/init.d/iptables restart防火墙的关闭,关闭其服务即可:查看防火墙信息:#/etc/init.d/iptables status关闭防火墙服务:#/etc/init.d/iptables stop永久关闭?

不知道怎么个永久法:#chkconfig –level 35 iptables off 再查看是否已经有了: 

[root@vcentos ~]# /etc/init.d/iptables status   Table: filter   Chain INPUT (policy ACCEPT)   num  target     prot opt source               destination           1    ACCEPT     udp  --  0.0.0.0/0            0.0.0.0/0           udp dpt:80   2    ACCEPT     tcp  --  0.0.0.0/0            0.0.0.0/0           tcp dpt:80   3    RH-Firewall-1-INPUT  all  --  0.0.0.0/0            0.0.0.0/0       Chain FORWARD (policy ACCEPT)   num  target     prot opt source               destination           1    RH-Firewall-1-INPUT  all  --  0.0.0.0/0            0.0.0.0/0  
以后大家就可以这样设置CentOS防火墙了。


在我们使用CentOS系统的时候,CentOS防火墙有时是需要改变设置的。CentOS防火墙默认是打开的,设置CentOS防火墙开放端口方法如下:

打开iptables的配置文件:
vi /etc/sysconfig/iptables
修改CentOS防火墙时注意:一定要给自己留好后路,留VNC一个管理端口和SSh的管理端口

下面是一个iptables的示例:

# Firewall configuration written by system-config-securitylevel
# Manual customization of this file is not recommended.
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
:RH-Firewall-1-INPUT - [0:0]
-A INPUT -j RH-Firewall-1-INPUT
-A FORWARD -j RH-Firewall-1-INPUT
-A RH-Firewall-1-INPUT -i lo -j ACCEPT
-A RH-Firewall-1-INPUT -p icmp –icmp-type any -j ACCEPT
-A RH-Firewall-1-INPUT -p 50 -j ACCEPT
-A RH-Firewall-1-INPUT -p 51 -j ACCEPT
-A RH-Firewall-1-INPUT -m state –state ESTABLISHED,RELATED -j ACCEPT
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 53 -j ACCEPT
-A RH-Firewall-1-INPUT -m state –state NEW -m udp -p udp –dport 53 -j ACCEPT
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 22 -j ACCEPT
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 25 -j ACCEPT
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 80 -j ACCEPT
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 443 -j ACCEPT
-A RH-Firewall-1-INPUT -j REJECT –reject-with icmp-host-prohibited
COMMIT

修改CentOS防火墙需要注意的是,你必须根据自己服务器的情况来修改这个文件。

举例来说,如果你不希望开放80端口提供web服务,那么应该相应的删除这一行:
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 80 -j ACCEPT

全部修改完之后重启iptables:
service iptables restart

你可以验证一下是否规则都已经生效:iptables -L

这样,我们就完成了CentOS防火墙的设置修改。


注意上边的mono   mod_mono   xsp  的安装包要从MOD官方下载。版本要对应,否则不会成功的


转自http://www.zhangyongjun.com/blog/article.asp?id=7541

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值