文章目录
- 1. net::ERR_INCOMPLETE_CHUNKED_ENCODING 200 (OK) 问题解决
- 2. 升级nacos-client2.0+ 报错 ,nacos-server集群环境时UNAVAILABLE: io exception
- 3. 下载经过nginx代理后,丢包,下载不全文件,导致下载后无法打开
- 4. $http_host 与 $host 差别
- 5. 请求IP透传到服务器
1. net::ERR_INCOMPLETE_CHUNKED_ENCODING 200 (OK) 问题解决
nginx丢包问题。比如访问某个页面,接口请求都是OK的,但是页面一片空白。看看console答应日志net::ERR_INCOMPLETE_CHUNKED_ENCODING 200 (OK) 问题解决
说是某个js文件没有下载下来。
解决办法:
server节点中配置以下配置,根据具体情况,可以适当调整数值。然后重启nginx。
proxy_buffer_size 1024k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffers 16 1024k; #proxy_buffers缓冲区,网页平均在32k以下的设置
proxy_busy_buffers_size 2048k; #高负荷下缓冲大小(proxy_buffers*2)
proxy_temp_file_write_size 2048k;#设定缓存文件夹大小,大于这个值,将从upstream服务器传
2. 升级nacos-client2.0+ 报错 ,nacos-server集群环境时UNAVAILABLE: io exception
具体报错如下:
Server check fail, please check server localhost ,port 9848 is available , error ={}
java.util.concurrent.ExecutionException: com.alibaba.nacos.shaded.io.grpc.StatusRuntimeException: UNAVAILABLE: io exception
解决办法:
按照nacos官网的意思就是nginx要多开放出来两个端口,供客户端与服务端,服务端与服务端之间通信。
Nacos2.0版本相比1.X新增了gRPC的通信方式,因此需要增加2个端口。新增端口是在配置的主端口(server.port)基础上,进行一定偏移量自动生成。
端口 | 与主端口的偏移量 | 描述 |
9848 | 1000 | 客户端gRPC请求服务端端口,用于客户端向服务端发起连接和请求 |
9849 | 1001 | 服务端gRPC请求服务端端口,用于服务间同步等 |
使用VIP/nginx请求时,需要配置成TCP转发,不能配置http2转发,否则连接会被nginx断开。
比如集群环境:
nginx代理路径(以后19服务nacos使用这个,账户密码都是之前)
http://172.31.129.19:8848/nacos/index.html
三台nacos: /home/cloud/nacos2.0.3
http://172.31.129.19:1950/nacos/index.html
http://172.31.129.19:1960/nacos/index.html
http://172.31.129.19:1970/nacos/index.html
那么配置应该如下:
stream {
upstream nacos-server-grpc9848 {
server 172.31.129.19:2950;
server 172.31.129.19:2960;
server 172.31.129.19:2970;
}
server {
listen 9848;
proxy_pass nacos-server-grpc9848;
}
upstream nacos-server-grpc9849 {
server 172.31.129.19:2951;
server 172.31.129.19:2961;
server 172.31.129.19:2971;
}
server {
listen 9849;
proxy_pass nacos-server-grpc9849;
}
}
http {
upstream nacos-server {
server 172.31.129.19:1950;
server 172.31.129.19:1960;
server 172.31.129.19:1970;
}
server {
listen 8848;
server_name localhost;
location /nacos/ {
proxy_pass http://nacos-server/nacos/;
}
}
}
3. 下载经过nginx代理后,丢包,下载不全文件,导致下载后无法打开
问题原因: 可能是nginx配置限制了下载的大小,还有可能是超时等等。
解决办法1: 把下面的必要配置配置到nginx,值大小根据自己的需求配置,重启nginx。
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 120s 120s;
server {
# listen 80;
# server_name localhost;
client_max_body_size 5000m;
proxy_max_temp_file_size 5000m;
proxy_read_timeout 3600s;
proxy_send_timeout 3600s;
# location / {
# return 302 /user-center-portal/;
# }
# ...
}
}
如果还是解决不了问题,也有可能是nginx访问临时目录没有权限的问题。
解决办法2:
# 授权 ${NGINX_HOME} 为nginx的安装目录,不同的安装方法,可能路径不一样
chmod -R 777 ${NGINX_HOME}/uwsgi_temp/
chmod -R 777 ${NGINX_HOME}/client_body_temp
chmod -R 777 ${NGINX_HOME}/fastcgi_temp
chmod -R 777 ${NGINX_HOME}/proxy_temp
chmod -R 777 ${NGINX_HOME}/scgi_temp
chmod -R 777 ${NGINX_HOME}/uwsgi_temp
4. $http_host 与 $host 差别
proxy_set_header Host $http_host;
# proxy_set_header Host $host;
使用这个配置,当你的 Nginx 服务器作为反向代理服务器时,可以确保后端服务器接收到的请求中包含正确的 Host 信息。这对于后端服务器正确处理请求、生成正确的链接、处理重定向等方面非常重要。
详解:
-
proxy_set_header
:这是 Nginx 用于设置向代理服务器请求时所带的 HTTP 头字段的指令。 -
Host
:这是 HTTP 请求头的一部分,通常用于指定请求的目标主机和端口号。在虚拟主机的配置中尤其重要,因为一个物理服务器上可能托管了多个域名,服务器需要通过 Host 字段来判断请求的目的地。 -
$http_host
:这是一个 Nginx 变量,它包含了原始请求中的 Host 头的值,包括域名和端口号(如果指定了端口号的话)。这个变量确保了请求转发到后端服务器时,后端服务器可以接收到原始的 Host 信息。 -
$host
变量仅包括请求的主机名。
5. 请求IP透传到服务器
Nginx 可以作为反向代理服务器,将请求转发到指定的后端服务器,并且在转发请求时附加了一些额外的头信息,以便后端服务器能够获取到客户端的真实信息。
location /gateway/ {
proxy_redirect off ;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://172.98.xxx.xxx:8080/;
}
-
proxy_redirect off;
:禁用代理服务器对响应中的 Location 和 Refresh 头字段的修改。通常在反向代理中不需要进行重定向修改。 -
proxy_set_header Host $http_host;
:设置请求头中的 Host 字段为原始请求的 Host 值。保持 Host 字段的原样是非常重要的,因为后端服务器可能需要使用 Host 来处理请求。 -
proxy_set_header X-Real-IP $remote_addr;
:设置请求头中的 X-Real-IP 字段为客户端的真实 IP 地址。这样可以将客户端的真实 IP 传递给后端服务器,以便后端服务器获取到客户端的真实地址。 -
proxy_set_header REMOTE-HOST $remote_addr;
:设置请求头中的 REMOTE-HOST 字段为客户端的 IP 地址。这个字段的作用类似于 X-Real-IP 字段,不同之处在于可以根据需要自定义字段名。 -
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
:将请求头中的 X-Forwarded-For 字段设置为原始客户端 IP 地址,并将代理服务器的 IP 地址追加到该字段中。这样可以让后端服务器了解到请求的真实来源。 -
proxy_pass http://172.98.xxx.xxx:8080/;
:指定代理服务器转发请求到的后端服务器地址。
一般使用,以下配置,就可以实现标准请求头ip透传。
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;