用户
 找回密码
 立即注册

QQ登录

只需一步,快速开始

微客吧 首页 教程 微信小程序 新手教程 查看内容

node插件http-proxy反向代理实现对端口的分发

纸飞机 2018-3-8 09:37

本文用于辅助这个问题的解答: 分享者:孟星魂,原文地址最近自己动手做了一个微信,是直接买的腾讯云的小程序解决方案,怎么说那,用起来还是会遇到不少问题的,不过在交流群里还是会有很多人帮助你的。闲话少说, ...

本文用于辅助这个问题的解答:

分享者:孟星魂,

原文地址

最近自己动手做了一个微信,是直接买的腾讯云的小程序解决方案,怎么说那,用起来还是会遇到不少问题的,不过在交流群里还是会有很多人帮助你的。

闲话少说,因为要再做一个别的服务,就想直接用这台小程序的服务器就好了,但是服务器的80端口已经被小程序占用了,所以只能使用反向代理,说白了就是完成端口的分发。我们不妨以域名为路由分发:凡是 AA.com 域名请求的,分发到 PHP 82 端口执行;凡是 BB.com 域名请求的,分发到 ASP 83 端口执行;…… 如此类推。当然这里的端口只说说明用而已,您可以任意配置,反正就是从 80 端口接收回来的请求,先作一次处理,进而分发。反向代理,通俗地讲,就是左手转右手而已。

放到我实际的项目里面,先npm init一个新的项目,安装http-proxy插件用来反向代理,这个服务占用80接口,然后我把之前小程序占用的80接口,改为了3000接口。(这个端口号大家随便选)。

在项目下面新建一个app.js文件,内容如下:

  1. var http = require('http'), httpProxy = require('http-proxy');
  2. // 新建一个代理 Proxy Server 对象
  3. var proxy = httpProxy.createProxyServer({});
  4. // 捕获异常
  5. proxy.on('error', function (err, req, res) {
  6. res.writeHead(500, {
  7. 'Content-Type': 'text/plain'
  8. });
  9. res.end('Something went wrong. And we are reporting a custom error message.');
  10. });
  11. // 在每次请求中,调用 proxy.web(req, res config) 方法进行请求分发
  12. var server = require('http').createServer(function(req, res) {
  13. // 在这里可以自定义你的路由分发
  14. var host = req.headers.host, ip = req.headers['x-forwarded-for'] || req.connection.remoteAddress;
  15. console.log("client ip:" + ip + ", host:" + host);
  16. switch(host){
  17. case 'www.111.cn':
  18. proxy.web(req, res, { target: 'http://localhost:3000' });
  19. break;
  20. case 'vote.111.cn':
  21. proxy.web(req, res, { target: 'http://localhost:9527' });
  22. break;
  23. default:
  24. res.writeHead(200, {
  25. 'Content-Type': 'text/plain'
  26. });
  27. res.end('Welcome to my server!');
  28. }
  29. });
  30. console.log("listening on port 80")
  31. server.listen(80);

如代码所示,当访问www.111.cn的时候,请求就被转发到了3000接口上,访问vote.111.cn时就被转发到了9527这个接口上,自己当时很困惑的是怎么在小程序的80接口上去做转发,其实80是个独立的服务,只做转发这个一件事情,别的服务都要放到别的端口上去的。

用node做服务器的话,推荐大家用pm2来做管理,这样可以把一台服务器上的所有服务都监管起来,利于开发调试。

鲜花
鲜花
握手
握手
雷人
雷人
路过
路过
鸡蛋
鸡蛋
分享至 : QQ空间
收藏