ฉันกำลังพยายามปรับใช้เซิร์ฟเวอร์ Tomcat & Nginx บนอินสแตนซ์ AWS EC2 เดียว ฉันมี 3 อินสแตนซ์ & ในแต่ละอินสแตนซ์ ฉันต้องการปรับใช้เซิร์ฟเวอร์ Nginx & Tomcat ด้านล่างนี้คือไฟล์กำหนดค่าของฉัน
/etc/nginx/nginx.conf
ผู้ใช้ www-data;
worker_processes อัตโนมัติ
pid /run/nginx.pid;
รวม /etc/nginx/modules-enabled/*.conf;
เหตุการณ์ {
worker_connections 768;
}
http {
ส่งไฟล์บน;
tcp_nopush บน;
tcp_nodelay บน;
keepalive_timeout 65;
types_hash_max_size 2048;
รวม /etc/nginx/mime.types;
แอปพลิเคชัน default_type/octet-stream;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
เปิด ssl_prefer_server_ciphers;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
เปิด gzip;
รวม /etc/nginx/conf.d/*.conf;
}"
/etc/nginx/conf.d/application.conf
เซิร์ฟเวอร์ {
ฟัง 80 default_server;
ฟัง [::]:80 default_server;
server_name localhost;
รูท /var/lib/tomcat9/webapps/ROOT;
ดัชนี deploy.html;
ตำแหน่ง / ผู้ดูแลระบบ {
try_files $uri $uri/ /deploy.html;
}
ตำแหน่ง /admin/admin-พอร์ทัล {
นามแฝง /opt/tomcat/webapps/ROOT/;
เขียนใหม่ /admin-portal/(.*) /$1 ตัวแบ่ง;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-ส่งต่อเซิร์ฟเวอร์ $host;
proxy_set_header X-ส่งต่อ-สำหรับ $proxy_add_x_forwarded_for;
proxy_pass http://localhost:8080/;
}
ตำแหน่ง ~ \.css {
add_header เนื้อหา-ประเภทข้อความ/css;
}
ตำแหน่ง ~ \.js {
แอปพลิเคชันประเภทเนื้อหา add_header/x-javascript;
}
เป้าหมายของฉันคือ เมื่อฉันกด http://IP/ หรือ HTTP://IP/admin มันควรจะเปลี่ยนเส้นทางไปที่ deploy.html และเมื่อฉันกด HTTP://IP/admin/admi-portal มันควรจะเปิดเซิร์ฟเวอร์ tomcat
หมายเหตุ: ฉันประสบความสำเร็จในทั้งสองเงื่อนไขยกเว้นเมื่อฉันกด HTTP://IP/admin/admi-portal จากนั้นจะเปิดเฉพาะหน้า HTML และไฟล์ CSS/png/js ได้รับข้อผิดพลาด 404:not found
/opt/tomcat/webapps/ROOT/ นี่คือเส้นทางไฟล์สำหรับไฟล์คงที่ Tomcat ทั้งหมด CSS/js/png เป็นต้น
ใครสามารถช่วยฉันได้บ้าง