抛弃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学习笔记之FS文件模块
Jan 13 NodeJs
使用nodejs下载风景壁纸
Feb 05 NodeJs
nodejs处理图片的中间件node-images详解
May 08 NodeJs
Express+Nodejs 下的登录拦截实现代码
Jul 01 NodeJs
详解HTTPS 的原理和 NodeJS 的实现
Jul 04 NodeJs
nodejs后台集成ueditor富文本编辑器的实例
Jul 11 NodeJs
nodejs调取微信收货地址的方法
Dec 20 NodeJs
nodejs更改项目端口号的方法
May 13 NodeJs
Nodejs 发布自己的npm包并制作成命令行工具的实例讲解
May 15 NodeJs
Nodejs中怎么实现函数的串行执行
Mar 02 NodeJs
nodejs中request库使用HTTPS代理的方法
Apr 30 NodeJs
nodejs处理tcp连接的核心流程
Feb 26 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
使用Thinkphp框架开发移动端接口
2015/08/05 PHP
jquery中的sortable排序之后的保存状态的解决方法
2010/01/28 Javascript
jQuery源码分析-05异步队列 Deferred 使用介绍
2011/11/14 Javascript
javascript中获取下个月一号,是星期几
2012/06/01 Javascript
js获取控件位置以及不同浏览器中的差别介绍
2013/08/08 Javascript
jquery移除、绑定、触发元素事件使用示例详解
2014/04/10 Javascript
js限制文本框的输入内容代码分享(3类)
2015/08/20 Javascript
jquery实现可横向和竖向展开的动态下滑菜单效果
2015/08/24 Javascript
JS数组合并push与concat区别分析
2015/12/17 Javascript
Bootstrap轮播加上css3动画,炫酷到底!
2015/12/22 Javascript
基于JQuery实现图片上传预览与删除操作
2016/05/24 Javascript
jQuery选取所有复选框被选中的值并用Ajax异步提交数据的实例
2017/08/04 jQuery
vue移动端UI框架实现QQ侧边菜单组件
2018/03/09 Javascript
从零开始学习搭建React脚手架项目
2018/08/23 Javascript
js实现随机8位验证码
2020/07/24 Javascript
jQuery删除/清空指定元素的所有子节点实例代码
2019/07/04 jQuery
vue 集成 vis-network 实现网络拓扑图的方法
2019/08/07 Javascript
js实现滑动进度条效果
2020/08/21 Javascript
python中的迭代和可迭代对象代码示例
2017/12/27 Python
python如何把嵌套列表转变成普通列表
2018/03/20 Python
python多线程+代理池爬取天天基金网、股票数据过程解析
2019/08/13 Python
基于Python和PyYAML读取yaml配置文件数据
2020/01/13 Python
Numpy 多维数据数组的实现
2020/06/18 Python
美国生鲜及杂货电商:FreshDirect
2018/01/29 全球购物
可爱的童装和鞋子:Fabkids
2019/08/16 全球购物
.net软件工程师应聘上机试题
2015/03/10 面试题
精选干货:Java精选笔试题附答案
2014/01/18 面试题
商务日语毕业生自荐信
2013/11/23 职场文书
通用自荐信范文
2014/03/14 职场文书
幼儿园大班区域活动总结
2014/07/09 职场文书
美术学专业求职信
2014/07/23 职场文书
公司搬迁通知
2015/04/20 职场文书
2015年乡镇平安建设工作总结
2015/05/13 职场文书
初三英语教学反思
2016/02/15 职场文书
python爬虫--selenium模块
2021/03/31 Python
解决pytorch-gpu 安装失败的记录
2021/05/24 Python