JDBC 插件导入数据到 ES
mysql-demo.yml
input { jdbc { jdbc_driver_class => "com.mysql.jdbc.Driver" jdbc_connection_string => "jdbc:mysql://localhost:3306/db_example" jdbc_user => root jdbc_password => ymruan123 #启用追踪,如果为true,则需要指定tracking_column use_column_value => true #指定追踪的字段, tracking_column => "last_updated" #追踪字段的类型,目前只有数字(numeric)和时间类型(timestamp),默认是数字类型 tracking_column_type => "numeric" #记录最后一次运行的结果 record_last_run => true #上面运行结果的保存位置 last_run_metadata_path => "jdbc-position.txt" statement => "SELECT * FROM user where last_updated >:sql_last_value;" schedule => " * * * * * *" } } output { elasticsearch { document_id => "%{id}" document_type => "_doc" index => "users" hosts => ["http://localhost:9200"] } stdout{ codec => rubydebug } }
添加 jar 包
cp mysql-connector-java-8.0.17.jar /usr/share/logstash/logstash-core/lib/jars
导入数据参考 https://github.com/geektime-geekbang/geektime-ELK/tree/master/part-4/12.2-%E5%88%A9%E7%94%A8JDBC%E6%8F%92%E4%BB%B6%E5%AF%BC%E5%85%A5%E6%95%B0%E6%8D%AE%E5%88%B0Elasticsearch
处理与查询
# 创建 alias,只显示没有被标记 deleted的用户 POST /_aliases { "actions": [ { "add": { "index": "users", "alias": "view_users", "filter" : { "term" : { "is_deleted" : false } } } } ] } # 通过 Alias查询,查不到被标记成 deleted的用户 POST view_users/_search { } POST view_users/_search { "query": { "term": { "name.keyword": { "value": "Jack" } } } } POST users/_search { "query": { "term": { "name.keyword": { "value": "Jack" } } } }
233