zoukankan      html  css  js  c++  java
  • Logstash同步多数据库多表到ES的配置文件

    input {
        stdin{
        }
        jdbc {
          # 连接的数据库地址和哪一个数据库,指定编码格式,禁用SSL协议,设定自动重连
          jdbc_connection_string => "jdbc:mysql://127.0.0.1:3306/userdb?characterEncoding=UTF-8&useSSL=false&autoReconnect=true"
          # 用户名密码
          jdbc_user => "user"
          jdbc_password => "password"
          
          #以下配置是为了达到增量同步的目的,每次同步结束之后会记录最后一条数据的tracking_column列,这里设置的是id,就会将这个值记录在last_run_metadata_path中。下次在执行同步的时候会将这个值,赋给sql_last_value
          
          # 是否记录上次执行结果,true表示会将上次执行结果的tracking_column字段的值保存到last_run_metadata_path指定的文件中;
          record_last_run => "true"
          # 需要记录查询结果某字段的值时,此字段为true,否则默认tracking_column为timestamp的值;
          use_column_value => "true"
          # 需要记录的字段,用于增量同步,需是数据库字段
          tracking_column => "id"
          # record_last_run上次数据存放位置;
          last_run_metadata_path => "/u02/tomcat-8.5.9/logstash-7.6.2/bin/user_last_id"
          # 是否清除last_run_metadata_path的记录,需要增量同步时此字段必须为false;
          clean_run => "false"
          
          # jar包的位置
          jdbc_driver_library => "/u02/tomcat/mysql-connector-java-8.0.20/mysql-connector-java-8.0.20.jar"
          # mysql的Driver
          jdbc_driver_class => "com.mysql.jdbc.Driver"
          jdbc_default_timezone => "Asia/Shanghai"
          # 开启分页查询(默认false不开启)
          jdbc_paging_enabled => "true"
          # 单次分页查询条数(默认100000,若字段较多且更新频率较高,建议调低此值)
          jdbc_page_size => "500"
          #注意这个sql不能出现type,这是es的保留字段
          statement => "select * from user where id > :sql_last_value ORDER BY  id asc  limit  20000"
          # 同步频率(分 时 天 月 年),默认每分钟同步一次;当前配置每10分钟执行一下 
          schedule => "*/10 * * * *"
        }
        jdbc {
          # 连接的数据库地址和哪一个数据库,指定编码格式,禁用SSL协议,设定自动重连
          jdbc_connection_string => "jdbc:mysql://127.0.0.1:3306/userdb?characterEncoding=UTF-8&useSSL=false&autoReconnect=true"
          # 用户名密码
          jdbc_user => "user"
          jdbc_password => "password"
          
          
          #这些配置是为了达到增量同步的目的,每次同步结束之后会记录最后一条数据的tracking_column列,这里设置的是id,就会将这个值记录在last_run_metadata_path中。下次在执行同步的时候会将这个值,赋给sql_last_value
          
          # 是否记录上次执行结果,true表示会将上次执行结果的tracking_column字段的值保存到last_run_metadata_path指定的文件中;
          record_last_run => "true"
          # 需要记录查询结果某字段的值时,此字段为true,否则默认tracking_column为timestamp的值;
          use_column_value => "true"
          # 需要记录的字段,用于增量同步,需是数据库字段
          tracking_column => "id"
          # record_last_run上次数据存放位置;
          last_run_metadata_path => "/u02/tomcat-8.5.9/logstash-7.6.2/bin/dept_last_id"
          # 是否清除last_run_metadata_path的记录,需要增量同步时此字段必须为false;
          clean_run => "false"
          
          # jar包的位置
          jdbc_driver_library => "/u02/tomcat/mysql-connector-java-8.0.20/mysql-connector-java-8.0.20.jar"
          # mysql的Driver
          jdbc_driver_class => "com.mysql.jdbc.Driver"
          jdbc_default_timezone => "Asia/Shanghai"
          # 开启分页查询(默认false不开启)
          jdbc_paging_enabled => "true"
          # 单次分页查询条数(默认100000,若字段较多且更新频率较高,建议调低此值)
          jdbc_page_size => "500"
          #注意这个sql不能出现type,这是es的保留字段
          statement => "select * from dept where id > :sql_last_value   ORDER BY  id asc  limit  20000"
          schedule => "*/10 * * * *"
        }
    }
    
    output {
        if [type]=="user" {
            elasticsearch {
                hosts => "127.0.0.1:9200"
                # index名
                index => "monitor_user"
                # type名
                document_type => "_doc"
                # 数据唯一索引(建议使用数据库KeyID)
                document_id => "%{id}"
            }
            # JSON格式输出
            stdout {
                codec => json_lines
            }
        }
    
        if [type]=="dept" {
            elasticsearch {
                hosts => "127.0.0.1:9200"
                # index名
                index => "monitor_dept"
                # type名
                document_type => "_doc"
                # 数据唯一索引(建议使用数据库KeyID)
                document_id => "%{id}"
            }
            # JSON格式输出
            stdout {
                codec => json_lines
            }
        }
        
    }
  • 相关阅读:
    C# WinForm界面上实现按条件检索数据
    DevExpress中XtraEditors.RadioGroup 控件如何保存获取选中的值及读取数据库中的值
    在QTP Test中利用vbs和cmd实现重新启动QTP
    VBS操作Excel的一点问题总结
    利用vbs维护qtp的虚拟对象的坐标
    Smoke Test和BVT Test的区别
    小结一下VS2012新开发环境的设置经历
    关闭EF4.x Code First的级联删除Cascade Delete
    关于Entity Framework 4.0/4.1数据验证的一点体会
    CentOS 6.3 Minimal yum 安装 PostgreSQL 9.2.3
  • 原文地址:https://www.cnblogs.com/wueryuan/p/13230849.html
Copyright © 2011-2022 走看看