在elasticsearch5升级到elasticsearch7的过程中。由于同一台机器启动了es5和es7的两个不同端口。
而业务在执行导入操作到时候,前端发送es _bulk
请求到业务处理服务器,然后nginx拦截_bulk请求直接proxy_pass转发到elasticsearch7。在nginx转发_bulk
请求过程中,发现在nginx那里日志返回403状态码。
未更改前的配置
server {
listen 80;
server_name xxx.xxx.xxx;
access_log /data/nginx/xxx.log;
#....其他配置省略
location ~ ^/_bulk {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_pass http://${eshost}:${port};
}
问题在于之前elasticsearch5的时候,上面的配置是ok的。反而升到es7的时候却返回403了。或许原因在于es7的鉴权、安全保障方面上确实比较严格。
解决的办法
在上述配置添加上proxy_set_header Host $http_host
;
location ~ ^/_bulk {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
#添加这一句
proxy_set_header Host $http_host;
proxy_pass http://172.16.176.111:9207;
}
综上,测试的时候问题的可以得到解决了。