IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> ES配置即整合项目 -> 正文阅读

[大数据]ES配置即整合项目

ELK日志分析平台系统windows环境搭建和基本使用
ELK(ElasticSearch,Logstash,Kibana)三者组合在一起就可以搭建实时的日志分析平台
LogStash:主要收集、过滤日志信息并将其存储,所以主要用来提供信息。
ElasticSearch是一个基于Lucene的开源分布式搜索引擎,主要用来进行信息搜索。
Kibana为LogStash和ElasticSearch提供了一个可视化的平台。

一、下载安装包

https://www.elastic.co/cn/downloads/
在这里插入图片描述
将图中的软件下载下来(版本最好对应一致)

二、解压安装

在这里插入图片描述
自己按照自己的心情,将其解压在某个盘里,放在一个文件夹里面。

三、搭建部署

1、配置LogStash

1)在logstash文件夹下的bin目录创建配置文件logstash.conf文件

input{
	tcp {
		host => "localhost"
		mode => "server"
		port => 9900
    }

	file{
      path => ["E:/logs/logsFile.log"]  # 想要收集的日志信息文件-注意全路径
      type=>"elasticsearch"              # 指定一个类型
      start_position =>"beginning"      # 说明从文件最开始读
	}
}
filter{
	grok {
		match => { "message" => "%{COMBINEDAPACHELOG}" }
	}
	# 请求头
	mutate {
		convert => {
		"bytes" => "integer"
		}
	}
	# ip 地理位置
	geoip {
		source => "clientip"
	}
	# 浏览器请求信息
	useragent {
		source => "agent"
		target => "useragent"
	}


}
output{
    elasticsearch{                      # 配置elasticsearch接收数据信息
    hosts=>["127.0.0.1:9200"]           # 配置elasticsearch端口信息
    index=>"es-%{+YYYY.MM.dd}"         # 配置Kibana新建index,比如我这里是”log-“开头,在Kibana可以写”log-*”
    }
	stdout { codec => rubydebug }
}



2)在bin目录下执行

logstash -f logstash.conf

3)启动浏览器访问 http://localhost:9600,出现以下内容说明启动成功。
在这里插入图片描述

2、配置ElasticSearch

1)ElasticSearch默认端口为9200,双击elasticsearch.bat即可
在这里插入图片描述
2)访问 http://localhost:9200,出现一下界面说明启动成功
在这里插入图片描述

3、配置Kibana

1)修改config目录下面的kibana.yml文件

server.port: 5601
server.host: "0.0.0.0"
elasticsearch.hosts: "http://localhost:9200"
kibana.index: ".kibana"

2)双击kinaba.bat文件启动
在这里插入图片描述
3)启动后访问页面 http://localhost:5601,出现以下页面说明启动成功。
4)配置elasticSearch head,具体配置可以参考https://blog.csdn.net/qq3401247010/article/details/78742524
然后访问http://localhost:9100,出现以下页面说明成功
在这里插入图片描述

四、在idea里面部署

1、导入依赖

        <!--logStash-->
        <dependency>
            <groupId>net.logstash.logback</groupId>
            <artifactId>logstash-logback-encoder</artifactId>
            <version>5.3</version>
        </dependency>

2、在静态资源下创建logback-spring.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <property name="springAppName" value="LogstashTest"/>

    <include resource="org/springframework/boot/logging/logback/base.xml" />
    <appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
        <!--配置logStash 服务地址-->
        <destination>127.0.0.1:9900</destination>
        <!-- 日志输出编码 -->
        <encoder charset="UTF-8"
                 class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder">
            <providers>
                <timestamp>
                    <timeZone>UTC</timeZone>
                </timestamp>
                <pattern>
                    <pattern>
                        {
                        "logLevel": "%level",
                        "serviceName": "${springAppName:-}",
                        "pid": "${PID:-}",
                        "thread": "%thread",
                        "class": "%logger{40}",
                        "message": "%message"
                        }
                    </pattern>
                </pattern>
            </providers>
        </encoder>
    </appender>

    <root level="INFO">
        <appender-ref ref="LOGSTASH" />
        <appender-ref ref="CONSOLE" />
    </root>
</configuration>

3、yml文件

server:
  port: 8011
spring:
  application:
    name: logstash-test
logging:
  level:
    com.chris.log: debug

4、测试接口

@RestController
@RequestMapping("api")
public class TestController {
    Logger logger = LoggerFactory.getLogger(TestController.class);
 
    /**
     * 测试不同格式的message过滤处理之后写入不同的elasticsearch-index
     *
     * @param type
     * @return
     */
    @GetMapping("test")
    public Boolean test(int type) {
        switch (type) {
            case 1:
                logger.info("{} {} {} {}", "HTTP", "GET", "/api/test", "none");
                break;
            case 2:
                logger.info("{} {} {} {}", "HTTP", "POST", "/api/test", "天王盖地虎");
                break;
            case 3:
                logger.info("{} {} {}", "WS", "ChenFabao", "我已到达");
                break;
            default:
                logger.info("{} {} {} {}", "HTTP", "GET", "/api/test", "other");
                break;
        }
        return true;
    }
}

5、开始测试

在浏览器上运行http://localhost:8011/api/test?type=2

然后去head里面查看会出现新的连接的集群

在这里插入图片描述
然后去看里面的数据
在这里插入图片描述
然后就可以啦!!!

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-07-22 14:16:32  更:2021-07-22 14:17:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/6 13:13:33-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码