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


Posted in NodeJs onJuly 17, 2014

时下不少场景,都是申请一个 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://3water.com:81/foo/' });

NodeJs 相关文章推荐
基于NodeJS的前后端分离的思考与实践(四)安全问题解决方案
Sep 26 NodeJs
轻松创建nodejs服务器(5):事件处理程序
Dec 18 NodeJs
nodejs的HTML分析利器node-jquery用法浅析
Nov 08 NodeJs
nodejs连接mysql数据库简单封装示例-mysql模块
Apr 10 NodeJs
nodejs个人博客开发第七步 后台登陆
Apr 12 NodeJs
nodejs入门教程二:创建一个简单应用示例
Apr 24 NodeJs
nodejs入门教程三:调用内部和外部方法示例
Apr 24 NodeJs
NodeJs中express框架的send()方法简介
Jun 20 NodeJs
nodejs中Express与Koa2对比分析
Feb 06 NodeJs
nodejs更新package.json中的dependencies依赖到最新版本的方法
Oct 10 NodeJs
使用nodejs分离html文件里的js和css详解
Apr 12 NodeJs
NodeJS实现一个聊天室功能
Nov 25 NodeJs
nodejs的10个性能优化技巧
Jul 15 #NodeJs
提高NodeJS中SSL服务的性能
Jul 15 #NodeJs
在NodeJS中启用ECMAScript 6小结(windos以及Linux)
Jul 15 #NodeJs
nodejs 实现模拟form表单上传文件
Jul 14 #NodeJs
14款NodeJS Web框架推荐
Jul 11 #NodeJs
基于promise.js实现nodejs的promises库
Jul 06 #NodeJs
我的NodeJs学习小结(一)
Jul 06 #NodeJs
You might like
PHP安装全攻略:APACHE
2006/10/09 PHP
深入探讨<br />和 \r\n两者有什么区别??
2013/06/05 PHP
php生成EAN_13标准条形码实例
2013/11/13 PHP
php获取数组元素中头一个数组元素值的实现方法
2014/12/20 PHP
制作安全性高的PHP网站的几个实用要点
2014/12/30 PHP
Laravel+jQuery实现AJAX分页效果
2016/09/14 PHP
YII框架学习笔记之命名空间、操作响应与视图操作示例
2019/04/30 PHP
js 强制弹出窗口代码研究-又一款代码
2010/03/20 Javascript
JS 类型转换常见方法小结
2010/05/31 Javascript
javascript重复绑定事件造成的后果说明
2013/03/02 Javascript
jquery sortable的拖动方法示例详解
2014/01/16 Javascript
AngularJS入门教程之Select(选择框)详解
2016/07/27 Javascript
js仿百度音乐全选操作
2017/01/13 Javascript
使用JQ完成表格隔行换色的简单实例
2017/08/25 Javascript
Vue无限滑动周选择日期的组件的示例代码
2018/07/18 Javascript
angular2 组件之间通过service互相传递的实例
2018/09/30 Javascript
使用 JavaScript 创建并下载文件(模拟点击)
2019/10/25 Javascript
在VUE style中使用data中的变量的方法
2020/06/19 Javascript
原生js实现移动小球(碰撞检测)
2020/12/17 Javascript
简单实现python爬虫功能
2015/12/31 Python
Python黑魔法@property装饰器的使用技巧解析
2016/06/16 Python
轻松掌握python设计模式之访问者模式
2016/11/18 Python
python使用pygame框架实现推箱子游戏
2018/11/20 Python
实例讲解Python中浮点型的基本内容
2019/02/11 Python
python实时检测键盘输入函数的示例
2019/07/17 Python
Python3操作MongoDB增册改查等方法详解
2020/02/10 Python
非常漂亮的CSS3百叶窗焦点图动画
2016/02/24 HTML / CSS
HTML5 自动聚焦(autofocus)属性使用介绍
2013/08/07 HTML / CSS
荷兰和比利时时尚鞋店:Van Dalen
2018/04/23 全球购物
社区居务公开实施方案
2014/03/27 职场文书
拾金不昧表扬稿
2015/01/16 职场文书
2015年团队工作总结范文
2015/05/04 职场文书
学生通报表扬范文
2015/05/04 职场文书
爱鸟护鸟的宣传语
2015/07/13 职场文书
nginx 防盗链防爬虫配置详解
2021/03/31 Servers
Java异常体系非正常停止和分类
2022/06/14 Java/Android