因为只有一台服务器(win2003 server) 既需要在上面跑asp程序 又需要在上面跑php应用 又不想用iis跑php应用 还有就是不想把asp程序跑在apache上 就需要一个apache与iis共存的方案。
iis是windows2003 server自带的iis6.0
apache是apache2.2.8
--------------------------------------------
首先当然是下载并安装apache
接着开始先把自动启动的iis服务器停下来,修改iis的端口为非80(比如8081)
再接着打开apache的httpd.conf文件开始配置
要让apache支持转发也就是做iis的代理那么就要先启用apache的代理模块:
#LoadModule proxy_module modules/mod_proxy.so
-->LoadModule proxy_module modules/mod_proxy.so
#LoadModule proxy_connect_module modules/mod_proxy_connect.so
-->LoadModule proxy_connect_module modules/mod_proxy_connect.so
#LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
-->LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
#LoadModule proxy_http_module modules/mod_proxy_http.so
-->LoadModule proxy_http_module modules/mod_proxy_http.so
完成了代理模块的启用 那么我们开始配置虚拟主机
先包含httpd-vhosts.conf文件
#Include conf/extra/httpd-vhosts.conf
-->Include conf/extra/httpd-vhosts.conf
保存httpd.conf,打开httpd-vhosts.conf文件
----------------------------------------------
开始配置虚拟机
NameVirtualHost *:80
<VIRTUALHOST *:80>
ServerAdmin [email protected]
ServerName www.b.com
DocumentRoot "C:/Program Files/Apache Software Foundation/Apache2.2/htdocs"
</VIRTUALHOST >
<VIRTUALHOST *:80>
ProxyPreserveHost On
ServerAdmin [email protected]
ServerName www.a.com
DefaultLanguage zh-CN
AddDefaultCharset GB2312
ProxyPass / http://www.a.com:8081/
ProxyPassReverse / http://www.a.com:8081/
</VIRTUALHOST>
配置完成并保存httpd-vhosts.conf
开始重启apache服务器和iis服务器
我们通过www.a.com访问过去就会看到iis的默认页面
通过www.b.com访问过去就可以看到it's work。
这样我们就实现了iis和apache共享80端口
==================================================
各种方法总结
IIS和APACHE如何共用80端口?
在现一台服务器上安装了IIS之后,因工作需要又得安装APACHE,网上说把IIS设置为81端口,APACHE设置为80端口,然后可以通过APACHE代理功能来实现,可我试一下只有IIS的WEB功能可以正常访问。无法解析出APACHE的网页来。请问有哪位具体配置过?如果配置过的话,那么具体如何做?
问题补充 2008-10-31 15:28
刚才有一位朋友给了网上的实现方法。不过我只有一个互联网上的IP。无法按照方法一去实现。我想请问一下用方法三的时候其他什么地方还需要进行修改吗?目前就是按方法三来处理的,可就是得不到满意的效果。
---------
- 答案 -
---------
这个问题我也遇到过,下面是网络上提供的方法,我用的方法一实现的,你可以试下:
本机安装iis与apache,无法同时使用80端口,现给出解决方法:
--------------------------------------------------------------------------
方法一:
IIS5,多IP下共存,IIS为192.168.0.1,apache为192.168.0.2 原文地址
c:InetpubAdminscripts
cscript adsutil.vbs set w3svc/disablesocketpooling true
该命令反馈如下disablesocketpooling : (BOOLEAN) True
重启IIS
InetpubAdminScripts>cscript adsutil.vbs set w3svc/disablesocketpooling true
由于 DisableSocketPooling 在 IIS 6.0 元数据库架构 (MBSchema.xml) 中被定义为有效属性,所以,您仍然可以使用 Adsutil.vbs 设置该属性,但这种设置不起作用。IIS 6.0 中的功能是新增的核心级别驱动程序 HTTP.sys 的一部分。要配置 HTTP.sys,您必须使用 Httpcfg.exe
------------------------------------------------------------------------------
方法二:
IIS6,多IP下共存,IIS为192.168.0.1,apache为192.168.0.2 原文地址
到2003的CD下的 support/tools/Support.cab。解压出httpcfg.exe文件,COPY到windows/system32/目录下,用法自己看帮助
命令行
绑定到某IP: httpcfg set iplisten -i 192.168.0.1
即命令使用IIS的只监听指定的IP及端口
查看绑定: httpcfg query iplisten
删除绑定: httpcfg delete iplisten -i 192.168.0.1
命令行
net stop Apache2
net stop iisadmin /y
net START Apache2
net START w3svc
保证iis下的ip设置为全局默认,Apache中httpconf设置listen 192.168.0.2:80,就应该可以两个服务同时运行,相互不冲突了。
IIS的访问地址为http://192.168.0.1,Apache访问地址为http://192.168.0.2
-----------------------------------------------------------------------
方法三:
网上常用的单IP共用80端口方法,不过不推荐,只是使用Apache的代理,速度有影响将apache设为使用80端口,IIS使用其它端口,比如81,然后将apache作为IIS的代理。
在httpd.conf里面,取消下面四行的注释:
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_connect_module modules/mod_proxy_connect.so
LoadModule proxy_http_module modules/mod_proxy_http.so
LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
然后建立一个虚拟主机,将该域名的所有访问转向81端口。
ServerName iloves.vicp.net
ProxyPass / http://localhost:81/
ProxyPassReverse / http://localhost:81/
这样,对外就可以只需要一个端口,即可同时使用apache和IIS的功能了
类推,使用第二种方法,你可以在IIS上配置PHP4,Apache2中配置PHP5,只需要IIS中安装PHP4,把php.ini复制到windows目录即可,这个就不用说了吧,Apache2中,只要把PHP5的php.ini放在PHP5安装目录里面就行了
配置Apache以支持PHP5:
LoadModule php5_module "D:/PHPServer/PHP5/php5apache2.dll"
AddType application/x-httpd-php .php
DirectoryIndex index.html index.php
PHPIniDir "D:/PHPServer/PHP5"
其中最重要的一条就是 PHPIniDir,用来指明php.ini文件所在位置,即PHP5的安装目录,注意所有目录的应该改为D:/PHPServer/PHP5这种格式,而非D:PHPServerPHP5,IIS的访问地址为http://192.168.0.1,Apache访问地址为http://192.168.0.2
声明: 此文观点不代表本站立场;转载须要保留原文链接;版权疑问请联系我们。