RabbitMQ River 插件技术文档
2024-12-24 12:34:22作者:卓炯娓
1. 安装指南
在安装 RabbitMQ River 插件之前,请确保您的 Elasticsearch 版本与插件版本兼容。根据 Elasticsearch 的版本,选择对应的插件版本进行安装。安装命令如下:
bin/plugin install elasticsearch/elasticsearch-river-rabbitmq/版本号
例如,对于 Elasticsearch 1.6 版本,安装命令为:
bin/plugin install elasticsearch/elasticsearch-river-rabbitmq/2.6.0
若需要构建 SNAPSHOT 版本,可以使用以下 Maven 命令:
mvn clean install
plugin --install river-rabbitmq \
--url file:target/releases/elasticsearch-river-rabbitmq-X.X.X-SNAPSHOT.zip
2. 项目的使用说明
RabbitMQ River 插件允许将 RabbitMQ 消息队列中的消息以 Elasticsearch 的批量格式索引到 Elasticsearch 中。以下是创建 RabbitMQ River 的基本步骤:
curl -XPUT 'localhost:9200/_river/my_river/_meta' -d '{
"type" : "rabbitmq",
"rabbitmq" : {
"host" : "localhost",
"port" : 5672,
"user" : "guest",
"pass" : "guest",
"vhost" : "/",
"queue" : "elasticsearch",
"exchange" : "elasticsearch",
"routing_key" : "elasticsearch",
"exchange_declare" : true,
"exchange_type" : "direct",
"exchange_durable" : true,
"queue_declare" : true,
"queue_bind" : true,
"queue_durable" : true,
"queue_auto_delete" : false,
"heartbeat" : "30m",
"qos_prefetch_size" : 0,
"qos_prefetch_count" : 10,
"nack_errors" : true
},
"index" : {
"bulk_size" : 100,
"bulk_timeout" : "10ms",
"ordered" : false,
"replication" : "default"
}
}'
3. 项目API使用文档
RabbitMQ River 插件支持以下配置选项:
exchange_declare:是否声明交换机(默认为true)。exchange_type:交换机类型(默认为direct)。exchange_durable:交换机是否持久化(默认为true)。queue_declare:是否声明队列(默认为true)。queue_bind:是否绑定队列(默认为true)。queue_durable:队列是否持久化(默认为true)。queue_auto_delete:队列是否自动删除(默认为false)。heartbeat:心跳时间(默认为30m)。qos_prefetch_size:QoS 预取大小(默认为0,即无限)。qos_prefetch_count:QoS 预取计数(默认为10)。nack_errors:是否在错误发生时拒绝消息(默认为true)。
此外,还支持以下索引配置选项:
bulk_size:批量大小(默认为100)。bulk_timeout:批量超时时间(默认为10ms)。ordered:是否有序(默认为false)。replication:复制模式(默认为default)。
4. 项目安装方式
RabbitMQ River 插件的安装方式已在“安装指南”部分详细介绍,此处不再赘述。需要注意的是,安装时要确保插件版本与 Elasticsearch 版本兼容。安装命令如下:
bin/plugin install elasticsearch/elasticsearch-river-rabbitmq/版本号
例如,对于 Elasticsearch 1.6 版本,安装命令为:
bin/plugin install elasticsearch/elasticsearch-river-rabbitmq/2.6.0
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0192- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
awesome-zig一个关于 Zig 优秀库及资源的协作列表。Makefile00
项目优选
收起
deepin linux kernel
C
27
12
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
600
4.04 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
Ascend Extension for PyTorch
Python
440
531
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
112
170
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.46 K
823
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
921
770
暂无简介
Dart
845
204
React Native鸿蒙化仓库
JavaScript
321
375
openGauss kernel ~ openGauss is an open source relational database management system
C++
174
249