在Node.js中的单个URL上托管2个网站

在Node.js中的单个URL上托管2个网站,node.js,angular,angular-universal,Node.js,Angular,Angular Universal,我有2个网站使用angular universal(用于SEO)编译。我需要在一个url上托管这两个网站。根据url更改,它将被定向到相关网站 项目结构 dist - repair -browser -server -server.js - renew - browser - server - server.js 我是这个环境的新手,这是我尝试过的代码,但是端口冲突,甚至更改端口都不起作用。任何帮助都将

我有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);
});

对于您的情况,最好的解决方案是使用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代理,仍然是这样


您可以在不同的端口(专用)上运行每个应用程序,然后在公共端口上运行第三个应用程序,该端口将根据URL将请求传输到正确的nodejs实例。您忘了提及使用这些端口运行每个应用程序。这两个是相同的版本?我不知道,但是OP正在尝试将它们变成一个。如果你可以通过在angular universal中更改server.ts文件中的端口,在两个端口中构建两个应用程序,那就更好了。只是使用webserver代理,我总是建议您这样做,因为当您扩展应用程序时,这是最好的方法。我同意,我只是说您随机选择了8042和8043?但没有提到每个应用程序需要如何/在哪里放置这些号码才能使用它们