在Node.js中的单个URL上托管2个网站
我有2个网站使用angular universal(用于SEO)编译。我需要在一个url上托管这两个网站。根据url更改,它将被定向到相关网站 项目结构在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 我是这个环境的新手,这是我尝试过的代码,但是端口冲突,甚至更改端口都不起作用。任何帮助都将
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?但没有提到每个应用程序需要如何/在哪里放置这些号码才能使用它们