即使是不成熟的尝试,也胜于胎死腹中的策略。

Jdbc向es集群传输数据并解析json格式

匿名 | 发布于2018年09月14日 | 阅读数:3122

mysql里面的数据是这样的:
   id       phone      data
   12       12453452   {"cc":"aex","c":" qkp ","s":"owj","pt":"124sqa"}
  
我的配置文件是这样的:
input {
    jdbc {
        jdbc_driver_library => "C:/ES/mysql-connector-java-5.1.46-bin.jar"
        jdbc_driver_class => "com.mysql.jdbc.Driver"
        jdbc_connection_string => "jdbc:mysql://localhost:3306/aa?autoReconnect=true&useSSL=false"
        jdbc_user => ""
        jdbc_password => ""
        #schedule => "* * * * *"
        jdbc_default_timezone => "Asia/Shanghai"
        statement => "SELECT * FROM a;"
    }
}
filter {
    json {
        source => "data"
        add_field => {
            "data_cc" => "%{cc}"
            "data_c" => "%{c}"
            "data_s" => "%{s}"
            "data_pt" => "%{pt}"
        }
        add_field => {"source" => ""}
        remove_field => ["_id" , "@version", "@timestamp", "path", "host","tags","message","data","cc","c","s","pt"]
    } 
}
output {
    elasticsearch {
        index => ""
        document_type => ""
        #document_id => "%{id}"
        user => ""
        password => ""
        hosts => [""]
    }
    stdout {
        codec => rubydebug
    }
}
输出的是这样:
{
     "source" => "",
     "data_s" => "owj",
       "tags" => ,
    "data_cc" => "aex",
      "phone" => "12453452   ",
         "id" => 12,
    "data_pt" => "124sqa",
     "data_c" => "qkp "
}
我想要这样的结果:
{
     "source" => "",
       "tags" => ,
      "phone" => "",
         "id" => 12,
         data => {
            "data_pt" => "124sqa",
            "data_c" => "qkp ",
            "data_s" => "owj",
            "data_cc" => "aex"
         }
}
配置文件应该怎么写.
已邀请:

zyy

赞同来自: JonRambo

        add_field => {
            "data_cc" => "%{cc}"
            "data_c" => "%{c}"
            "data_s" => "%{s}"
            "data_pt" => "%{pt}"
        }
写成下面这样就可以了
        add_field => {
            "[data][data_cc]" => "%{cc}"
            "[data][data_c]" => "%{c}"
            "[data][data_s]" => "%{s}"
            "[data][data_pt]" => "%{pt}"
        }

JonRambo

赞同来自:

有用到,谢谢.@

要回复问题请先登录注册