ELK的简介与es的安装部署

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 事件日志数据)

ELK的作用

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

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

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

收集-能够采集多种来源的日志数据
传输-能够稳定的把日志数据传输到中央系统
存储-如何存储日志数据
分析-可以支持 UI 分析
警告-能够提供错误报告,监控机制

ELK提供了一整套解决方案,并且都是开源软件,之间互相配合使用,完美衔接,高效的满足了很多场合的应用。目前主流的一种日志系统。

ES的安装部署

[root@server1 ~]# rpm -ivh jdk-8u121-linux-x64.rpm 

在这里插入图片描述
首先需要安装jdk,之后在安装elasticsearch,要注意先后顺序。

[root@server1 6.6]# rpm -ivh elasticsearch-6.6.1.rpm 

在这里插入图片描述
安装完成。
在这里插入图片描述

[root@server1 elasticsearch]# vim elasticsearch.yml
 23 node.name: server1
 55 network.host: 172.25.26.1
 59 http.port: 9200
 73 cluster.initial_master_nodes: ["server1"]

指定node节点和主机ip,开启9200端口。

[root@server1 elasticsearch]# systemctl daemon-reload 
[root@server1 elasticsearch]# systemctl start elasticsearch.service 

启动服务。
在这里插入图片描述
查看9200端口是否打开,这个端口打开了才算启动成功。
在这里插入图片描述
在浏览器上也可以查看到内容。
我们使用这个服务的时候,很多时候会将服务使用的内存锁定。

[root@server1 elasticsearch]# vim elasticsearch.yml

在这里插入图片描述
打开注释的这一行。

[root@server1 elasticsearch]# systemctl restart elasticsearch.service 

在这里插入图片描述
重启服务之后再使用netstat命令查看端口我们会发现已经查不到了,但是服务却显示正常,但由于端口为开启,这个服务是不能正常使用的。

[root@server1 elasticsearch]# cat /var/log/elasticsearch/elasticsearch.log 

在这里插入图片描述
我们可以查看es的日志,发现服务已经关闭了。

[root@server1 elasticsearch]# vim /etc/security/limits.conf 
elasticsearch   -       nofile  65535
elasticsearch   -       nproc   4096
elasticsearch   -       memlock unlimited

设置系统对资源的限制。

[root@server1 elasticsearch]# vim /usr/lib/systemd/system/elasticsearch.service 
LimitMEMLOCK=infinity

修改systemd的启动脚本。

[root@server1 elasticsearch]# vim elasticsearch.yml
[root@server1 elasticsearch]# systemctl daemon-reload 

重新加载配置
在这里插入图片描述

再次重启服务后可以看到9200端口启动了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值