百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

使用Logstash的ruby插件实现复杂处理逻辑

bigegpt 2024-09-09 01:19 12 浏览

导读:Logstash拥有许多的filter plugins 可相互配合进行数据处理,但是当遇到复杂的处理逻辑时部分插件即便可以达到相同的处理效果,但在编写时也可能会显得比较吃力。这时候可以考虑使用 ruby插件,通过编写 ruby 脚本实现轻松灵活处理复杂逻辑。本文将围绕以下四点展开讨论关于使用Logstash的ruby插件实现复杂处理逻辑:

  • Ruby简述
  • Logstash的ruby插件
  • event概念
  • 使用ruby插件实现复杂处理逻辑的demo

Ruby简述

Ruby 一种简单快捷的面向对象(面向对象程序设计)脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发,Ruby是动态语言。

Ruby 安装及语法学习地址,如下:

https://www.runoob.com/ruby/ruby-tutorial.html

可自己在平台上搭建ruby开发环境,或者使用ruby在线编程测试网站,如下

http://www.dooccn.com/ruby/

Logstash的ruby插件

Logstash在Filter plugins中提供了ruby plugin,支持通过内联(inline)或者 ruby file形式。

内联形式

    filter {
      ruby {
        # 在此处编写直接编写ruby代码
        code => "event.cancel if rand <= 0.90"
      }
    }

ruby file形式

当代码比较复杂时,采用内联形式在文本字符串中构造会显得复杂和困难,因此最好将Ruby代码放在.rb文件中,并通过 path 指定。

 filter {
      ruby {
        # path指定 ruby file所在路径
        path => "/etc/logstash/drop_percentage.rb"
        script_params => { "percentage" => 0.9 }
      }
    }

在编写 .rb 脚本文件时,应定义以下两个方法:

  • register(params):一个可选的注册方法,该方法接收自配置选项 script_params 传递进来的 key/value 。
  • filter(event):一个强制的Ruby方法,它接受Logstash event并必须返回event(注:在filter中,我们的参数就是input过来的每一条消息,这个消息在filter中被称为event对象,关于event对象下文会进行详细讨论)。
def register(params)
	@drop_percentage = params["percentage"]
end

def filter(event)
	if rand >= @drop_percentage
		return [event]
	else
		return [] # return empty array to cancel event
	end
end

详细关于ruby 插件详细描述可查看官网地址,如下:

https://www.elastic.co/guide/en/logstash/7.1/plugins-filters-ruby.html#_description_134

Event

Event是在Logstash内部封装数据流的主要对象,同时其为使用插件的开发人员提供与事件(event)内容交互的API,其可以用于Ruby filter 进行数据检索及转换。Event对象包含发送到Logstash的原始数据和在Logstash的过滤阶段创建的任何其他字段。因此当采用ruby插件时,我们可以通过处理event对象实现数据处理。

# 获取
event.get(field)  
# 设置
event.set(field, value)

关于event api 的详细应用可参考官方文档,如下:

https://www.elastic.co/guide/en/logstash/7.1/event-api.html#_event_object

一个简单的Demo例子

编写一个 logstash.conf 文件,包含 input、filter 、output三部分

input {
  file {
     path => ["/data/nginx_logs/ods_media_show_log/access.log"]
     type => "nginx"
  }
}

filter {
      kv {
        field_split => "&?"
      }
      mutate{
        split=>["message","/"]
        add_field => {
          "channel" => "%{[message][0]}"
        }
        remove_field => [ "message" ]
      }
     # ruby 插件可以与其他filter插件相结合
      ruby {
         path => "/usr/local/logstash/config/odsMediaShowLog.rb"
      }
}

output {
   stdout {}
}

编写ruby脚本文件

  • (可选)编写register(params)
  • (必选)编写filter(event),内部编写对 event的处理逻辑
# 用于接收script_params传递过来的值,同时做一些声明
def register(params)
          @MEDIA_TYPE_MAP = { "channel1" => 1, "channel2" => 2, "channel3" => 5 }
end

# 处理event
def filter(event)
        # 获取event中channel字段的值
        channel = event.get("channel")
        # 添加新字段
        event.set("media_type_id", @MEDIA_TYPE_MAP[channel])

        # 如果没有platform字段,则返回空数组,过滤掉该event
        if event.get("platform").nil?
                return []
        end

       #....... 其他复杂逻辑
 end

通过借助ruby插件,我们可以通过编写ruby file 从而更加简便灵活地实现复杂处理逻辑。ruby插件可以使用任何的ruby语法,包括如逻辑判断,条件语句,循环语句,字符串的操作等,十分方便。

总结

本文先简单介绍了 Ruby语言、Logstash的ruby插件、event 这个三个概念。并使用一个简单的例子展示了如何通过 ruby 插件实现复杂处理逻辑。logstash 拥有很多 filter 插件,拥有强大的过滤功能,尽管ruby插件很方便,但也需要一定的学习成本。要达到过滤目的方式有很多,我们应结合实际场景选择最恰当的处理方式才是最好的方案。

感谢您的阅读,如果喜欢本文欢迎关注和转发,本头条号将坚持持续分享IT技术知识。对于文章内容有其他想法或意见建议等,欢迎提出共同讨论共同进步。

相关推荐

当Frida来“敲”门(frida是什么)

0x1渗透测试瓶颈目前,碰到越来越多的大客户都会将核心资产业务集中在统一的APP上,或者对自己比较重要的APP,如自己的主业务,办公APP进行加壳,流量加密,投入了很多精力在移动端的防护上。而现在挖...

服务端性能测试实战3-性能测试脚本开发

前言在前面的两篇文章中,我们分别介绍了性能测试的理论知识以及性能测试计划制定,本篇文章将重点介绍性能测试脚本开发。脚本开发将分为两个阶段:阶段一:了解各个接口的入参、出参,使用Python代码模拟前端...

Springboot整合Apache Ftpserver拓展功能及业务讲解(三)

今日分享每天分享技术实战干货,技术在于积累和收藏,希望可以帮助到您,同时也希望获得您的支持和关注。架构开源地址:https://gitee.com/msxyspringboot整合Ftpserver参...

Linux和Windows下:Python Crypto模块安装方式区别

一、Linux环境下:fromCrypto.SignatureimportPKCS1_v1_5如果导包报错:ImportError:Nomodulenamed'Crypt...

Python 3 加密简介(python des加密解密)

Python3的标准库中是没多少用来解决加密的,不过却有用于处理哈希的库。在这里我们会对其进行一个简单的介绍,但重点会放在两个第三方的软件包:PyCrypto和cryptography上,我...

怎样从零开始编译一个魔兽世界开源服务端Windows

第二章:编译和安装我是艾西,上期我们讲述到编译一个魔兽世界开源服务端环境准备,那么今天跟大家聊聊怎么编译和安装我们直接进入正题(上一章没有看到的小伙伴可以点我主页查看)编译服务端:在D盘新建一个文件夹...

附1-Conda部署安装及基本使用(conda安装教程)

Windows环境安装安装介质下载下载地址:https://www.anaconda.com/products/individual安装Anaconda安装时,选择自定义安装,选择自定义安装路径:配置...

如何配置全世界最小的 MySQL 服务器

配置全世界最小的MySQL服务器——如何在一块IntelEdison为控制板上安装一个MySQL服务器。介绍在我最近的一篇博文中,物联网,消息以及MySQL,我展示了如果Partic...

如何使用Github Action来自动化编译PolarDB-PG数据库

随着PolarDB在国产数据库领域荣膺桂冠并持续获得广泛认可,越来越多的学生和技术爱好者开始关注并涉足这款由阿里巴巴集团倾力打造且性能卓越的关系型云原生数据库。有很多同学想要上手尝试,却卡在了编译数据...

面向NDK开发者的Android 7.0变更(ndk android.mk)

订阅Google官方微信公众号:谷歌开发者。与谷歌一起创造未来!受Android平台其他改进的影响,为了方便加载本机代码,AndroidM和N中的动态链接器对编写整洁且跨平台兼容的本机...

信创改造--人大金仓(Kingbase)数据库安装、备份恢复的问题纪要

问题一:在安装KingbaseES时,安装用户对于安装路径需有“读”、“写”、“执行”的权限。在Linux系统中,需要以非root用户执行安装程序,且该用户要有标准的home目录,您可...

OpenSSH 安全漏洞,修补操作一手掌握

1.漏洞概述近日,国家信息安全漏洞库(CNNVD)收到关于OpenSSH安全漏洞(CNNVD-202407-017、CVE-2024-6387)情况的报送。攻击者可以利用该漏洞在无需认证的情况下,通...

Linux:lsof命令详解(linux lsof命令详解)

介绍欢迎来到这篇博客。在这篇博客中,我们将学习Unix/Linux系统上的lsof命令行工具。命令行工具是您使用CLI(命令行界面)而不是GUI(图形用户界面)运行的程序或工具。lsoflsof代表&...

幻隐说固态第一期:固态硬盘接口类别

前排声明所有信息来源于网络收集,如有错误请评论区指出更正。废话不多说,目前固态硬盘接口按速度由慢到快分有这几类:SATA、mSATA、SATAExpress、PCI-E、m.2、u.2。下面我们来...

新品轰炸 影驰SSD多款产品登Computex

分享泡泡网SSD固态硬盘频道6月6日台北电脑展作为全球第二、亚洲最大的3C/IT产业链专业展,吸引了众多IT厂商和全球各地媒体的热烈关注,全球存储新势力—影驰,也积极参与其中,为广大玩家朋友带来了...