小程序模板网

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

本文用于辅助这个问题的解答: 
服务器的同学,一个服务器怎么运行多个小程序 
分享者:孟星魂,原文地址

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

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

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

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

 

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

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

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



易优小程序(企业版)+灵活api+前后代码开源 码云仓库:starfork
本文地址:https://www.eyoucms.com/wxmini/doc/course/23404.html 复制链接 如需定制请联系易优客服咨询:800182392 点击咨询
QQ在线咨询