首页 > 其他分享 >Docker/Docker Compose部署ELK

Docker/Docker Compose部署ELK

时间:2022-08-17 16:00:36浏览次数:82  
标签:opt ELK Compose elk kibana logstash Docker docker

目录

Docker/Docker Compose部署ELK

Docker下安装ELK

  1. 搜索elk镜像
docker search sebp/elk
  1. 拉取elk镜像
docker pull sebp/elk:latest
  1. 运行容器
sudo docker run -p 5601:5601 -p 9200:9200 -p 5044:5044 -d --name log-platform --restart always  sebp/elk

遇到报错信息

max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]]


解决方案:

永久解决:在/etc/sysctl.conf文件最后添加一行:vm.max_map_count=262144 重启虚拟机
临时解决:sysctl -w vm.max_map_count=262144

  1. vi /etc/sysctl.conf
  2. vm.max_map_count=655360
  3. sysctl -p
  4. 重启es

DockerCompose 部署ELK

原文链接:https://blog.csdn.net/bshhr/article/details/122689931

准备工作

相关文件结构

在这里插入图片描述

修改系统的vm.max_map_count

基于elk-docker Prerequisites的说明,需要将系统的vm.max_map_count设置为262144或更多。

  1. 修改文件/etc/sysctl.conf
sudo vi /etc/sysctl.conf
  1. 增加以下属性
vm.max_map_count=262144
  1. 查看修改结果
sysctl -p

安装和配置ELK服务

获取sebp/elk的原始配置文件

// 在运行容器并且把容器里的配置cp到宿主机当中
docker run --name elk sebp/elk

docker cp -a elk:/opt/kibana/config/kibana.yml ./kibana

docker cp -a elk:/opt/logstash/config ./logstash/config

//然后删除刚才创建的容器
docker stop -f elk

docker rm -f elk

编写docker-compose文件

version: '3'
services:
  elk:
    image: sebp/elk
    container_name: elk
    restart: always
    ports:
      - "5601:5601"
      - "9200:9200"
      - "5044:5044"
    volumes:
      - /opt/docker/elk/elasticsearch/data:/var/lib/elasticsearch
      - /opt/docker/elk/logstash/conf.d:/etc/logstash/conf.d
      - /opt/docker/elk/logstash/config:/opt/logstash/config
      - /opt/docker/elk/kibana/kibana.yml:/opt/kibana/config/kibana.yml
    networks:
      - elk_net
    environment:
      - TZ=Asia/Shanghai
      
networks: 
  elk_net:
    external: true

单机版docker-compose文件

version: '3'
services:
  elk:
    image: sebp/elk
    container_name: elk
    restart: always
    ports:
      - "5601:5601"
      - "9200:9200"
      - "5044:5044"
    volumes:
      - /home/elk/elasticsearch/data:/var/lib/elasticsearch
      - /home/elk/logstash/conf.d:/etc/logstash/conf.d
      - /home/elk/logstash/config:/opt/logstash/config
      - /home/elk/kibana/kibana.yml:/opt/kibana/config/kibana.yml
    environment:
      - TZ=Asia/Shanghai

配置Logstash

创建配置文件

vi ./logstash/conf.d/yourconfigname.conf

根据需求配置文件内容

input {
  beats {
    port => 5044
  }
}
output {
  stdout {
    codec => rubydebug
  }
  elasticsearch {
    hosts => ["http://localhost:9200"]
    index => "%{[@metadata][beat]}-%{[@metadata][version]}-%{+YYYY.MM.dd}"
  }
}

汉化kibana

修改配置文件

vi ./kibana/kibana.yml

在文件末尾增加如下内容

i18n.locale: "zh-CN"

启动ELK

docker-compose -f ./docker-compose.yml up -d

启动完成后访问 http://ip:5601

报错

启动docker-compose报错:network elk_net declared as external, but could not be found

解决办法:启动前手动创建elk_net

docker network create --driver overlay elk_net

如果不需要集群可以使用单机版的docker-compose,就不会有这个报错。

标签:opt,ELK,Compose,elk,kibana,logstash,Docker,docker
From: https://www.cnblogs.com/AJun816/p/16595526.html

相关文章

  • 乘风破浪,遇见最美Windows 11之现代Windows开发运维 - Docker容器化镜像使用规范总结
    背景在通过Docker使用和打包容器化镜像的时候,很容易因为一些不规范的操作引发不必要的麻烦,下面总结一些规范项供参考。总结建议描述镜像构建除系统镜像外所......
  • Docker-基础
    1、Docker概述1.1Docker是什么Docker是一个开源的容器引擎,基于Go语言并遵从Apache2.0协议开源。开发这可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发......
  • 如何查看一个docker容器占用空间的大小?
    你如果想要知道,一个运行起来的容器,占用了多少磁盘空间该怎么做呢? 方法很简单。 使用下面的命令dockerps-s  得到下面的结果: 没错SIZE列,就是容器占用......
  • 什么是docker的存储驱动?有什么作用?
    如题目所示的问题,你知道吗? 读完下面的部分,你必然会豁然开朗······ 1、当你执行dockerpull命令拉取一个镜像的时候,镜像在docker主机上是怎么存储的?2、当你执......
  • docker 配置代理
    vi~/.docker/config.json{"proxies":{"default":{"httpProxy":"socks5h://192.168.36.106:7890","httpsProxy":"socks5h://19......
  • docker
    docker常用命令root权限进入容器dockerexec–it–urootpromrtheus/bin/sh复制文件从本地到服务器dockercp本地路径容器id或者容器名字:容器内路径复制......
  • 添加docker容器端口(映射宿主机和docker容器中的端口)
    1.关闭正在运行要修改的容器dockerstop容器id#二选一即可dockerstop容器名2.查看要修改的容器iddockerps-a   3.进入主机配置文件目录cd/var/l......
  • docker 如何删除none镜像
    删除none的镜像,要先删除镜像中的容器。要删除镜像中的容器,必须先停止容器。$dockerimages$dockerrmi$(dockerimages|grep"none"|awk'{print$3}')直接删除......
  • docker pull 和 push
    docker拉取镜像和推送镜像pull镜像dockerpull仓库地址(repository:tag)从镜像中运行容器#-i交互式操作#-t终端#-d后台运行#—name容器名字dockerru......
  • docker 安装oracle
    1、docker安装参考:     https://www.cnblogs.com/snailgirl/p/15503867.html2、拉取镜像     dockerpullregistry.cn-hangzhou.aliyuncs.com/helowin......