elasticsearch+logstash_jdbc 实现mysql数据实时同步至es
2024-10-10 04:16:28
jdk安装1.8版本,es、ls、ik、kibana版本一致我这里使用的6.6.2版本
安装es
tar xf elasticsearch-6.6.2.tar.gz
mv elasticsearch-6.6.2 /home/heron/elasticsearch
## 使用普通用户启动
chown -R heron.heron /home/heron/elasticsearch
su - heron
cd /home/heron/elasticsearch
cat config/elasticsearch.yml
##修改前三行,添加最后两行到行尾
node.name: test-01
network.host: 10.10.1.231
http.port: 9200
http.cors.enabled: true
http.cors.allow-origin: "*"
cat config/jvm.options
###修改为512M
-Xms512m
-Xmx512m
安装ik+pinyin分词器
tar xf elasticsearch-analysis-pinyin-6.6.2.zip
mv elasticsearch-analysis-pinyin-6.6.2 /home/heron/elasticsearch/plugins/pinyin
tar xf elasticsearch-analysis-ik-6.6.2.zip
mv elasticsearch-analysis-ik-6.6.2 /home/heron/elasticsearch/plugins/ik
启动
/home/heron/elasticsearch/bin/elasticsearch -d
创建thinkcmf5索引和shop_goods表
curl -XPUT "http://10.10.1.231:9200/thinkcmf5" -H 'Content-Type: application/json' -d'
{
"settings":{
"number_of_shards":"3",
"index.refresh_interval":"15s",
"index":{
"analysis":{
"analyzer":{
"ik_pinyin_analyzer":{
"type":"custom",
"tokenizer":"ik_smart",
"filter":"pinyin_filter"
}
},
"filter":{
"pinyin_filter":{
"type":"pinyin",
"keep_first_letter": false
}
}
}
}
}
}'
curl -XPUT "http://10.10.1.231:9200/thinkcmf5/_mapping/shop_goods" -H 'Content-Type: application/json' -d'
{
"properties": {
"goodsname":{
"type": "text",
"analyzer": "ik_smart",
"search_analyzer": "ik_smart",
"fields": {
"pinyin":{
"type":"text",
"analyzer": "ik_pinyin_analyzer",
"search_analyzer": "ik_pinyin_analyzer"
}
}
}
}
}'
安装logstash-input-jdbc插件
首先安装logstash
wget https://artifacts.elastic.co/downloads/logstash/logstash-6.6.2.tar.gz
tar xf logstash-6.6.2.tar.gz
mv logstash-6.6.2 /home/heron/logstash
安装jdbc插件
cd /home/heron/logstash
./bin/logstash-plugin install logstash-input-jdbc
准备
配置文件:mysql.conf
sql文件:my_sql2.sql
mysql 的java 驱动包 :mysql-connector-java-5.1.44-bin.jar
cat /home/heron/logstash/mysql.conf
input {
jdbc {
jdbc_driver_library => "/home/heron/logstash/config/mysql-connector-java-5.1.44-bin.jar"
jdbc_driver_class => "com.mysql.jdbc.Driver"
jdbc_connection_string => "jdbc:mysql://10.10.1.231:3306/thinkcmf5"
jdbc_user => "root"
jdbc_password => "dg9WA1nv"
statement_filepath => "./data/my_sql2.sql"
schedule => "* * * * *"
jdbc_paging_enabled => "true"
jdbc_page_size => "50000"
}
}
filter {
mutate {
rename => { "[host][name]" => "host" }
}
}
output{
stdout {
codec => rubydebug
}
elasticsearch {
index => "thinkcmf5"
document_type => "shop_goods"
hosts => "10.10.1.231:9200"
}
}
cat /home/heron/logstash/data/my_sql2.sql
###全量
select * from shop_goods
###增量,由于开始使用时间戳存储时间,ls变量使用实际时间,因此我转换了一下
select * from shop_goods where createtime > unix_timestamp(:sql_last_value)
启动
/home/heron/logstash/bin/logstash -f /home/heron/logstash/mysql.conf
安装kibana
wget https://artifacts.elastic.co/downloads/kibana/kibana-6.6.2.tar.gz
tar xf kibana-6.6.2.tar.gz
mv kibana-6.6.2 /home/heron/kibana
cat config/kibana.yml
###修改文件
server.port: 5601
server.host: "10.10.1.231"
elasticsearch.hosts: ["http://10.10.1.231:9200"]
启动
/home/heron/kibana/bin/kibana -d
最新文章
- SpringMVC+FreeMarker
- RecyclerView 介绍 01
- C#禁止程序重复启动
- Nginx 配置指令location 匹配符优先级和安全问题【转】
- 异常:HRESULT: 0x80070057 (E_INVALIDARG) 的处理
- 享元模式(咖啡屋)【java与模式】
- Linux 内核使用的 GNU C 扩展
- Django学习笔记之URL与视图cookie和session
- arm 执行 交叉编译完成的可执行文件时 出现premission denied 问题
- 算法进阶面试题07——求子数组的最大异或和(前缀树)、换钱的方法数(递归改dp最全套路解说)、纸牌博弈、机器人行走问题
- [cnbeta]华为值多少钱,全世界非上市公司中估值最高的巨头
- 利用WCF实现上传下载文件服务
- Capjoint的merrcmd生成二次曲线的misfit原理
- How to use GM MDI interface for programming
- BZOJ 2959: 长跑 lct 双联通分量 并查集 splay
- hdu 4055 Number String (基础dp)
- HibernateSessionFactory演示样例
- 51nod 1161 组合数,规律
- Git代码merge
- Python执行Linux系统命令的4种方法
热门文章
- 【Python基础】lpthw - Exercise 41 学习面向对象术语
- Kali 开启 SSH 服务方法
- Autofac之自动装配
- Warning: count(): Parameter must be an array or an object that implements Countable in line 302解决方法
- ADB——命令大全
- PowerBI更新2019/04 - 解决方案架构 - PowerBI Solution Architecture(一图胜万字!)
- Java数组之二维数组
- Cocos Creator 动态设置Canvas的宽度与高度,更改适配
- java的智能提示无法打开
- 用php实现表格