国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Logstash 同步MySQL數(shù)據(jù) 至 開啟HTTPS的ElasticSearch

這篇具有很好參考價值的文章主要介紹了Logstash 同步MySQL數(shù)據(jù) 至 開啟HTTPS的ElasticSearch。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

最近因為一些原因被迫學(xué)習(xí)了一周多的ElasticSearch,記錄一下遇到的小問題。

配置.conf文件

此文件我理解為是Logstash的 *可編譯文件 *,我們通過編寫此文件然后運行l(wèi)ogstash去編譯執(zhí)行來讓我們的數(shù)據(jù)按照自身期望的去傳輸。該文件主要包括input、filter和output三個部分,其中input和output是必要的,filter根據(jù)自身情況選擇使用。

1.輸入源 input

數(shù)據(jù)的來源,因為此處我們要同步MySQL的數(shù)據(jù)到ES,所以要用到j(luò)dbc插件去連接MySQL。

input {
  jdbc {
   // jdbc驅(qū)動包的路徑 /logstash-8.2.3/logstash-core/lib/jars/mysql-connector-java-8.0.22.jar
    jdbc_driver_library => "" 
    jdbc_driver_class => "com.mysql.cj.jdbc.Driver"  //jdbc驅(qū)動類
    jdbc_connection_string => "jdbc:mysql://host:3306/DB"  //mysql數(shù)據(jù)庫地址
    jdbc_user => "root"          //mysql數(shù)據(jù)庫用戶名
    jdbc_password => "password"      //mysql數(shù)據(jù)庫密碼
    jdbc_paging_enabled => true             //開啟分頁功能
    tracking_column => "unix_ts_in_secs"    //記錄unix_ts_in_secs (unix時間戳)
    use_column_value => true             //需要記錄查詢結(jié)果某字段的值
    tracking_column_type => "numeric"    //跟蹤字段類型 numeric為數(shù)字類型
    schedule => "*/3 * * * * *"          //cron表達(dá)式 ,定時執(zhí)行
    //add_field添加字段  字段數(shù)據(jù)為“tb_type”
    add_field => { "[@metadata][type]" => "tb_type" }  //[@metadata]為管道內(nèi)臨時字段,不會被輸出
    //SQL文,從tb表中提取數(shù)據(jù)
    statement => "SELECT *, UNIX_TIMESTAMP(update_time) AS unix_ts_in_secs FROM  tb WHERE (UNIX_TIMESTAMP(update_time) > :sql_last_value AND update_time < NOW()) ORDER BY update_time ASC"       
  }
}

2.過濾器 filter

mutate插件對input提取到的數(shù)據(jù)進(jìn)行加工修正。

filter {
  mutate {
    copy => { "id" => "[@metadata][_id]"}   //復(fù)制id字段數(shù)據(jù)至[@metadata][_id]字段
    remove_field => ["id", "@version", "unix_ts_in_secs"] //移除"id", "@version", "unix_ts_in_secs" 字段
  }
}

3.輸出源 output

將上面的到的數(shù)據(jù)輸出到指定位置,這里用elasticsearch插件,即將數(shù)據(jù)保存到ES庫中。

output {
  elasticsearch {
      index => "tb_sync"                        // 將數(shù)據(jù)同步到tb_sync索引里
      hosts => ["elasticsearch_host:port"]      //ES庫的主機地址,端口號一般為9200
      document_id => "%{[@metadata][_id]}"      //文檔ID為[@metadata][_id],即原來的id字段的值
  }
}

4.多表多索引

多個表的數(shù)據(jù)分別同步到不同的索引中。

//sync.conf
/* 利用[@metadata][type]字段做判斷,使同一張表內(nèi)的數(shù)據(jù)得到相同的加工并輸出到同一索引*/
input {
  jdbc {
    jdbc_driver_library => ""
    jdbc_driver_class => "com.mysql.cj.jdbc.Driver"
    jdbc_connection_string => "jdbc:mysql://123.67.92.210:3306/database"
    jdbc_user => "root"
    jdbc_password => "123456"
    jdbc_paging_enabled => true
    tracking_column => "unix_ts_in_secs"
    use_column_value => true
    add_field => { "[@metadata][type]" => "first_info" } //增加[@metadata][type]字段,字段數(shù)據(jù)設(shè)為first_info
    tracking_column_type => "numeric"
    schedule => "*/3 * * * * *" 
    statement => "SELECT *, UNIX_TIMESTAMP(update_time) AS unix_ts_in_secs FROM  first_info WHERE (UNIX_TIMESTAMP(update_time) > :sql_last_value AND update_time < NOW()) ORDER BY update_time ASC"
  }
}
input {
  jdbc {
    jdbc_driver_library => ""
    jdbc_driver_class => "com.mysql.cj.jdbc.Driver"
    jdbc_connection_string => "jdbc:mysql://123.67.92.210:3306/database"
    jdbc_user => "root"
    jdbc_password => "123456"
    jdbc_paging_enabled => true
    tracking_column => "unix_ts_in_secs"
    use_column_value => true
    add_field => { "[@metadata][type]" => "second_info" }
    tracking_column_type => "numeric"
    schedule => "*/3 * * * * *" 
    statement => "SELECT *, UNIX_TIMESTAMP(update_time) AS unix_ts_in_secs FROM  second_info WHERE (UNIX_TIMESTAMP(update_time) > :sql_last_value AND update_time < NOW()) ORDER BY update_time ASC"
  }
}

filter {
 //判斷[@metadata][type]字段,數(shù)據(jù)為first_info,則該條數(shù)據(jù)從first_info表中獲得
	if [@metadata][type] == "first_info"{
	  mutate {
	    copy => { "id" => "[@metadata][_id]"}
  	  	remove_field => ["id", "@version", "unix_ts_in_secs"]
	  }
	}
//數(shù)據(jù)為second_info,則該條數(shù)據(jù)從second_info表中獲得
	if [@metadata][type] == "second_info"{
	  mutate {
	    copy => { "id" => "[@metadata][_id]"}
	    remove_field => ["id", "@version", "unix_ts_in_secs"]
	  }
	}
}

output {
//判斷[@metadata][type]字段,
//該條數(shù)據(jù)從first_info表中獲得,輸出到tb_first索引里
if [@metadata][type] == "first_info"{
  elasticsearch {
      index => "tb_first"
      hosts => ["https://192.168.31.141:9200","https://192.168.31.220:9200"]  //多節(jié)點的ES
      document_id => "%{[@metadata][_id]}"
  }
}
//該條數(shù)據(jù)從second_info表中獲得,輸出到tb_second索引里
if [@metadata][type] == "second_info"{
  elasticsearch {
      index => "tb_second"
      hosts => ["http://192.168.31.141:9200","http://192.168.31.220:9200"]
      document_id => "%{[@metadata][_id]}"
  }
}
}

Logstash至 開啟HTTPS的ElasticSearch

ElasticSearch開啟了安全協(xié)議,我們在使用Logstash同步數(shù)據(jù)時需要有證書和用戶名及密碼。讓ES知道我們是安全被信任的,才會允許我們往里面同步數(shù)據(jù)。

1.證書

在/elasticsearch-8.2.3/config/certs文件夾內(nèi),我們應(yīng)該可以看到三個文件,

http.p12 http_ca.crt transport.p12

我們可以將 http_ca.crt 文件復(fù)制到/logstash-8.2.3/config/certs文件夾內(nèi),沒有自己建一個文件夾。

2. 配置Logstash

 elasticsearch {
      index => "tb_sync"
      hosts => ["https://192.168.31.141:9200","https://192.168.31.220:9200"]
	  user => "elastic"  //es超級用戶 不建議使用,可以去配置別的roles和用戶
	  password => "elasticpassword"  //用戶密碼
	  ssl => "true"
	  //證書存放的絕對路徑
	  cacert => "/home/logstash-8.2.3/config/certs/http_ca.crt"
      document_id => "%{[@metadata][_id]}"
}

運行Logstash

在/logstash-8.2.3文件夾內(nèi),我們編寫了sync.conf ,啟動終端,執(zhí)行下列命令。

./bin/logstash -f sync.conf 

TIP:前面ElasticSearch的配置方法可以參考大佬寫的Elastic Stack 8.0 安裝文章來源地址http://www.zghlxwxcb.cn/news/detail-427284.html

到了這里,關(guān)于Logstash 同步MySQL數(shù)據(jù) 至 開啟HTTPS的ElasticSearch的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • Docker部署Logstash同步Mysql數(shù)據(jù)到ES

    Docker部署Logstash同步Mysql數(shù)據(jù)到ES

    頁面訪問 ip:9200端口,出現(xiàn)下面頁面部署成功 成功日志

    2024年04月13日
    瀏覽(19)
  • 【elasticsearch專題】:Logstash從入門到同步MySQL數(shù)據(jù)

    【elasticsearch專題】:Logstash從入門到同步MySQL數(shù)據(jù)

    ??Elasticsearch是在數(shù)據(jù)處理生態(tài)系統(tǒng)中擔(dān)任一個開源的分布式 搜索 和 分析 引擎的角色,專為 存儲 、 檢索 和分析大量的數(shù)據(jù)而打造。與此相伴的是Kibana,一個開源數(shù)據(jù)可視化平臺,用于以優(yōu)雅的方式展示Elasticsearch中的數(shù)據(jù),并賦予用戶創(chuàng)建儀表盤、圖表和報告的能力。然

    2024年02月04日
    瀏覽(19)
  • 使用Logstash同步mysql數(shù)據(jù)到Elasticsearch(親自踩坑)

    使用Logstash同步mysql數(shù)據(jù)到Elasticsearch(親自踩坑)

    這篇文章主要介紹了如何使用Logstash同步mysql數(shù)據(jù)到Elasticsearch(親自踩坑),如果幫助到了大家,希望用你毛茸茸的小手點個贊??;如有錯誤或未考慮周全的地方,希望在評論區(qū)留言?? Logstash官方文檔提供了解決方案 一. 安裝Logstash Logstash下載地址 下載版本一定要和Elastics

    2024年04月09日
    瀏覽(18)
  • 通過logstash實現(xiàn)mysql與es的雙向數(shù)據(jù)同步

    通過logstash實現(xiàn)mysql與es的雙向數(shù)據(jù)同步

    參考題目 一種基于MySQL和Elasticsearch的數(shù)據(jù)同步方法及系統(tǒng) 基于MySQL和Elasticsearch的數(shù)據(jù)同步方法 一種基于MySQL和Elasticsearch的數(shù)據(jù)同步系統(tǒng) 基于MySQL和Elasticsearch的數(shù)據(jù)同步技術(shù) 目錄 1【理論調(diào)研】 方案1:使用Logstash實現(xiàn)數(shù)據(jù)同步 方案2:使用Canal實現(xiàn)數(shù)據(jù)同步 方案3:使用Debe

    2024年02月15日
    瀏覽(21)
  • logstash同步mysql數(shù)據(jù)到es(三、es模板問題)

    ?相關(guān)問題匯總: logstash同步mysql數(shù)據(jù)到es(一、es模板問題,請求返回400) logstash同步mysql數(shù)據(jù)到es(二、jdbc_driver_library問題)_(please check user and group permissions for the p-CSDN博客 logstash同步mysql數(shù)據(jù)到es(三、es模板問題)-CSDN博客 使用docker實現(xiàn)logstash同步mysql到es-CSDN博客 [INFO ] 2023-12-11 09

    2024年01月17日
    瀏覽(19)
  • 使用Logstash同步mysql數(shù)據(jù)到Elasticsearch(親自踩坑)_將mysql中的數(shù)據(jù)導(dǎo)入es搜索引擎利用logstash(1)

    使用Logstash同步mysql數(shù)據(jù)到Elasticsearch(親自踩坑)_將mysql中的數(shù)據(jù)導(dǎo)入es搜索引擎利用logstash(1)

    先自我介紹一下,小編浙江大學(xué)畢業(yè),去過華為、字節(jié)跳動等大廠,目前阿里P7 深知大多數(shù)程序員,想要提升技能,往往是自己摸索成長,但自己不成體系的自學(xué)效果低效又漫長,而且極易碰到天花板技術(shù)停滯不前! 因此收集整理了一份《2024年最新大數(shù)據(jù)全套學(xué)習(xí)資料》,

    2024年04月28日
    瀏覽(27)
  • Lostash同步Mysql數(shù)據(jù)到ElasticSearch(二)logstash腳本配置和常見坑點

    Lostash同步Mysql數(shù)據(jù)到ElasticSearch(二)logstash腳本配置和常見坑點

    新建腳本文件夾 cd /usr/local/logstash mkdir sql cd sql vim 表名稱.conf #如: znyw_data_gkb_logstash.conf 建立文件夾,保存資源文件更新Id mkdir -p /data/logstash/data/last_run_metadata 腳本JDBC插件參數(shù)說明: 第一步要做的事情,配置logstasht同步腳本文件,內(nèi)容如下: 第二部要做的事情,根據(jù)_mapping.

    2024年02月07日
    瀏覽(26)
  • 使用logstash把mysql同步到es,Kibana可視化查看

    使用logstash把mysql同步到es,Kibana可視化查看

    Logstash下載地址:https://www.elastic.co/cn/downloads/logstash

    2024年02月02日
    瀏覽(15)
  • Logstash數(shù)據(jù)同步

    Logstash數(shù)據(jù)同步

    Logstash 是 Elastic 技術(shù)棧中的一個技術(shù),它是一個數(shù)據(jù)采集引擎,可以從數(shù)據(jù)庫采集數(shù)據(jù)到 ES 中??梢酝ㄟ^設(shè)置 自增 ID 主鍵 或 更新時間 來控制數(shù)據(jù)的自動同步: 自增 ID 主鍵:Logstatsh 會有定時任務(wù),如果發(fā)現(xiàn)有主鍵的值大于先前同步記錄的主鍵值,就會將對應(yīng)的增量數(shù)據(jù)同

    2024年02月06日
    瀏覽(17)
  • logstash同步數(shù)據(jù)從kafka到es集群

    logstash同步數(shù)據(jù)從kafka到es集群

    背景:需求是這樣的,原始文件是txt文件(每天300個文件),最終想要的結(jié)果是每天將txt中的數(shù)據(jù)加載到es中,開始的想法是通過logstash加載數(shù)據(jù)到es中,但是對logstash不太熟悉,不知道怎么講程序弄成讀取一個txt文件到es中以后,就將這個txt原始文件備份并且刪除掉,然后就想

    2024年02月15日
    瀏覽(17)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包