首页 > 后端开发 > php教程 > 如何让apache和nodejs共用80端口

如何让apache和nodejs共用80端口

WBOY
发布: 2016-06-06 20:38:02
原创
1442 人浏览过

我的服务器上用apache搭建了php的服务器,已经有程序在跑了,现在在玩 ghost,用的是nodejs。那么问题来了,如何让他们同用80端口。

SF上面已经有一篇文章:http://segmentfault.com/q/1010000000702092,但是不符合我的要求,设置后无法达到效果,所有请求都被转发了。网上找了其他的文章,都发现不能符合我的要求。

我用了反向代理来解决,但是发现所有请求都被转发了,这不是我想要的。

假设我的域名是www.hello.com
我想通过一个域名,一个ip地址,80端口,只需要改变访问的url就能指定到不同的web服务器(指的是apache和nodejs) 我要实现的效果是:
1、www.hello.com或者hello.com访问我的ghost博客站点
2、www.hello.com/wechat/wx.php 或 hello.com/wechat/wx.php访问我的php站点

现在说说我的服务器目录设置:
1、php站点根目录在 /usr/local/apache/htdocs/,下面有wechat这个目录,是我的微信公众号后台服务器;
2、ghost站点在 /usr/local/apache/htdocs/ghost/,已经用nodejs启动了它,端口是2386。

在新增ghost站点之前,www.hello.com/wechat/ 是可以正常访问php站点的。

我在httpd.conf中加了这个设置:

<code><virtualhost>
ServerAdmin hello@foxmail.com
ServerName www.hello.com
ServerAlias hello.com

ProxyRequests Off

<proxy>
    Order deny,allow
    Allow from all
</proxy>    

ProxyPass / http://localhost:2386/ max=20 ttl=120 retry=300
ProxyPassReverse / http://localhost:2386/

ErrorLog "/usr/local/apache/logs/proxy_error.log" 
</virtualhost></code>
登录后复制
登录后复制

加了上述站点后,我的所有请求都被转发到ghost站点去了,也就是www.hello.com/wechat/wx.php 也被 转发到了 http://localhost:2386/,提示找不到网页404错误。

请问我要如何设置才能让php的请求不被反向代理转发?谢谢!

回复内容:

我的服务器上用apache搭建了php的服务器,已经有程序在跑了,现在在玩 ghost,用的是nodejs。那么问题来了,如何让他们同用80端口。

SF上面已经有一篇文章:http://segmentfault.com/q/1010000000702092,但是不符合我的要求,设置后无法达到效果,所有请求都被转发了。网上找了其他的文章,都发现不能符合我的要求。

我用了反向代理来解决,但是发现所有请求都被转发了,这不是我想要的。

假设我的域名是www.hello.com
我想通过一个域名,一个ip地址,80端口,只需要改变访问的url就能指定到不同的web服务器(指的是apache和nodejs) 我要实现的效果是:
1、www.hello.com或者hello.com访问我的ghost博客站点
2、www.hello.com/wechat/wx.php 或 hello.com/wechat/wx.php访问我的php站点

现在说说我的服务器目录设置:
1、php站点根目录在 /usr/local/apache/htdocs/,下面有wechat这个目录,是我的微信公众号后台服务器;
2、ghost站点在 /usr/local/apache/htdocs/ghost/,已经用nodejs启动了它,端口是2386。

在新增ghost站点之前,www.hello.com/wechat/ 是可以正常访问php站点的。

我在httpd.conf中加了这个设置:

<code><virtualhost>
ServerAdmin hello@foxmail.com
ServerName www.hello.com
ServerAlias hello.com

ProxyRequests Off

<proxy>
    Order deny,allow
    Allow from all
</proxy>    

ProxyPass / http://localhost:2386/ max=20 ttl=120 retry=300
ProxyPassReverse / http://localhost:2386/

ErrorLog "/usr/local/apache/logs/proxy_error.log" 
</virtualhost></code>
登录后复制
登录后复制

加了上述站点后,我的所有请求都被转发到ghost站点去了,也就是www.hello.com/wechat/wx.php 也被 转发到了 http://localhost:2386/,提示找不到网页404错误。

请问我要如何设置才能让php的请求不被反向代理转发?谢谢!

用nginx 可以做到..

在你的node外面使用nginx php用php-fpm和nginx通信,利用url规则转发完全满足你的需求。话说回来Apache的反向代理其实也可以,只是不如nginx简单好用速度快。还有在使用反向代理的时候node肯定不是和nginx同一个端口的啦。

<code><virtualhost>
    ServerName www.test.com
    ProxyRequests Off
    <proxy>
        Order deny,allow
        Allow from all
    </proxy>
    ProxyPass / http://127.0.0.1:9000/
    ProxyPassReverse / http://127.0.0.1:9000/
</virtualhost>
</code>
登录后复制

请注意看这里:

<code>ProxyPass / http://127.0.0.1:9000/
ProxyPassReverse / http://127.0.0.1:9000/
</code>
登录后复制

是指将/转发到http://127.0.0.1:9000/也就是将所有的请求都转到9000端口了。

试下这样子是否ok。

<code>ProxyPass / http://127.0.0.1:2386/
ProxyPassReverse / http://127.0.0.1:2386/
ProxyPass /wechat/wx.php http://localhost:80/ 
ProxyPassReverse /wechat/wx.php http://localhost:80/
</code>
登录后复制
相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板