技术解析

nginx 反向代理同一个域名的不同端口
0
2021-05-19 21:22:54
idczone

我的需求是:

  1. 同一个域名范文,通过指定 URL 访问具体的端口
  2. 不使用二级域名
  3. 全局 https,强制 http 转 https

现在我解决了,http 和 https 共存,且可以通过 http 访问指美国服务器定 URL,但是当 https 访问时会 404

我的配置文件如下:

# sudo certbot certonly --webroot -w /usr/share/nginx/html/ -d hzzone.io
user www-data;
worker_processes auto;
pid /run/nginx.pid;

events {
	worker_connections 768;
	# multi_accept on;
}

http {

	##
	# Basic Settings
	##

	sendfile on;
	tcp_nopush on;
	tcp_nodelay on;
	keepalive_timeout 65;
	types_hash_max_size 2048;
	# server_tokens off;

	# server_names_hash_bucket_size 64;
	# server_name_in_redirect off;

	include /etc/nginx/mime.types;
	default_type application/octet-stream;

	##
	# SSL Settings
	##

	##
	# Logging Settings
	##

	access_log /var/log/nginx/access.log;
	error_log /var/log/nginx/error.log;

	gzip on;
	gzip_disable "msie6";


	
	include /etc/nginx/conf.d/*.conf;
	include /etc/nginx/sites-enabled/*;

	server {
		listen 80;
        listen       443 ssl;

        # 域名,实际情况下时,将这个改成域名
        server_name  hzzone.io;

        ssl on;

        # 证书位置
        ssl_certificate  /etc/letsencrypt/live/hzzone.io/fullchain.pem;
        ssl_certificate_key /etc/letsencrypt/live/hzzone.io/privkey.pem;

        location /api {
	        proxy_pass http://localhost:1111/api;
	        proxy_http_version 1.1;
	        proxy_set_header Upgrade $http_upgrade;
	        proxy_set_header Connection "Upgrade";
	        proxy_set_header X-Real-IP $remote_addr;
	    }

	    location / {
	        proxy_pass https://localhost;
	    }
    }
}

为什么当我使用 http 访问 域名 /api/子目录 时,是正常的,而 https 却 404 呢?我看了 access log,根本没有转发。

请问是什么原因导致的这个问题?


我的 python 代码如下:
```python
from flask import Flask
app = Flask(__name__)
@app.route('/api/latex')
def hello_world():
return 'Hello World!'
if __name__ == "__main__":
context = ('/etc/letsencrypt/live/hzzone.io/fullchain.pem', '/etc/letsencrypt/live/hzzone.io/privkey.pem')
app.run(host='0.0.0.0', ssl_context=context, port=1111)
app.run(host='0.0.0.0', ssl_context=context, port=1111)
```
即使我 flask 也使用 https,http 访问 502 Bad Gateway,https 访问 404 Not Found,即使我改成 `http://localhost:1111/api;`

location / 转发到 443 端口,这个有什么意义?自己转发到自己不就死循环了,你看了 error.log 吗

如果你想实现 http 转 https 可以用 rewrite 进行 301 跳转。
一个 server 上配两个端口行不行得通我不知道,一般 HTTP 和 https 的 server 是分开配置的

proxy_pass https://localhost;
这是要干嘛……

location / 这个地方有问题。如果是针对 http 的,你需要把两个端口分开来配。



```
2018/10/10 09:18:08 [error] 1798*4 open() "/usr/share/nginx/html/api/latex" failed (2: No such file or directory), client: 182.148.57.110, server: hzzone.io, request: "GET /api/latex HTTP/1.1", host: "hzzone.io"
```
把这几行删了之后还是一样的呀,404
我想做的事对指定 URL 转发到本机上的其他端口

分两个 server 吗??

https 不能多个端口吧

server {
listen 80;
server_name xxxx.com;
server_name www.xxxx.com;
access_log /home/wwwlogs/xxxx.access.log;
root /home/wwwroot/xxxx;
include enable-php.conf;
location / {
return 301 https://www.xxxx.com$request_uri;
}
}
server {
listen 443 ssl http2;
server_name www.xxxx.com;
root /home/wwwroot/xxxx;
ssl_certificate xxxx.pem;
ssl_certificate_key xxxx.key;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1.2;
ssl_session_timeout 5m;
ssl_prefer_server_ciphers on;
include enable-php.conf;
location / {
include wordpress.conf;
index index.php index.html index.htm;
}
location /api {
proxy_pass http://127.0.0.1:3000/api;
}
}

此贴结束,最终配成功了,需求如下:
http 全部转 https
指定 url 转发,例如 域名 /api/latex 转发 域名:1111/api/latex
配置文件如下:
```
user www-data;
worker_processes auto;
pid /run/nginx.pid;
events {
worker_connections 768;
multi_accept on;
}
http {
server {
listen 80;
server_name 域名;
rewrite ^/(.*) https://hzzone.io/$1 permanent;
}
server {
listen 443;

ssl on;
ssl_certificate /etc/letsencrypt/live/hzzone.io/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/hzzone.io/privkey.pem;
server_name 域名;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
location / {
checks for static files; if not found, proxy to app
$uri @proxy_to_app;
}
location /api {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
proxy_pass http://localhost:1111/api;
}
}
}
```

谢谢哈,我已经配好了

ssh 账号给我 我去帮你配

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服