ELK —— Logstash 将 MySQL 数据同步至 ElasticSearch

目录预览

一、搭建环境

    1.0 环境依赖

    1.1 搭建 ElasticSearch 环境

        1.1.1 ElasticSearch 简介

        1.1.2 启动 ElasticSearch

    1.2 Logstash(多数据源采集系统)

    1.3 Kibana(可视化面板)

二、Logstash 配置

    2.1 配置数据库连接

    2.2 配置同步 ES

    2.3 重新启动

三、下一步更新计划

Author:Gorit 

Date:2021/4/7 

Refer:各种同类文章参考融合 + 自己的思考总结 

2021年发表博文: 16/50

一、搭建环境

官网介绍[1] 下载地址[2]

1.0 环境依赖

1.windows 10 开发环境2.jdk1.8 环境(最低版本要求,我看到目前最新)3.配置好 JAVA_HOME,以及 classpath4.相同版本的 ELK (我目前用的是 7.10.0,最新版本的已经更新到了 7.12.0。一定要下载相同版本的,不然会出现莫名其妙的 BUG)5.mysql-connector-java.jar (8.0 或者 5.5 都可以,这个从maven 仓库里面找,因为同步数据用的是 jdbc)6.ELK 三个下载好的软件放在一起,目录中不要出现 空格,中文什么的,也会出现莫名其妙的 BUG

1.1 搭建 ElasticSearch 环境

1.1.1 ElasticSearch 简介

ElasticSearch 是基于 Lucence 的分布式搜索引擎,也可以作为“数据库”存储一些数据,同类产品还有一个叫做 solr 的,这里就不做描述

1.1.2 启动 ElasticSearch

1.

不了解 ES 的可以先看这篇 文章[3],毕竟ES 的概念还是挺多的

PS:近期我会整理出 ES 的基本操作的文档,

2.

ES 的项目结构

3.

ES 启动很简单,一键启动即可 bin/elasticsearch.bat

4.

ES 会占用 9200 和 9300 端口

[2021-04-07T15:02:36,121][INFO ][o.e.t.TransportService  ] [DESKTOP-8HFODO1] publish_address {127.0.0.1:9300}, bound_addresses {127.0.0.1:9300}, {[::1]:9300}

[2021-04-07T15:02:39,181][INFO ][o.e.h.AbstractHttpServerTransport] [DESKTOP-8HFODO1] publish_address {127.0.0.1:9200}, bound_addresses {127.0.0.1:9200}, {[::1]:9200}

1.打开游览器访问 http://localhost:9200,可以看到你的 ES 基本信息,说明你就搭建完成了

1.2 Logstash(多数据源采集系统)

1.项目结构

2.这里需要配置一些东西才能启动,并且需要启动参数才能解决。启动 Logstash logstash -f ../config/logstash-sample.conf 即可3.但是看不到效果,因为要和 ES 配合使用才行

1.3 Kibana(可视化面板)

1.是一个纯前端项目,下载好后,项目结构如下

2.启动方式同 ES,在 bin/kibana.bat ,双击即可启动3.输入 http://localhost:5601 即可看到 Kibana 的控制面板,但是发现页面全是英文的,但是 kibana 也是支持中文的。4.进入 config/kibana.yml ,的最后一行

5.然后重新启动即可

6.进入工作页

二、Logstash 配置

2.1 配置数据库连接

7.将下载好的 mysql-connector-java.8.22.jar 拷贝到 lib/mysql/ 下

8.进入 config 目录,拷贝 logstash-sample.conf 并重命名为 logstash.conf9.查看 logstash.conf 的内容

# Sample Logstash configuration for creating a simple

# Beats -> Logstash -> Elasticsearch pipeline.

logstash 收集模块,从日志,数据库中采集数据

input { beats { port => 5044 } }

logstash 输出模块,将采集好的数据同步至 ES

output { elasticsearch { hosts => ["http://localhost:9200"] index => "%{[@metadata][beat]}-%{[@metadata][version]}-%{+YYYY.MM.dd}" #user => "elastic" #password => "changeme" } }

4. 因此我们需要修改 input 中的内容

```js

input{

beats{

port =>5044

}

# 可以在 logstash 控制台输入相对应的参数,来改变 output 的行为

stdin{}

jdbc{

type=>"jdbc"

# 数据库连接地址,我的是 MySQL 8.0 的,所以连接必须带上时区

jdbc_connection_string =>"jdbc:mysql://连接地址:3306/数据库名称?characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai"

# 数据库连接账号密码

jdbc_user =>"root"

jdbc_password =>"root"

# MySQL依赖包路径,名称一定要对应;

jdbc_driver_library =>"../lib/mysql/mysql-connector-java-8.0.22.jar"

# the name of the driver class for mysql

jdbc_driver_class =>"com.mysql.cj.jdbc.Driver"

# 数据库重连尝试次数

connection_retry_attempts =>"3"

# 判断数据库连接是否可用,默认false不开启

jdbc_validate_connection =>"true"

# 数据库连接可用校验超时时间,默认3600S

jdbc_validation_timeout =>"3600"

# 开启分页查询(默认false不开启);

jdbc_paging_enabled =>"true"

# 单次分页查询条数(默认100000,若字段较多且更新频率较高,建议调低此值);

jdbc_page_size =>"500"

# statement为查询数据sql,如果sql较复杂,建议配通过statement_filepath配置sql文件的存放路径;

# sql_last_value为内置的变量,存放上次查询结果中最后一条数据tracking_column的值,此处即为ModifyTime;

# 这个你需要自己多尝试,执行 sql 文件

#statement_filepath =>"../lib/mysql/jdbc.sql"

# 查询语句,高级一点的就是增加查询条件

statement =>"select * from `xxx`"

# 是否将字段名转换为小写,默认true(如果有数据序列化、反序列化需求,建议改为false);

lowercase_column_names =>false

# Value can be any of: fatal,error,warn,info,debug,默认info;

sql_log_level => warn

# 是否记录上次执行结果,true表示会将上次执行结果的tracking_column字段的值保存到last_run_metadata_path指定的文件中;

record_last_run =>true

# 需要记录查询结果某字段的值时,此字段为true,否则默认tracking_column为timestamp的值;

use_column_value =>true

# 需要记录的字段,用于增量同步,需是数据库字段

tracking_column =>"ModifyTime"

# Value can be any of: numeric,timestamp,Default value is"numeric"

tracking_column_type=> timestamp

# record_last_run上次数据存放位置;

last_run_metadata_path =>"mysql/last_id.txt"

# 是否清除last_run_metadata_path的记录,需要增量同步时此字段必须为false;

clean_run =>false

# 同步频率(分 时 天 月 年),默认每分钟同步一次; 定时任务中的 corn 表达式

schedule =>"* * * * *"

}

}

2.2 配置同步 ES

output{

elasticsearch{

# 作为数组可以存储集群数据

hosts => ["http://localhost:9200"]

# 索引名字

index =>"blog"

# index => "%{[@metadata][beat]}-%{[@metadata][version]}-%{+YYYY.MM.dd}"

# 数据的唯一索引,就是你查询的表的主键或者一个唯一 ID,自动替换为 ES 的 _id 字段

document_id =>"%{blog_id}"

}

stdout{

codec => json_lines

}

}

2.3 重新启动

可以看到 MySQL 数据库中的内容已经同步过来了

三、下一步更新计划

可能考虑做一下 ELK 做日志系统吧

References

[1] 官网介绍: https://www.elastic.co/cn/what-is/elk-stack

[2] 下载地址: https://www.elastic.co/cn/start

[3] 文章: https://blog.csdn.net/caidewei121/article/details/109192680

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容