162 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			162 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|   | upstream official_backend { | |||
|  |     server 10.0.0.5:3000;          # 机器A的内网地址 | |||
|  |     server 10.0.0.15:3000;         # 机器B的内网地址 | |||
|  | } | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | log_format official_log '客户端IP: $remote_addr | 用户: $remote_user | 时间: $time_local | ' | |||
|  |                             '请求方法和路径: "$request" | 状态码: $status | 响应大小: $body_bytes_sent | ' | |||
|  |                             '来源页面: "$http_referer" | 客户端UA: "$http_user_agent" | ' | |||
|  |                             '上游服务器: $upstream_addr | 上游响应耗时: $upstream_response_time | ' | |||
|  |                             '请求总耗时: $request_time | Host: $host'; | |||
|  | 
 | |||
|  | 
 | |||
|  | #  1. 强制 HTTP 转 HTTPS(统一跳转到 lessie.ai) | |||
|  | server { | |||
|  |     listen 80; | |||
|  |     server_name lessie.ai www.lessie.ai; | |||
|  |     return 301 https://lessie.ai$request_uri; | |||
|  | } | |||
|  | 
 | |||
|  | #  2. 统一将 www.lessie.ai 重定向到 lessie.ai(HTTPS 保留) | |||
|  | server { | |||
|  |     listen 443 ssl; | |||
|  |     server_name www.lessie.ai; | |||
|  | 
 | |||
|  |     ssl_certificate /data/tengine/certificate/lessie.ai.pem; | |||
|  |     ssl_certificate_key /data/tengine/certificate/lessie.ai.key; | |||
|  | 
 | |||
|  |     ssl_protocols TLSv1.2 TLSv1.3; | |||
|  |     ssl_ciphers HIGH:!aNULL:!MD5; | |||
|  | 
 | |||
|  |     #  清除 HSTS | |||
|  |     add_header Strict-Transport-Security "max-age=0; includeSubDomains" always; | |||
|  | 
 | |||
|  |     return 301 https://lessie.ai$request_uri; | |||
|  | } | |||
|  | 
 | |||
|  | #  3. 正式服务站点(https://lessie.ai) | |||
|  | server { | |||
|  |     listen 443 ssl; | |||
|  |     server_name lessie.ai; | |||
|  | 
 | |||
|  |     ssl_certificate /data/tengine/certificate/lessie.ai.pem; | |||
|  |     ssl_certificate_key /data/tengine/certificate/lessie.ai.key; | |||
|  | 
 | |||
|  |     ssl_protocols TLSv1.2 TLSv1.3; | |||
|  |     ssl_ciphers HIGH:!aNULL:!MD5; | |||
|  | 
 | |||
|  |     access_log /data/tengine/logs/lessie.ai.official.access.log  official_log; | |||
|  |     error_log /data/tengine/logs/lessie.ai.official.error.log; | |||
|  | 
 | |||
|  | 
 | |||
|  |     location /video/lessie.mp4 { | |||
|  |         root /data/tengine/html/lessie_official; | |||
|  |         expires 30d; | |||
|  |         add_header Cache-Control "public"; | |||
|  |         add_header Accept-Ranges bytes; | |||
|  |     } | |||
|  | 
 | |||
|  |     #  反向代理到后端服务器渲染的nxut项目3000端口 | |||
|  |     location / { | |||
|  |         proxy_pass http://official_backend; | |||
|  |         proxy_set_header Host $host; | |||
|  |         proxy_set_header X-Real-IP $remote_addr; | |||
|  |     } | |||
|  | 
 | |||
|  |     # 禁止 logo 缓存(默认给用户方形) | |||
|  |     location = /favicon.svg { | |||
|  |         # 判断 UA,如果是 Googlebot,改写路径 | |||
|  |         if ($http_user_agent ~* "(Googlebot|Bingbot)") { | |||
|  |             rewrite ^/favicon.svg$ /favicon-google.svg last; | |||
|  |         } | |||
|  | 
 | |||
|  |         proxy_pass http://official_backend; | |||
|  |         proxy_set_header Host $host; | |||
|  |         proxy_set_header X-Real-IP $remote_addr; | |||
|  | 
 | |||
|  |         add_header Cache-Control "no-cache, no-store, must-revalidate" always; | |||
|  |         add_header Pragma "no-cache" always; | |||
|  |         add_header Expires 0 always; | |||
|  |     } | |||
|  | 
 | |||
|  |     # Googlebot 专用 favicon 文件(圆形图标) | |||
|  |     location = /favicon-google.svg { | |||
|  |         root /data/tengine/html/lessie_official; | |||
|  |         add_header Cache-Control "no-cache, no-store, must-revalidate" always; | |||
|  |         add_header Pragma "no-cache" always; | |||
|  |         add_header Expires 0 always; | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  |      | |||
|  |     # 第三方邮件件平台调国内email | |||
|  |     location /prod-api/webhook/ { | |||
|  |         proxy_pass http://129.204.158.54:4997/webhook/;  | |||
|  |         proxy_set_header Host 129.204.158.54; | |||
|  |         proxy_set_header X-Real-IP $remote_addr; | |||
|  |         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | |||
|  | 
 | |||
|  |         proxy_intercept_errors off; | |||
|  |         proxy_buffering off; | |||
|  |         proxy_cache off; | |||
|  |         proxy_set_header Connection keep-alive; | |||
|  | 
 | |||
|  |         add_header 'Access-Control-Allow-Origin' "$http_origin" always; | |||
|  |         add_header 'Access-Control-Allow-Credentials' 'true' always; | |||
|  |         add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE' always; | |||
|  |         add_header 'Access-Control-Allow-Headers' 'Authorization,Content-Type,X-Requested-With,Accept,Origin' always; | |||
|  | 
 | |||
|  |        if ($request_method = OPTIONS ) { | |||
|  |           return 204; | |||
|  |        } | |||
|  |     } | |||
|  | 
 | |||
|  |     # 第三方邮件件平台调硅谷email | |||
|  |     location /prod-api/webhook/us { | |||
|  |         proxy_pass http://10.0.10:4997/webhook/us; | |||
|  |         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_intercept_errors off; | |||
|  |         proxy_buffering off; | |||
|  |         proxy_cache off; | |||
|  |         proxy_set_header Connection keep-alive; | |||
|  | 
 | |||
|  |         add_header 'Access-Control-Allow-Origin' "$http_origin" always; | |||
|  |         add_header 'Access-Control-Allow-Credentials' 'true' always; | |||
|  |         add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE' always; | |||
|  |         add_header 'Access-Control-Allow-Headers' 'Authorization,Content-Type,X-Requested-With,Accept,Origin' always; | |||
|  | 
 | |||
|  |        if ($request_method = OPTIONS ) { | |||
|  |           return 204; | |||
|  |        } | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     # 第三方支付平台调用 | |||
|  |     location /payment/webhook/ { | |||
|  |         proxy_pass http://10.0.0.8:8090;  | |||
|  |         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_intercept_errors off; | |||
|  |         proxy_buffering off; | |||
|  |         proxy_cache off; | |||
|  |         proxy_set_header Connection keep-alive; | |||
|  | 
 | |||
|  |         add_header 'Access-Control-Allow-Origin' "$http_origin" always; | |||
|  |         add_header 'Access-Control-Allow-Credentials' 'true' always; | |||
|  |         add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE' always; | |||
|  |         add_header 'Access-Control-Allow-Headers' 'Authorization,Content-Type,X-Requested-With,Accept,Origin' always; | |||
|  | 
 | |||
|  |        if ($request_method = OPTIONS ) { | |||
|  |           return 204; | |||
|  |        } | |||
|  |     } | |||
|  | 
 | |||
|  | } |