基于Centos快速搭建ELK
[TOC]
ELK是一个成熟的日志系统,主要功能有收集、分析、检索,详细见 elastic官网。
本文主要介绍如何在CentOS7下安装最新版本的ELK,当然现在docker已经有完全配置成功的elk容器,安装配置非常方便.
环境准备
- centos-7-x86_64
- java8
- elasticsearch-7.6.2
- kibana-7.6.2
- logstash-7.6.2
安装过程
关闭防火墙和Selinux
关闭Selinux
vim /etc/sysconfig/selinux
|
SELINUX=disabled #需重启永久生效 wq #保存退出 setenforce 0 #临时生效
|
data:image/s3,"s3://crabby-images/0db04/0db040eafcfd5db0e9da96e0c984f4471af48dad" alt="image-20200504171123609"
关闭Firewalld
systemctl stop firewalld #关闭防火墙 systemctl disable firewalld #禁止开机自启
|
data:image/s3,"s3://crabby-images/e12fc/e12fca997269aef1e579d8732765c32067ac13fa" alt="image-20200504171423477"
安装JDK
先是确认环境rpm -qa|grep Java
如果有其他版本的请删除
rpm–e –nodeps java-*
检查是否删除
java –version
安装Elasticsearch
- 导入密钥
rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch
|
- 下载最新的安装包
wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.6.2-x86_64.rpm
|
下载较慢的话建议科学下载
- 安装
rpm -ivh elasticsearch-7.6.2-x86_64.rpm
|
data:image/s3,"s3://crabby-images/f9983/f998308d0780cb4487d1b4d0cac2c92483dc54e5" alt="image-20200504174503913"
- 配置
vim /etc/elasticsearch/elasticsearch.yml
|
取消以下两行的注释
data:image/s3,"s3://crabby-images/9d9ff/9d9ff49449112a4158517d895bad75ba40545ebd" alt="image-20200504174906489"
data:image/s3,"s3://crabby-images/6d2d9/6d2d9913338656a0265f66dc05c132d90e5a497a" alt="image-20200504175014902"
- 启动
[root@localhost ~]# systemctl daemon-reload [root@localhost ~]# systemctl enable elasticsearch [root@localhost ~]# systemctl start elasticsearch [root@localhost ~]# netstat -plntu
|
观察到9200端口,证明启动成功
data:image/s3,"s3://crabby-images/1c00d/1c00d82a8992b225dd160deea0b17777bdfd944d" alt="image-20200504175254546"
安装Nginx
- 安装
[root@localhost ~]# yum install epel-release -y[root@localhost ~]# yum install nginx httpd-tools -y
|
安装Nginx之前要先安装epel源
- 配置
vim /etc/nginx/nginx.conf
|
这里把位于36、59行之间的Server块删掉,更多的配置项在 /etc/nginx/conf.d/*.conf中
36 include /etc/nginx/conf.d/*.conf;Server { }59# Settings for a TLS enabled server.
|
data:image/s3,"s3://crabby-images/0f284/0f2840c8db6d4fde025958c66ff923f5b99cfb82" alt="image-20200504180031958"
Kibanna添加代理
vim /etc/nginx/conf.d/kibana.conf
|
这里域名为 elk-stack.co,然后使用http协议的basic认证,密码稍后添加,然后看location块,当Nginx监听到域名为elk-stack.co,端口为80的请求时,就会转发给本地监听端口5601的进程,这个进程就是kibana,下一步安装它,内容如下:
server {listen 80;server_name elk-stack.co;auth_basic "Restricted Access";auth_basic_user_file /etc/nginx/.kibana-user;location / { proxy_pass http://localhost:5601; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection 'upgrade'; proxy_set_header Host $host; proxy_cache_bypass $http_upgrade;} }
|
data:image/s3,"s3://crabby-images/20ddb/20ddbafba1d0f9c0f3435c3c198e8a931ccb3fbc" alt="image-20200507221717828"
Elasticsearch添加代理
vim /etc/nginx/conf.d/elasticsearch.conf
|
当Nginx监听到域名为elk-stack.co,端口为81的请求时,就会转发给本地监听端口9200的进程,这个进程就是Elasticsearch
server {listen 81;server_name elk-stack.co;location / { proxy_pass http://localhost:9200; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection 'upgrade'; proxy_set_header Host $host; proxy_cache_bypass $http_upgrade;} }
|
data:image/s3,"s3://crabby-images/1b98b/1b98b08549bf9afd15b555c6c3ed5cafbeb7e11c" alt="image-20200507222435945"
添加basic认证
htpasswd -c /etc/nginx/.kibana-user admin
|
然后输入你的密码,记住最后要通过这个来登录kibana的
测试Nginx配置
出现如下证明Nginx成功
data:image/s3,"s3://crabby-images/4fb52/4fb527f38095fa2eca39b10e908dbff80bd0bf2c" alt="image-20200507223447583"
如果出现 test failed,就回过头检查/etc/nginx/conf.d/kibana.conf和/etc/nginx/nginx.conf这两个文件,肯定是不小心弄错了。
如果输出 test is successful,那么就可以启动 nginx 了
systemctl enable nginxsystemctl start nginx
|
安装Kibana
- 下载好对应的rpm包
rpm -ivh kibana-7.6.2-x86_64.rpm
|
data:image/s3,"s3://crabby-images/89299/892990c96227eda7214cba1c835f25be0d50908e" alt="image-20200507225326794"
- 修改Kibana配置
vim /etc/kibana/kibana.yml
|
- 取消2、7、28行的注释,行号不一定准确,但一定是下面这几项(各个版本行号可能有出入)
server.port: 5601server.host: "localhost"elasticsearch.url: "http://localhost:9200"
|
data:image/s3,"s3://crabby-images/f2981/f2981017336cbc7fe7767f117f43906305a9ecb1" alt="image-20200507231907245"
data:image/s3,"s3://crabby-images/cc08d/cc08d3299f65a617598bdb6c506185cf41fe0af7" alt="image-20200507232332287"
data:image/s3,"s3://crabby-images/0cf8d/0cf8db590cd8e470d337023061a9d3fc713a8232" alt="image-20200507232609205"
- 启动Kibana
systemctl enable kibanasystemctl start kibananetstat -plntu
|
出现5601端口代表Kibana启动成功
data:image/s3,"s3://crabby-images/68f96/68f9620abb880c3668a0998ba394da3cbce9731a" alt="image-20200507233100421"
安装Logstash
下载对应的rpm包
安装
rpm -ivh logstash-7.6.2.rpm
|
data:image/s3,"s3://crabby-images/27b34/27b349ee069fbb97e96ee517bd67228c82b1a7f4" alt="image-20200507233242902"
- 启动
systemctl enable logstashsystemctl start logstash
|
安装成功
访问对应ip的80端口
data:image/s3,"s3://crabby-images/d8e4b/d8e4b1bd97d22aee97907541a3b0181343fabd98" alt="image-20200507233840411"
如需用上面的域名访问,添加一条hosts就行
后面ELK优化敬请期待下一篇文章~