ActiveMQ作为Logstash的消息代理

扩展Logstash时,通常会添加一个消息代理,该消息代理用于在一个或多个Logstash节点处理传入消息之前临时缓冲传入的消息。 数据通过像Beaver这样的发运人推送到代理, Beaver读取日志文件并将每个事件发送到代理。 或者,应用程序可以使用Log4j附加程序之类的东西直接发送日志事件。

概观

一个常见的选择是将Redis用作将数据存储在内存中的代理 ,但也可以使用其他选项(例如Apache Kafka)。 有时,组织不那么热衷于引入很多新技术,并想重用现有商店。 ActiveMQ是一个广泛使用的消息传递和集成平台,它支持不同的协议,看起来非常适合用作消息代理。 让我们看看将其集成的选项。

设置ActiveMQ

ActiveMQ可以使用随附的脚本轻松设置。 在Linux上,只需执行./activemq console 。 使用http://127.0.0.1:8161/admin/上的管理控制台,您可以创建新的队列,甚至可以将消息排队以进行测试。

管理仪表板

使用AMQP消费消息

尝试将ActiveMQ连接到Logstash的一种明显方法是使用AMQP(高级消息队列协议) 。 这是不同消息平台所支持的标准协议。

AMQP曾经有一个Logstash输入,但不幸的是,由于RabbitMQ是受支持的主要系统,因此它已重命名为Rabbitmq-input 。

让我们看看如果尝试将输入与ActiveMQ一起使用会发生什么。

input {rabbitmq {host => "localhost"queue => "TestQueue"port => 5672}
}output {stdout {codec => "rubydebug"}
}

我们告诉Logstash在名为TestQueue的队列的标准端口上的localhost上侦听。 结果应转储到标准输出中。 不幸的是,Logstash仅发出错误,因为它无法连接。

Logstash startup completed
RabbitMQ connection error: . Will reconnect in 10 seconds... {:level=>:error}

在ActiveMQ日志中,我们可以看到我们的参数正确,但是不幸的是,两个系统似乎都说出了不同的AMQP方言。

WARN | Connection attempt from non AMQP v1.0 client. AMQP,0,0,9,1
org.apache.activemq.transport.amqp.AmqpProtocolException: Connection from client using unsupported AMQP attempted
...

不幸的是,这个选项。

使用STOMP消费消息

适当命名的“ 面向简单文本的消息传递协议”是ActiveMQ支持的另一个选项。 幸运的是有一个专用的输入 。 默认情况下,它不包含在Logstash中,但可以轻松安装。

bin/plugin install logstash-input-stomp

之后,我们可以在Logstash配置中使用它。

input {stomp {host => "localhost"destination => "TestQueue"}
}output {stdout {codec => "rubydebug"}
}

这次我们更好了:Logstash确实可以连接并将消息转储到标准输出。

bin/logstash --config stomp.conf 
Logstash startup completed
{"message" => "Can I kick it...","@version" => "1","@timestamp" => "2015-07-22T05:42:35.016Z"
}

使用JMS消费消息

尽管stomp-input可以工作,但还有一个尚未发布但可以测试的选项: jms-input支持Java Messaging System,这是在JVM上进行消息传递的标准方法。

当前,您需要自己构建插件(该插件在我的计算机上不起作用,但应由我过时的本地jruby安装引起)。

在ActiveMQ中获取数据

现在我们知道了从ActiveMQ消费数据的方法,现在该考虑如何获取数据了。使用Java时,您可以使用Log4j-或Logback -Appender之类的东西,这些东西使用JMS将日志事件直接推送到队列中。

不幸的是,在传输数据时,似乎没有哪个流行的解决方案能够将数据推送到ActiveMQ。 如果您知道可以使用的任何解决方案,那么请留下您的评论。

总而言之,我认为可以将ActiveMQ用作Logstash的代理,但是在传输数据时可能还需要做更多的工作。

翻译自: https://www.javacodegeeks.com/2015/08/activemq-as-a-message-broker-for-logstash.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/357408.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql 索引- 笔记

索引 mysql最常用的索引结构是btree(O(log(n))),但是总有一些情况下我们为了更好的性能希望能使用别的类型的索引。hash就是其中一种选择,例如我们在通过用户名检索用户id的时候,他们总是一对一的关系,用到的操作符只是而已&#…

在编译器中鼠标光标变成下横线的解决办法

适用于各种智能编译器,HB-X,VSCode,ST3,IDEA等。 问题: 按一下键盘上的,insert 键。

java自定义序列化_Java中的自定义国际化(i18n)

java自定义序列化国际化(i18n)在我们的软件项目中非常重要。 它主要带来以下好处: 将UI字符串外部化为代码文件以外的外部文件,以及易于管理的UI内容。 支持多种语言。 在这篇文章中,将为Eclipse和Java项目提供一个i…

如何科学高效的学习Web前端开发?

近几年,web前端开发工程师越来越火了,薪资待遇也快接近后端开发工程师了。很多准备入行前端开发工程师的小伙伴们,不知道准备得怎么样了呢? 有的朋友在想方设法的学习,争取在年后的金九银十能靠实力找到一份满意的工作!有的小伙伴在准备准备回家过个团圆年,来年再战!还有…

Apache Drill:如何创建新功能?

Apache Drill允许用户使用ANSI SQL探索任何类型的数据。 这很棒,但是Drill的作用远远不止于此,它允许您创建自定义函数来扩展查询引擎。 这些自定义功能具有任何Drill基本操作的所有性能,但是允许执行这些性能会使编写这些功能比您期望的要复…

Json的访问

JSON:JavaScript 对象表示法(JavaScript Object Notation) 写法:名称/值对 访问方法:可以通过 data.名称 访问,也可以通过 data[名称] 访问 注意:名称加不加引号都可以,但是加引号安…

让一个文字在背景图片水平居中的方法

最近工作中在做那个可视化大屏&#xff0c;图中用到了大量的装饰图片&#xff0c;下面看一下文字怎么在图片中水平居中。 这个方法比较好用&#xff0c;其他的方法嵌入太多可能不是特别好使&#xff0c;尤其嵌入到多个框架中。 html <!DOCTYPE html> <html><h…

Objective-C中,ARC下的 strong和weak指针原理解释

Objective-C中&#xff0c;ARC下的 strong和weak指针原理解释 提示&#xff1a;本文中所说的"实例变量"即是"成员变量"&#xff0c;"局部变量"即是"本地变量" 一、简介 ARC是自iOS 5之后增加的新特性&#xff0c;完全消除了手动管理内…

elementui去掉表格所有边框

/deep/.el-table {border: 0;th,tr,td{border: 0;background-color: #fff;}&::before {height: 0px;}&::after {width: 0;}.el-table__fixed:before {height: 0;}}

cdi 2.7.5_集成测试CDI 1.0和Spring 3.1中的作用域bean

cdi 2.7.5在这篇博客文章中&#xff0c;我描述了如何在Spring和CDI中使用作用域bean进行集成测试。 一切都用小代码示例进行说明。 使用范围进行集成测试并不是特别容易。 想象一下存在于会话范围内的bean&#xff0c;例如UserCredentials 。 在集成测试中&#xff0c;通常没有…

工作流编写教程

介绍 ONES中使用了flowchart.js作为前端展示&#xff0c;并且扩展了flowchart.js的流程描述语言。flowchart.js 参见&#xff1a; https://github.com/adrai/flowchart.js 描述语言分为三部分&#xff0c;使用\n\n(空一行)作为分割&#xff0c;分别是节点定义、执行流程描述、节…

elementui设置表头与表格(左对齐,背景颜色,字体大小等)

headerStyle控制表头&#xff0c;finalCellStyle控制表格 html <div class"table1"><el-tablesize"mini":data"tableDataLeft"borderstripe:default-sort"defaultSort":max-height"tableMaxH":header-cell-style&…

使用LocalTestServer对HTTP调用进行单元测试

有时候&#xff0c;当您正在对远程服务器进行HTTP调用的单元测试代码时。 您可能正在使用诸如ApachesHttpClient或Spring的RestTemplate之类的库。 当然&#xff0c;您不想依靠远程服务进行单元测试。 除了涉及的开销&#xff08;记住单元测试应该是快速的&#xff09;之外&am…

PHP header函数大全

PHP header函数大全 header(Content-Type: text/html; charsetutf-8); header(Location: http://www.php-note.com/); <?php // fix 404 pages: header(HTTP/1.1 200 OK);// set 404 header: header(HTTP/1.1 404 Not Found);// set Moved Permanently header (good for re…

JS提升(hoisting)

近期在学习js&#xff0c;了解到js的一个名词&#xff0c;就是hoisting&#xff0c;进而了解了下js的解析机制 详情可参考&#xff1a;http://www.runoob.com/js/js-hoisting.html js的解析过程分为两个阶段&#xff1a;编译阶段和执行阶段 编译阶段&#xff1a;即我们常说的…

【Java从入门到天黑|01】SE入门之Java的前生今世

大家好,我是孙叫兽,微信公众号【孙叫兽杂谈】,本期给大家分享一下JavaSE的入门部分之Java的前生今世。 Java : 一个帝国的诞生 C语言帝国的统治 现在是公元1995年, C语言帝国已经统治了我们20多年, 实在是太久了。 1972年, 随着C语言的诞生和Unix的问世, 帝国

前端-html、css

HTML一、html简介超级文本标记语言是标准通用标记语言下的一个应用&#xff0c;也是一种规范&#xff0c;一种标准&#xff0c;它通过标记符号来标记要显示的网页中的各个部分。网页文件本身是一种文本文件&#xff0c;通过在文本文件中添加标记符&#xff0c;可以告诉浏览器如…

在Java EE组件中使用骆驼路线

从现在开始我一直在与Camel合作&#xff0c;我真的很喜欢它的简单性。 在Java EE之上始终使用它一直是一个挑战&#xff0c;而我最近发表的有关如何做到这一点的演讲之一以及Java EE中引导Camel的不同方法实际上建议使用WildFly-Camel Subsystem 。 在正在进行的系列文章中&…

【Java从入门到天黑|02】SE入门之Java基础

大家好,我是孙叫兽,微信公众号【孙叫兽杂谈】,本期给大家分享一下JavaSE的入门部分之Java基础 目录 注释 标识符 数据类型 类型转换 变量,常量 运算符

webpack入门

遇到问题首先到github项目的Issues中&#xff0c;检索一下相关问题&#xff0c;比在百度谷歌上直接搜索非官方解决方案好得多。 1、npm init 生成 package.json 2、npm i -D webpack 生成 # npm i -D 是 npm install --save-dev 的简写&#xff0c;是指安装模块并保存到 packa…