ELK+Spring Cloud搭建分布式日志中心

2024-09-08 04:48

本文主要是介绍ELK+Spring Cloud搭建分布式日志中心,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ELK+Spring Cloud搭建分布式日志中心

  • 1.ELK简介
  • 2.资源包下载
  • 3.Elasticsearch安装
    • 3.1 解压Elasticsearch
    • 3.2 修改Elasticsearch的配置文件
    • 3.3 修改系统配置
    • 3.4 启动Elasticsearch
  • 4.ElasticSearch-head插件安装
  • 5.Logstash安装
  • 6.Kibana安装
  • 7.SpringCloud集成logstash
  • 7.安装过程的异常处理

1.ELK简介

ELK 是 Elasticsearch、Logstash、Kibana 的简称。

Elasticsearch是实时全文搜索和分析引擎,提供搜集、分析、存储数据三大功能;是一套开放REST和JAVA API等结构提供高效搜索功能,可扩展的分布式系统。它构建于Apache Lucene搜索引擎库之上。

Logstash是一个用来搜集、分析、过滤日志的工具。它支持几乎任何类型的日志,包括系统日志、错误日志和自定义应用程序日志。它可以从许多来源接收日志,这些来源包括 syslog、消息传递(例如 RabbitMQ)和JMX,它能够以多种方式输出数据,包括电子邮件、websockets和Elasticsearch。

Kibana是一个基于Web的图形界面,用于搜索、分析和可视化存储在 Elasticsearch指标中的日志数据。它利用Elasticsearch的REST接口来检索数据,不仅允许用户创建他们自己的数据的定制仪表板视图,还允许他们以特殊的方式查询和过滤数据。

2.资源包下载

各个组件版本及安装包(基于Linux搭建):
   elasticsearch-7.3.0-linux-x86_64.tar.gz
   elasticsearch-head.zip
   kibana-7.3.0-linux-x86_64.tar.gz
   logstash-7.3.0.tar.gz
   node-v12.18.4-linux-x64.tar
我把所有的依赖包都下载打成了一个包,需要的直接下载即可,下载地址:
链接:https://pan.baidu.com/s/1jTvZFVC_6XP7ErE_epP5Cg 密码: q7b2
下载完成后解压:

unzip package

3.Elasticsearch安装

3.1 解压Elasticsearch

tar -zxvf elasticsearch-7.3.0-linux-x86_64.tar.gz

3.2 修改Elasticsearch的配置文件

vim elasticsearch-7.3.0/config/elasticsearch.yml
# 如果需要部署集群,集群需要同样的集群名
cluster.name: my-application
# 每个 node 的名字需要唯一
node.name: node-1
# 数据存放目录,集群必须配置,否则无法加入集群,单机不需要配置。
# path.data: /var/lib/elasticsearch/nodes
# path.logs: /var/log/elasticsearch
# 配置服务器的内网地址,可以配置为服务器IP地址或者0.0.0.0
network.host: 192.168.0.30
# 配置端口号,默认 9200
http.port: 9200
# 配置集群节点,多个服务器["node-1", "node-2"]
cluster.initial_master_nodes: ["node-1"]
# discovery.seed_hosts: ["192.168.0.146", "192.168.0.147", "192.168.0.148"]
# 解决跨域
http.cors.enabled: true
http.cors.allow-origin: "*"

注意:由于默认配置文件中的代码全部都是注释状态,所以直接在末尾添加即可。如何你用的不是这个版本,那么配置文件可能会有差异。

3.3 修改系统配置

3.3.1 解决max file descriptors [4096] for elasticsearch process is too low, increase to at least [65535]错误。

# 1.编辑 /etc/security/limits.conf
vim  /etc/security/limits.conf
# 2.在最后添加
* soft nofile 65536
* hard nofile 65536

3.3.2 解决max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]错误。

# 1.编辑/etc/sysctl.conf
vim /etc/sysctl.conf
# 2.在最后一行插入
vm.max_map_count=262144
# 3.立即生效
/sbin/sysctl -p

3.4 启动Elasticsearch

1、可以在elasticsearch-7.3.0/config/jvm.options中可以修改堆栈内存,Elasticsearch的默认内存大小是1G,可根据实际需求修改,由于JVM的限制,最大不能>=32G。
2、出现OpenJDK 64-Bit Server VM warning: Option UseConcMarkSweepGC was deprecated in version 9.0 and will likely be removed in a future release.可以通过修改jvm.options中-XX:+UseConcMarkSweepGC 改为 -XX:+UseG1GC来解决。

-Xms4g
-Xmx4g

注意:Elasticsearch不能使用root用户启动,使用root用户会报错,需要我们手动创建用户。
创建用户:

#创建elk组
groupadd elk
#创建用户 useradd [用户名] -g [组名] -p [密码]
useradd elk -g elk -p elk
#elasticsearch目录授权
chown -R elk:elk elasticsearch-7.3.0

启动:

#切换用户
su elk
#进入bin目录启动es
nohup ./elasticsearch &

测试是否安装成功:
浏览器访问:http://192.168.0.30:9200
看到如下页面,则表示安装成功。
测试结果

4.ElasticSearch-head插件安装

注意:ElasticSearch-head插件需要node.js环境。
4.1 node.js安装
解压node-v12.18.4-linux-x64.tar

tar -xvf node-v12.18.4-linux-x64.tar

配置环境变量
编辑/etc/profile配置文件

vim /etc/profile

在底部插入此语句

export NODE_HOME=/home/u01/Development/node-v12.18.4-linux-x64
export PATH=$NODE_HOME/bin:$PATH

是配置文件立即生效

source /etc/profile

测试node.js环境是否安装成功

npm version

在这里插入图片描述
4.2. ElasticSearch-head安装
解压elasticsearch-head.zip,如果使用git clone命令下来的则无需解压

unzip elasticsearch-head.zip

进入elasticsearch-head目录

cd elasticsearch-head

安装

npm install

运行

npm run start &

测试
浏览器访问: http://192.168.0.30:9100,看到如下页面则表示安装成功。(新安装里面是没有数据的)
在这里插入图片描述

5.Logstash安装

  1. 解压logstash-7.3.0.tar.gz
tar -zxvf logstash-7.3.0.tar.gz
  1. 修改配置文件
vim logstash-7.3.0/config/logstash-sample.conf

最终修改结果:

input {beats { port => 5044 }tcp {port => 4569codec => json_lines}
}
output {elasticsearch {hosts => ["http://192.168.0.30:9200"]index => "logstash--%{+YYYY.MM.dd}"}
}
  1. 启动(需要jdk环境)
# 需要使用root用户启动
cd bin/
nohup ./logstash -f ../config/logstash-sample.conf &

6.Kibana安装

  1. 解压kibana-7.3.0-linux-x86_64.tar.gz
tar -zxvf kibana-7.3.0-linux-x86_64.tar.gz
  1. 修改配置文件
vim kibana-7.3.0-linux-x86_64/config/kibana.yml

修改配置文件属性如下:

#端口
server.port: 5601
#指定本机IP
server.host: 0.0.0.0
#请求elasticsearch服务器
elasticsearch.hosts: ["http://192.168.0.30:9200"]
#将语言设置为中文
i18n.locale: "zh-CN"
  1. 启动
#切换用户
su elk
# 在bin目录下执行,不能使用root用户启动
nohup ./kibana &
  1. 访问
    http://192.168.0.30:5601

7.SpringCloud集成logstash

  1. 在pom.xml文件中引入依赖
<!--logstash-logback-->
<dependency><groupId>net.logstash.logback</groupId><artifactId>logstash-logback-encoder</artifactId><version>5.2</version>
</dependency>
  1. logback-spring.xml中加入
<!-- logstash 设置 -->
<appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender"><param name="Encoding" value="UTF-8"/><!-- logstash 服务器 ip --><remoteHost>192.168.0.30</remoteHost><!-- logstash tcp 端口--><port>4569</port><!-- encoder is required --><encoder charset="UTF-8" class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder"><providers><timestamp><timeZone>UTC</timeZone></timestamp><pattern><pattern>{"serviceName": "${name}","level": "%level","message": "%message","stack_trace": "%exception{5}","pid": "${PID:-}","thread": "%thread","class": "%logger{40}"}</pattern></pattern></providers></encoder><!-- 临界值过滤器,过滤掉低于指定临界值的日志。当日志级别等于或高于临界值时,过滤器返回NEUTRAL;当日志级别低于临界值时,日志会被拒绝,OFF>ERROR>WARN>INFO>DEBUG>TRACE>ALL --><filter class="ch.qos.logback.classic.filter.ThresholdFilter"><level>INFO</level></filter>
</appender><!--异步发送日志--> 
<appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender"> <appender-ref ref="LOGSTASH" /> 
</appender><!-- 日志输出级别 -->
<root level="INFO"><!-- 添加logstash日志输出 --><appender-ref ref="ASYNC" />
</root>

7.安装过程的异常处理

  1. npm install报错Failed at the phantomjs-prebuilt@2.1.16 install script
    解决方案,运行以下命令即可:
npm install phantomjs-prebuilt@2.1.14 --ignore-scripts

至此,ELK安装及集成Spring Cloud结束,当前教程中只罗列了ELK集成Spring Cloud的基本用法,本博客旨在让各位小伙伴在工作中能快速搭建并运行着一套分布式日志中心,如果需要完成更加复杂的需求,还是得系统的学习Elasticsearch、Logstash、Kibana的使用。

这篇关于ELK+Spring Cloud搭建分布式日志中心的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147156

相关文章

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版