我如何使用 tomcat 进行多域配置 NGINX?
How can i do multi domain config NGINX with tomcat?
我有一台云服务器和两个域。
我取得了一次成功,但第二个域无法正常工作。
工作会议;
server {
listen 80;
listen [::]:80;
server_name www.fromthepast.org fromthepast.org;
access_log /var/log/nginx/fromthepast-access.log main;
error_log /var/log/nginx/fromthepast-error.log;
location / {
proxy_set_header Host $host:$proxy_port;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://localhost:8080/;
}
}
您可以看到进入网站 fromthepast.org 它工作正常。
配置错误
server {
listen 80;
listen [::]:80;
server_name www.suyla.org suyla.org;
access_log /var/log/nginx/suylaaccess.log main;
error_log /var/log/nginx/suyla-error.log;
location / {
proxy_set_header Host $host:$proxy_port;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://localhost:8080/denizhan;
}
}
实际上它可以工作但不正确。
你可以看到输入 suyla.org > 重定向 http://suyla.org:8080/denizhan
我不想要 :8080 端口,只需要 suyla.org 或 suyla.org/denizhan
如何使用 tomcat 进行多域配置 NGINX?
尝试将您的配置更改为类似的内容:
server {
listen 80;
server_name www.suyla.org suyla.org;
access_log /var/log/nginx/suylaaccess.log main;
error_log /var/log/nginx/suyla-error.log;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_http_version 1.1;
proxy_pass http://localhost:8080/denizhan;
}
}
我修好了。例子;
/etc/nginx/conf.d
server {
listen 80;
listen [::]:80;
server_name www.suyla.org suyla.org;
access_log /var/log/nginx/suyla-access.log main;
error_log /var/log/nginx/suyla-error.log;
location / {
proxy_set_header Host $host:$proxy_port;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://localhost:8082/;
}
}
并重定向 8082
多一个配置 > ../tomcat/conf/server.xml
<Service name="denizhan">
<Connector port="8082" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="8444" />
<Engine name="Catalina" defaultHost="localhost">
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
<Context path="" docBase="/opt/tomcat/webapps/denizhan" reloadable="false" useHttpOnly="true">
<Manager pathname=""/>
</Context>
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_accessss_log" suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
</Host>
</Engine>
</Service>
如果我想要更多的域和应用程序,我将重定向 8083,谢谢大家
我有一台云服务器和两个域。
我取得了一次成功,但第二个域无法正常工作。
工作会议;
server {
listen 80;
listen [::]:80;
server_name www.fromthepast.org fromthepast.org;
access_log /var/log/nginx/fromthepast-access.log main;
error_log /var/log/nginx/fromthepast-error.log;
location / {
proxy_set_header Host $host:$proxy_port;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://localhost:8080/;
}
}
您可以看到进入网站 fromthepast.org 它工作正常。
配置错误
server {
listen 80;
listen [::]:80;
server_name www.suyla.org suyla.org;
access_log /var/log/nginx/suylaaccess.log main;
error_log /var/log/nginx/suyla-error.log;
location / {
proxy_set_header Host $host:$proxy_port;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://localhost:8080/denizhan;
}
}
实际上它可以工作但不正确。
你可以看到输入 suyla.org > 重定向 http://suyla.org:8080/denizhan
我不想要 :8080 端口,只需要 suyla.org 或 suyla.org/denizhan
如何使用 tomcat 进行多域配置 NGINX?
尝试将您的配置更改为类似的内容:
server {
listen 80;
server_name www.suyla.org suyla.org;
access_log /var/log/nginx/suylaaccess.log main;
error_log /var/log/nginx/suyla-error.log;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_http_version 1.1;
proxy_pass http://localhost:8080/denizhan;
}
}
我修好了。例子;
/etc/nginx/conf.d
server {
listen 80;
listen [::]:80;
server_name www.suyla.org suyla.org;
access_log /var/log/nginx/suyla-access.log main;
error_log /var/log/nginx/suyla-error.log;
location / {
proxy_set_header Host $host:$proxy_port;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://localhost:8082/;
}
}
并重定向 8082
多一个配置 > ../tomcat/conf/server.xml
<Service name="denizhan">
<Connector port="8082" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="8444" />
<Engine name="Catalina" defaultHost="localhost">
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
<Context path="" docBase="/opt/tomcat/webapps/denizhan" reloadable="false" useHttpOnly="true">
<Manager pathname=""/>
</Context>
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_accessss_log" suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
</Host>
</Engine>
</Service>
如果我想要更多的域和应用程序,我将重定向 8083,谢谢大家