logstash修改字段内容_logstash原理

logstash修改字段内容_logstash原理logstash数据类型的修改logstash中可以设置字段的类型为integer,float,stringfilter{mutate{convert=>[“request_time”,”float”]#设置request_time的类型为float类型}}注意:mutate除了转化字符值,还支持对数组类型的字段进行转换,即将[“1″,”2”]转换

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

logstash 数据类型的修改
logstash 中可以设置字段的类型为integer,string,float,boolean
filter{

mutate{

convert => [“request_time”,”float”]  #设置request_time的类型为float类型
}
}

注意:mutate 除了转化字符值,还支持对数组类型的字段进行转换,即将[“1″,”2”]转换成[1,2],但是不支持哈希字段做类似处理。
input {

file {

path => [
“/home/raw_data/8_31/*.csv”
]
start_position => “beginning” # 从什么位置读取
sincedb_path => “/home/es/sincedb/apk”  #sincedb存放路径
type => “apk”   #设置type
tags => [“hgw”, “gather”]
}
}

filter
{

if [type] == “apk”
{

csv
{

columns => [“Type”,”ProbeOUI”,”ProbeVersion”,”MAC”,
“UploadTime”,”IptvAccount”,”STBId”,”OUI”,”ProductClass”,
“SoftwareVersion”,”HardwareVersion”,”IpAddress”,”TeleOUI”,
“TeleProductClass”,”TeleResolution”,”LogUploadInterval”,
“ReportSerialNumber”,”WorkingTime”,”CPURate”,”MEMRate”,
“FrameLR”,”FrameDelay”,”FrameJitter”,”VideoStreamingRate”,
“RTPLossRate”,”RTPThroughPut”,”MdiMLR”,”MdiType”,”MdiDF”,”MAXMdiDF”,
“Jitter”,”MAXJitter”,”ResponseDelay”,”ChannelSwitchDelay”,”StreamBreak”,
“EPGDelay”,”ResourceURL”,”EPGVisitNum”,”EPGSuccessNum”,
“KaNum”,”KaDelay”]
separator => “|”
quote_char => “‰”  #千分号的输入,使用搜狗中文输入qfh
remove_field => [“ProbeVersion”,
“UploadTime”,”IptvAccount”,”STBId”,”ProductClass”,
“SoftwareVersion”,”HardwareVersion”,”IpAddress”,”TeleOUI”,
“TeleProductClass”,”TeleResolution”,”LogUploadInterval”,
“ReportSerialNumber”,”WorkingTime”,”CPURate”,”MEMRate”,
“FrameLR”,”FrameDelay”,”FrameJitter”,”VideoStreamingRate”,
“RTPThroughPut”,”MdiMLR”,”MdiType”,”MdiDF”,”MAXMdiDF”,
“Jitter”,”MAXJitter”,”ResponseDelay”,”ChannelSwitchDelay”,”StreamBreak”,
“EPGDelay”,”ResourceURL”,”EPGVisitNum”,”EPGSuccessNum”,
“KaNum”,”KaDelay”]   #删除不需要的字段
}
mutate {

        convert => [“RTPLossRate”, “integer”] #修改字段类型
    }
if ([Type]!=”1″ or [ProbeOUI]!=”YUCHUANG”){

drop{}
}
}
}

output{

if [type] == “apk”
{

elasticsearch
{

hosts => [“*:9200”]
index => “ana-%{type}”
document_type => “%{type}”
flush_size => 8000
idle_flush_time => 10
sniffing => true
template_overwrite => true
codec => “json”
}
}
}

filters/mutate 插件是 Logstash 另一个重要插件。它提供了丰富的基础类型数据处理能力。包括类型转换,字符串处理和字段处理等。

类型转换

类型转换是 filters/mutate 插件最初诞生时的唯一功能。其应用场景在之前 Codec/JSON 小节已经提到。

可以设置的转换类型包括:”integer”,”float” 和 “string”。示例如下:

filter {

    mutate {

        convert => [“request_time”, “float”]
    }
}
注意:mutate 除了转换简单的字符值,还支持对数组类型的字段进行转换,即将 [“1″,”2”] 转换成 [1,2]。但不支持对哈希类型的字段做类似处理。有这方面需求的可以采用稍后讲述的 filters/ruby 插件完成。

字符串处理

gsub
仅对字符串类型字段有效

    gsub => [“urlparams”, “[\\?#]”, “_”]
split
filter {

    mutate {

        split => [“message”, “|”]
    }
}
随意输入一串以|分割的字符,比如 “123|321|adfd|dfjld*=123″,可以看到如下输出:

{

    “message” => [
        [0] “123”,
        [1] “321”,
        [2] “adfd”,
        [3] “dfjld*=123”
    ],
    “@version” => “1”,
    “@timestamp” => “2014-08-20T15:58:23.120Z”,
    “host” => “raochenlindeMacBook-Air.local”
}
join
仅对数组类型字段有效

我们在之前已经用 split 割切的基础再 join 回去。配置改成:

filter {

    mutate {

        split => [“message”, “|”]
    }
    mutate {

        join => [“message”, “,”]
    }
}
filter 区段之内,是顺序执行的。所以我们最后看到的输出结果是:

{

    “message” => “123,321,adfd,dfjld*=123”,
    “@version” => “1”,
    “@timestamp” => “2014-08-20T16:01:33.972Z”,
    “host” => “raochenlindeMacBook-Air.local”
}
merge
合并两个数组或者哈希字段。依然在之前 split 的基础上继续:

filter {

    mutate {

        split => [“message”, “|”]
    }
    mutate {

        merge => [“message”, “message”]
    }
}
我们会看到输出:

{

       “message” => [
        [0] “123”,
        [1] “321”,
        [2] “adfd”,
        [3] “dfjld*=123”,
        [4] “123”,
        [5] “321”,
        [6] “adfd”,
        [7] “dfjld*=123”
    ],
      “@version” => “1”,
    “@timestamp” => “2014-08-20T16:05:53.711Z”,
          “host” => “raochenlindeMacBook-Air.local”
}
如果 src 字段是字符串,会自动先转换成一个单元素的数组再合并。把上一示例中的来源字段改成 “host”:

filter {

    mutate {

        split => [“message”, “|”]
    }
    mutate {

        merge => [“message”, “host”]
    }
}
结果变成:

{

       “message” => [
        [0] “123”,
        [1] “321”,
        [2] “adfd”,
        [3] “dfjld*=123”,
        [4] “raochenlindeMacBook-Air.local”
    ],
      “@version” => “1”,
    “@timestamp” => “2014-08-20T16:07:53.533Z”,
          “host” => [
        [0] “raochenlindeMacBook-Air.local”
    ]
}
看,目的字段 “message” 确实多了一个元素,但是来源字段 “host” 本身也由字符串类型变成数组类型了!

下面你猜,如果来源位置写的不是字段名而是直接一个字符串,会产生什么奇特的效果呢?

strip
lowercase
uppercase
字段处理

rename
重命名某个字段,如果目的字段已经存在,会被覆盖掉:

filter {

    mutate {

        rename => [“syslog_host”, “host”]
    }
}
update
更新某个字段的内容。如果字段不存在,不会新建。

replace
作用和 update 类似,但是当字段不存在的时候,它会起到 add_field 参数一样的效果,自动添加新的字段。

执行次序

需要注意的是,filter/mutate 内部是有执行次序的。其次序如下:

    rename(event) if @rename
    update(event) if @update
    replace(event) if @replace
    convert(event) if @convert
    gsub(event) if @gsub
    uppercase(event) if @uppercase
    lowercase(event) if @lowercase
    strip(event) if @strip
    remove(event) if @remove
    split(event) if @split
    join(event) if @join
    merge(event) if @merge

    filter_matched(event)
而 filter_matched 这个 filters/base.rb 里继承的方法也是有次序的。

  @add_field.each do |field, value|
  end
  @remove_field.each do |field|
  end
  @add_tag.each do |tag|
  end
  @remove_tag.each do |tag|
  end
 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196944.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 1.MySql驱动的jar包下载「建议收藏」

    1.MySql驱动的jar包下载「建议收藏」文章目录1.下载MySql驱动的jar包1.下载MySql驱动的jar包1)官网:http://dev.mysql.com/downloads/connector/2)点击右边的Connetor/J3)点击Archives4)ProductVersion为MySql驱动版本,可以根据需要版本安装。查找MySql数据库版本语句:SELECTVERSION();5)点击PlatformIndependent6)选择第二个好了,MySql驱动到此就安装好了…

    2022年5月11日
    34
  • python输出unicode编码_python gbk codec

    python输出unicode编码_python gbk codec解决Python报错–UnicodeDecodeError:‘gbk’codeccan’tdecodebyte0x80inposition658:illegalmultibytesequence今天在anaconda上新建一个python3.6环境后,使用时报错了:(base)C:\Users\peter>activatetf(tf)C:\Users\pe…

    2025年11月9日
    3
  • css动画和js动画的差异_css过渡和动画的区别

    css动画和js动画的差异_css过渡和动画的区别在工作中,经常会写点动画效果,常用的方式有CSS动画还有JS动画,根据项目的需求,采用的方案各不相同,但是两者实现的性能分析没有进行对比。总结网上相关资料,在这里简单整理下本文主要讲以下这些内容1、浏览器渲染流程2、回流和重绘3、CSS动画4、JS动画两者对比????1.浏览器的渲染流程渲染流程主要有4个步骤解析HTML生成DOM树解析CSS样式生成CSSOM树,CSSOM树与DOM树结合生成Rendertree布局RenderTree对每个节点进

    2022年10月15日
    2
  • 利用python 提取log 文件里的关键句子,并进行统计分析

    利用python 提取log 文件里的关键句子,并进行统计分析

    2022年1月19日
    44
  • Linux Redhat 7.6 操作系统 下载安装详解「建议收藏」

    Linux Redhat 7.6 操作系统 下载安装详解「建议收藏」redhat系统镜像分享[百度网盘分享]链接:https://pan.baidu.com/s/1U0SUh7qmLGfpLN5Fqb4Wgg提取码:bpwdredhat7.6版本安装详解

    2022年8月5日
    21
  • url参数过长_url长度限制为多少

    url参数过长_url长度限制为多少HTTP协议不对URI的长度作事先的限制,服务器必须能够处理任何他们提供资源的URI,并且应该能够处理无限长度的URIs,这种无效长度的URL可能会在客户端以基于GET方式的请求时产生。如果服务器不能处理太长的URI的时候,服务器应该返回414状态码(此状态码代表Request-URI太长)。具体参见协议ietf.org/rfc/rfc2616.txt虽然协议中未明确对url进行长度限制…

    2022年8月24日
    33

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号