抛弃Nginx使用nodejs做反向代理服务器


时下不少场景,都是申请一个 VPS 主机来托管运行 Web 项目的,小弟我也不例外,购买了一个小型的 Win 03 VPS 使用着。在使用的过程中,面临一个问题,就是同一类型的服务端环境还好——但如果是一个 PHP、一个 ASP、 一个 JSP 的三种类型的服务端项目并存着,该怎么分配唯一的 80 端口呢?因为商业 WWW 网站的话,往往只能占用 80  端口,——当然,如果只是做服务的话,如接口之类的,使用其他端口就不会与 80 端口冲突了。许多开发者都会面临到 80 端口这个问题,并且实际情况会受到成本的限制。因为单独为一个项目就买一个 VPS,也不太经济、不太合算,管理起来也不方便。于是,我们就应该好好考虑一下,怎么在提供一个 80 端口的情况下,分发到多种服务端那里去,让不同的主机执行各自的 Web 项目。

亲,那这项需求我们说可以实现吗?是的,这并不是什么“神奇的技术”,也不是什么复杂的技术。不知你是否有了解,网络服务中的“反向代理(Reverse Proxy)”,其中的一个功能就是可以完成端口的分发的。我们不妨以域名为路由分发:凡是 AA.com 域名请求的,分发到 PHP 82 端口执行;凡是 BB.com 域名请求的,分发到 ASP 83 端口执行;…… 如此类推。当然这里的端口只说说明用而已,您可以任意配置,反正就是从 80 端口接收回来的请求,先作一次处理,进而分发。反向代理,通俗地讲,就是左手转右手而已。

每当提起反向代理器,人们通常一想到的就是 Nginx,但是今天我们暂时忽略大名鼎鼎的 Nginx,采用同样也是使用单线程、事件循环的服务端小弟——Nodejs 来达成。首先 Node 采用 JS 作服务端编程,而不是 Nginx 写配置或 Lua,比较符合我的味口,其次自己对 Node 也比较熟悉,配置各方面什么的更为顺手。

完成该项功能的是 node-http-proxy 包。下载、安装请键入:

npm install http-proxy

安装完毕后,新建一个 proxy.js 文件,输入:

var http = require('http'), httpProxy = require('http-proxy');

// 新建一个代理 Proxy Server 对象
var proxy = httpProxy.createProxyServer({});

// 捕获异常
proxy.on('error', function (err, req, res) {
 res.writeHead(500, {
 'Content-Type': 'text/plain'
 });
 res.end('Something went wrong. And we are reporting a custom error message.');
});

// 另外新建一个 HTTP 80 端口的服务器,也就是常规 Node 创建 HTTP 服务器的方法。
// 在每次请求中,调用 proxy.web(req, res config) 方法进行请求分发Create your custom server and just call `proxy.web()` to proxy
// a web request to the target passed in the options
// also you can use `proxy.ws()` to proxy a websockets request
//
var server = require('http').createServer(function(req, res) {
 // You can define here your custom logic to handle the request
 // and then proxy the request.
 var host = req.url;
 host = url.parse(host); host = host.host;
 
 console.log("host:" + req.headers.host);
 console.log("client ip:" + (req.headers['x-forwarded-for'] || req.connection.remoteAddress));
 
 proxy.web(req, res, { target: 'http://localhost:8080' });
});

console.log("listening on port 80")
server.listen(80);

若说使用代理服务器的代价,可能就是会比不用消耗多的资源,消耗多的 CPU 运算罢了。

使用问题:不能指定文件夹 proxy.web(req, res, { target: 'http://phpstudy.net:81/foo/' });



相关阅读:
jQuery封装的tab选项卡插件分享
JavaScript如何自定义trim方法
Laravel 5.3 学习笔记之 错误&日志
基于jQuery实现的旋转彩圈实例
简单记事本java源码实例
mysql数据库优化总结(心得)
C#中is与as的区别分析
PHP设计模式之简单投诉页面实例
C#实现自定义FTP操作封装类实例
Win10下DX12实测:老卡老U能力翻3倍
Jquery插件easyUi表单验证提交(示例代码)
详解Linux中用于查询用户信息的finger和chfn命令
AngularJs学习第八篇 过滤器filter创建
html制作细线表格的简单实例
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 小学六年级作文1000字:太阳菊花 教师节黑板报资料 我战胜了困难100字作文 有这样一片森林 一束野菊的情意作文900字 电容薄膜厂2016年年度年终工作总结 秋色如画作文350字 我妈叫我下个月去相亲什么意思 办公室月工作总结 这年,那些年 2015年高考作文预测:生活与创造 缺爱 20年后的学校350字 时光吹过的微风 寓意诗五首 Snow White and the Seven Dwarfs 人在,一切就在 流淌在逝去岁月里的温馨作文800字 剪一枝梅花落语 让冬日暖阳 祖国,您好! 乡镇卫生院院长群众路线教育实践活动心得体会 放慢自己 班级宠物一家亲读后感200字 一盆月季花作文300字 财政局保持党员先进性教育活动工作总结 2008奥运畅想之篮球 数学游戏:智救小白兔 地税局三进三同党性作风实践锻炼活动实施方案 小学五年级学习计划 失眠 中学2012—2013学年度教学工作计划 重阳节客户祝福短信 安全生产演讲稿总结(22) 一见倾心作文600字 【精品】企业调查报告范文 读《魔法水晶球》有感 音乐喷泉 陈劲阳作文200字 人民检察院经验交流材料 喜忧网络情 写景的作文:耸入云霄,天台山之行 物流部个人工作总结 2015幼师筑梦中国心得体会 初中初二作文450字:读课文《乌塔》有感 游香港海洋公园1200字 经典英语爱情语录 我恨你的眼睛,你的嘴唇,你的拥抱,恨你不喜爱我 三位80后IT创业精英回顾2012谈感想 2014年6月教师工作总结 我用平淡的眼神看你 记忆中秋作文800字 作文写你和书的故事

Copyright © 2016 phpStudy |