网站首页 > 技术文章 正文
简介:ELK是(Elasticsearch、Logstash、Kibana)三个软件的集合简称。那么这三个软件分别扮演着一个什么样的角色呢?
Elasticsearch:搜索引擎,主要任务是将日志索引并进行存储。
Logstash:通俗来讲就是一个中间者,负责将日志进行收集、过滤并转发,转发给谁呢?在没有特殊配置的情况下转发给Elasticsearch进行处理。
Kibana:可视化展示工具,我们通过web界面可以查看到它将es的数据很美观的展示给客户。
开始部署:
一、安装jdk1.8
下载好jdk包后上传到目录下,我这里是直接上传到/usr/java下解压即可。
如果没有目录,执行命令新建目录:mkdir /usr/java -p
执行如下命令让环境变量生效:source /etc/profile
执行如下命令查看java版本信息:java -version
二、下载ELK安装包
wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5.3.0.tar.gz
wget https://artifacts.elastic.co/downloads/logstash/logstash-5.3.0.tar.gz
wget https://artifacts.elastic.co/downloads/kibana/kibana-5.3.0-linux-x86_64.tar.gz
下载后如下图所示:
(一)安装elasticsearch
1、首先解压es安装包,然后将其mv到/usr/local/elasticsearch/下命令如下:
tar -xzf elasticsearch-5.3.0.tar.gz
mv elasticsearch-5.3.0 /usr/local/elasticsearch/
2、修改elasticsearch.yml配置文件,设置监听地址为network.hosts:0.0.0.0
3、创建elk用户,并赋予权限,用elk用户启动es,命令如下:
useradd elk ##创建用户
chown -R elk:elk /usr/local/elasticsearch/ ##赋予elk属主属组权
su – elk ##切换用户
/usr/local/elasticsearch/bin/elasticsearch –d ##后台启动es
可以查看日志或者ps进程是否启动成功,如下图所示:
(二)安装Elasticsearch插件
1、首先安装ES HEAD插件,命令如下:
下载head
git clone git://github.com/mobz/elasticsearch-head.git
由于head是基于nodejs的所以我们还需要安装nodejs
获取nodejs 资源
curl --silent --location https://rpm.nodesource.com/setup_5.x | bash -
yum -y install nodejs npm
配置registry代理,不然下面的操作会卡住不动。
npm config set registry https://registry.npm.taobao.org
npm install grunt-cli
npm install grunt
(三)安装配置Kibana
同上,先解压。
tar -xzf kibana-5.3.0-linux-x86_64.tar.gz
mv kibana-5.3.0-linux-x86_64 /usr/local/kibana/
修改kibana配置文件信息,设置ES地址:
vim /usr/local/kibana/config/kibana.yml
(四)安装配置Logstash
同上,先解压。
tar xzf logstash-5.3.0.tar.gz
mv logstash-5.3.0 /usr/local/logstash/
创建配置文件:vim logstash.conf,如下图所示:
启动logstash,命令如下:
/usr/local/logstash/bin/logstash -f /usr/local/logstash/config/etc/logstash.conf
浏览器输入:ip地址+9200端口即可访问
接来下就是配置如何去拿日志了及画图了,后续继续分享!
- 上一篇: cat命令的13个用法(cat 命令行)
- 下一篇: curl 使用方法大全(curl 示例)
猜你喜欢
- 2025-09-09 使用Docker搭建一个Mail邮箱系统_docker搭建邮件服务器
- 2025-09-09 Linux必学技能 | 17个案例带运维小白快速精通Awk命令,拿来即用
- 2025-09-09 稳定的Claude Code渠道,白嫖100刀
- 2025-09-09 如何写出安全的、基本功能完善的Bash脚本
- 2025-09-09 如何限制访问域名之外的请求都禁止访问,包括域名对应的ip
- 2025-09-09 代理 IP 地址与端口:核心概念、匹配逻辑及常见配置误区
- 2025-09-09 Linux重复操作太痛苦?Shell脚本让你1分钟搞定1小时活
- 2025-06-30 记录一次彻底清除挖矿病毒(挖矿 清退)
- 2025-06-30 linux计划任务管理(linux计划任务设置)
- 2025-06-30 Linux基本命令—修改命令别名(linux永久修改别名)
- 最近发表
-
- count(*)、count1(1)、count(主键)、count(字段) 哪个更快?
- 深入探索 Spring Boot3 中 MyBatis 的 association 标签用法
- js异步操作 Promise fetch API 带来的网络请求变革—仙盟创梦IDE
- HTTP状态码超详细说明_http 状态码有哪些
- 聊聊跨域的原理与解决方法_跨域解决方案及原理
- 告别懵圈!产品新人的接口文档轻松入门指南
- 在Javaweb中实现发送简单邮件_java web发布
- 优化必备基础:Oracle中常见的三种表连接方式
- Oracle常用工具使用 - AWR_oracle工具有哪些
- 搭载USB 3.1接口:msi 微星 发布 990FXA Gaming 游戏主板
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)