如何使用 Nginx 代理 Easysearch 服务

Nginx 是一个高性能的 HTTP 服务器和反向代理服务器,广泛用于负载均衡、缓存、SSL 终端和服务代理等场景。本篇将尝试使用 Nginx 代理 Easysearch 服务,方法同样适用于 Elasticsearch 和 Opensearch。

测试环境

  • Easysearch 集群版本为 1.10.0,3 个节点
  • Nginx 版本为 1.21.5

Nginx

计划使用 Nginx 将请求均匀分发到所有节点,关键配置如下:

plain 复制代码
http {
 upstream es-cluster {
   server 192.168.56.102:9200;
   server 192.168.56.102:9201;
   server 192.168.56.102:9202;
 }

 log_format es_log '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for" '
                      'upstream: $upstream_addr';

 # 配置代理服务器信息
 server {
   listen 80;
   server_name localhost;

   location / {
     proxy_pass https://es-cluster;
     #proxy_http_version  1.1;
     #proxy_set_header    Connection "";

     # 添加 Basic Auth 认证
     auth_basic "Restricted Access";  # 认证提示信息
     auth_basic_user_file /etc/nginx/.htpasswd;  # 认证文件路径

     # 使用自定义日志格式
     access_log /var/log/nginx/elasticsearch_access.log es_log;
   }

 }
}

由于 Easysearch 开启了认证功能,需要 给 Nginx 创建一个认证文件。示例为 Nginx 配置了 admin 用户,大家根据情况自行调整。

plain 复制代码
echo "admin:$(openssl passwd -crypt yourpassword)" | sudo tee /etc/nginx/.htpasswd

经过上面的配置,Nginx 会将访问日志记录在 /var/log/nginx/elasticsearch_access.log 中。

至此 Nginx 已经配置完毕,启动 Nginx 服务。

plain 复制代码
sudo systemctl start nginx

测试

我们使用 curl 命令连续向 Nginx 发送 6 个查询请求,看看请求是否发送到 Easysearch 的所有节点。

plain 复制代码
curl localhost:80/infini/_search -uadmin:56939c1f6527d1a0d51c

可以看到,如我们期待那样查询请求在所有节点间轮询。

相关推荐
Tony Bai2 小时前
【Go开发者的数据库设计之道】07 诊断篇:SQL 性能诊断与问题排查
开发语言·数据库·后端·sql·golang
cpsvps_net2 小时前
VPS服务器锁等待超时处理,如何有效解决数据库性能瓶颈
服务器·数据库·oracle
文火冰糖的硅基工坊5 小时前
[创业之路-653]:社会产品与服务的分类
大数据·数据库·人工智能
235165 小时前
【MySQL】数据库事务深度解析:从四大特性到隔离级别的实现逻辑
java·数据库·后端·mysql·java-ee
脚踏实地的大梦想家5 小时前
【LangChain】P7 对话记忆完全指南:从原理到实战(下)
数据库·langchain
conkl5 小时前
Flask 与 MySQL 数据库集成:完整的 RESTful API 实现指南
数据库·mysql·flask
何中应6 小时前
MyBatis-Plus字段类型处理器使用
java·数据库·后端·mybatis
迎風吹頭髮7 小时前
UNIX下C语言编程与实践21-UNIX 文件访问权限控制:st_mode 与权限宏的解析与应用
c语言·数据库·unix
炬火初现7 小时前
SQL语句——高级字符串函数 / 正则表达式 / 子句
数据库·sql
TTGGGFF7 小时前
云端服务器使用指南:利用Python操作mysql数据库
服务器·数据库·python