【问题标题】:Hosting 2 website on a single URL in Node.js在 Node.js 中的单个 URL 上托管 2 个网站
【发布时间】:2018-12-30 18:40:36
【问题描述】:

我有 2 个使用 angular-universal(用于 SEO)编译的网站。我需要在一个 url 上托管这两个网站。根据 url 更改,它将被定向到相关网站

项目结构

dist
  - repair    
      -browser    
      -server    
      -server.js
  - renew
    - browser
    - server
    - server.js

我是这个环境的新手,这是我尝试过的代码,但端口发生冲突,甚至更改端口也不起作用。任何帮助将不胜感激

    app.get('/repair', (req, res, next) => {
    try {
        const port = process.env.PORT || 8080;
        const server = require('./dist/repair/server.js');
        server.app.listen(port, () => {
            console.log(`Listening on: http://localhost:${port}`);
        });
    } catch (error) {
        let err = new def.NError(500, messages.errInternalServerError, error.message);
        next(err);
    }
    console.log("repair");
});

app.get('/renew', (req, res, next) => {
    try {
        const port = process.env.PORT || 8080;
        const server = require('./dist/renew/server.js');
        server.app.listen(port, () => {
            console.log(`Listening on: http://localhost:${port}`);
        });
    } catch (error) {
        let err = new def.NError(500, messages.errInternalServerError, error.message);
        next(err);
    }
    console.log("renew");
});


var server = app.listen(process.env.PORT || 8080, function () {
    console.log('server running', ' at port: ', 8080);
});

【问题讨论】:

  • 您可以在不同的端口(私有)上运行每个端口,然后在公共端口上运行第三个端口,这将根据 url 将请求传输到正确的 nodejs 实例

标签: node.js angular angular-universal


【解决方案1】:

您的情况的最佳解决方案是使用 nginx(Web 服务器)代理而不是 nodejs 重定向。

解决方案 1:下面是使用 nginx 进行代理的解决方案。

    #worker_processes 2;

events {
    worker_connections 1024;
}
http {
   sendfile on;

   gzip on;
   gzip_disable "msie6";

   gzip_vary on;
   gzip_proxied any;
   gzip_comp_level 6;
   gzip_buffers 16 8k;
   gzip_http_version 1.1;
   gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

    log_format timed_combined '$remote_addr - $remote_user [$time_local] '
    '"$request" $status $body_bytes_sent '
    '"$http_referer" "$http_user_agent" '
    '$request_time $upstream_response_time $pipe';

    access_log /var/log/nginx/access.log timed_combined;
    error_log /var/log/nginx/error.log;

    include /etc/nginx/mime.types;
    default_type application/octet-stream;

    upstream api_server {
        server 127.0.0.1:8042;
    }

    upstream admin_server {
        server 127.0.0.1:8043;
    }

    server {
        listen 80;
        server_name _;
        return 404;
    }

   server {
        listen 80;
        server_name www.example.com;

        location / {
           proxy_pass         http://api_server;
           proxy_redirect     off;
           proxy_set_header   Host $host;
           proxy_set_header   X-Real-IP $remote_addr;
           proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
           proxy_set_header   X-Forwarded-Host $server_name;
        }


        location /proj-admin {
           proxy_pass         http://admin_server;
           proxy_redirect     off;
           proxy_set_header   Host $host;
           proxy_set_header   X-Real-IP $remote_addr;
           proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
           proxy_set_header   X-Forwarded-Host $server_name;
        }

    }
}

用上面的配置替换 nginx.conf。

解决方案 2:仍然如果您想使用 nodejs 进行代理

How to redirect to another page in node.js

【讨论】:

  • 您忘了提及使用列出的端口运行每个应用程序
  • 这两个是同一个版本吗?
  • 我不知道,但 OP 正试图将它们合二为一
  • 如果您可以通过在 Angular Universal 中更改 server.ts 文件中的端口,在两个端口中构建 2 个应用程序,那就更好了。只是使用网络服务器代理,我总是建议你这样做,因为当你扩展你的应用程序时,这是最好的方法。
  • 我同意,我只是说你随机选择了 8042 和 8043?但还没有提到需要如何/在哪里放置这些数字才能让每个应用程序与它们一起使用
猜你喜欢
  • 2013-02-19
  • 1970-01-01
  • 1970-01-01
  • 2020-06-27
  • 2016-05-24
  • 2015-10-11
  • 2013-02-14
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多