elk搭建记录

☆樱花仙子☆ 提交于 2020-01-20 18:15:13

ELK 搭建记录

为什么用到ELK:
一般我们需要进行日志分析场景:直接在日志文件中 grep、awk 就可以获得自己想要的信息。但在规模较大的场景中,此方法效率低下,面临问题包括日志量太大如何归档、文本搜索太慢怎么办、如何多维度查询。需要集中化的日志管理,所有服务器上的日志收集汇总。常见解决思路是建立集中式日志收集系统,将所有节点上的日志统一收集,管理,访问。

一般大型系统是一个分布式部署的架构,不同的服务模块部署在不同的服务器上,问题出现时,大部分情况需要根据问题暴露的关键信息,定位到具体的服务器和服务模块,构建一套集中式日志系统,可以提高定位问题的效率。

一个完整的集中式日志系统,需要包含以下几个主要特点:

收集-能够采集多种来源的日志数据
传输-能够稳定的把日志数据传输到中央系统
存储-如何存储日志数据
分析-可以支持 UI 分析
警告-能够提供错误报告,监控机制
ELK提供了一整套解决方案,并且都是开源软件,之间互相配合使用,完美衔接,高效的满足了很多场合的应用。目前主流的一种日志系统。

ELK简介:
ELK是三个开源软件的缩写,分别表示:Elasticsearch , Logstash, Kibana , 它们都是开源软件。新增了一个FileBeat,它是一个轻量级的日志收集处理工具(Agent),Filebeat占用资源少,适合于在各个服务器上搜集日志后传输给Logstash,官方也推荐此工具。

Elasticsearch是个开源分布式搜索引擎,提供搜集、分析、存储数据三大功能。它的特点有:分布式,零配置,自动发现,索引自动分片,索引副本机制,restful风格接口,多数据源,自动搜索负载等。

Logstash 主要是用来日志的搜集、分析、过滤日志的工具,支持大量的数据获取方式。一般工作方式为c/s架构,client端安装在需要收集日志的主机上,server端负责将收到的各节点日志进行过滤、修改等操作在一并发往elasticsearch上去。

Kibana 也是一个开源和免费的工具,Kibana可以为 Logstash 和 ElasticSearch 提供的日志分析友好的 Web 界面,可以帮助汇总、分析和搜索重要数据日志。

Filebeat隶属于Beats。目前Beats包含四种工具:

Packetbeat(搜集网络流量数据)
Topbeat(搜集系统、进程和文件系统级别的 CPU 和内存使用情况等数据)
Filebeat(搜集文件数据)
Winlogbeat(搜集 Windows 事件日志数据)

elasticsearch中文社区:
https://elasticsearch.cn/

使用软件下载地址:
elasticsearch下载 https://www.elastic.co/cn/downloads/elasticsearch
logstash下载 https://www.elastic.co/downloads/logstash
filebeat下载 https://www.elastic.co/downloads/beats/filebeat
kibana下载 https://www.elastic.co/downloads/kibana

测试环境使用的版本
系统版本: centos6.5
java版本: 1.8.0_45
elasticsearch版本: elasticsearch-6.4.2.tar.gz
logstash版本: logstash-6.4.2.tar.gz
filebeat版本: filebeat-6.4.2-linux-x86_64.tar.gz
kibana版本: kibana-6.4.2-linux-x86_64.tar.gz

创建用户
useradd elk

创建数据目录和存放包的路径
mkdir /data/elk
mkdir -p /usr/local/elk
chown -R elk. /data/elk/
chown -R elk. /usr/local/elk/

安装elasticsearch
调整内存大小(elasticsearch的默认内存大小是1G,测试机内存没有那么大调小一点)
进入 /usr/local/elk/elasticsearch-6.4.2/config/jvm.options
修改
-Xms512m
-Xmx512m

配置文件设置如下/usr/local/elk/elasticsearch-6.4.2/config/elasticsearch.yml
cluster.name: my-application
node.name: node-1
path.data: /data/elk/elasticsearch
path.logs: /data/elk/elasticsearch/logs
bootstrap.memory_lock: false
bootstrap.system_call_filter: false
network.host: 0.0.0.0
http.port: 9200

启动服务
./bin/elasticsearch &

访问curl http://localhost:9200有返回值表示正常

安装logstash
参考上面的操作修改内存大小

新建配置文件full.conf内容如下
input {
file {
path => "/var/log/messages"
type => "system"
start_position => "beginning"
}

file {
    path => "/var/log/secure"
    type => "secure"
    start_position => "beginning"
}   

file {
    path =>** "/var/log/httpd/access_log"
    type => "http"
    start_position => "beginning"
}   

file {
    path => "/usr/local/nginx/logs/elk.access.log"
    type => "nginx"
    start_position => "beginning"
}   

}

output {

if [type] == "system" { 

    elasticsearch {
        hosts => ["localhost:9200"]
        index => "nagios-system-%{+YYYY.MM.dd}"
    }       
}   

if [type] == "secure" {

    elasticsearch {
        hosts => ["localhost:9200"]
        index => "nagios-secure-%{+YYYY.MM.dd}"
    }
}

if [type] == "http" {

    elasticsearch {
        hosts => ["localhost:9200"]
        index => "nagios-http-%{+YYYY.MM.dd}"
    }
}

if [type] == "nginx" {

    elasticsearch {
        hosts => ["localhost:9200"]
        index => "nagios-nginx-%{+YYYY.MM.dd}"
    }
}

}

启动服务
nohup ./bin/logstash -f config/full.conf &

安装filebeat
修改配置文件/usr/local/elk/filebeat-6.4.2-linux-x86_64/filebeat.yml

  • type: log
    Change to true to enable this prospector configuration.
    enabled: True

    Paths that should be crawled and fetched. Glob based paths.
    读取 Nginx 的日志
    paths:

    • /usr/local/nginx/logs/*.log

#----------------------------- Logstash output --------------------------------
输出到本机的 LogStash
output.logstash:
#The Logstash hosts
hosts: ["localhost:5044"]

修改配置文件filebeat.yml的用户为root
chown root filebeat.yml

启动服务
./filebeat -e -c filebeat.yml -d "publish" &

安装kibana
设置配置文件的监听地址为0.0.0.0
/usr/local/elk/kibana-6.4.2-linux-x86_64/config/kibana.yml
server.host: "0.0.0.0"

启动服务
./bin/kibana &

访问http://localhost:5601 看是否可以显示管理界面

安装elasticsearch遇到的问题参考
https://blog.csdn.net/liangzhao_jay/article/details/56840941
我自己的测试修改结果
/etc/security/limits.conf

  • soft nofile 65536
    • hard nofile 131072
    • soft nproc 4096
    • hard nproc 65536

/etc/security/limits.d/90-nproc.conf

  • soft nproc 4096
    root soft nproc unlimited

/etc/sysctl.conf
vm.max_map_count=655360

上面的测试只能简单搭建elk

参考链接
https://blog.csdn.net/Ahri_J/article/details/79609444
https://www.cnblogs.com/yuhuLin/p/7018858.html
https://blog.csdn.net/fuckluy/article/details/80430732

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!