Skip to content

A one-click Kubernetes EFK (Elasticsearch, Fluentbit, Kibana) stack setup for easy log management.

Notifications You must be signed in to change notification settings

code4mk/k8s-efk-logging-setup

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EFK Stack Installation for Kubernetes

This repository contains scripts and configurations for deploying the EFK (Elasticsearch, Fluent Bit, Kibana) stack on a Kubernetes cluster for centralized logging.

Overview

The EFK stack consists of:

  • Elasticsearch: Database to store and index logs
  • Fluent Bit: Lightweight log collector and forwarder
  • Kibana: Web UI for visualizing and analyzing logs

Prerequisites

  • Kubernetes cluster
  • Helm 3.x installed
  • kubectl configured to access your cluster
  • Sufficient cluster resources as defined in the values files

Installation

Option 1: Automated Installation

Run the installation script:

./install.sh

The script will present you with the following options:

  1. Install Elasticsearch only
  2. Install Kibana only
  3. Install Fluent Bit only
  4. Install Complete Stack
  5. Exit

Option 2: Manual Installation

  1. Create the logging namespace:
kubectl create namespace logging
  1. Add the Elastic and Fluent Bit Helm repositories:
helm repo add elastic https://helm.elastic.co
helm repo add fluent https://fluent.github.io/helm-charts
helm repo update
  1. Install Elasticsearch:
helm install elasticsearch elastic/elasticsearch -f ek/elasticsearch-values.yaml -n logging
  • it will take about 110 seconds to be ready
  1. Install Kibana:
helm install kibana elastic/kibana -f ek/kibana-values.yaml -n logging
  • it will also take about 110 seconds to be ready
  1. Install Fluent Bit:
helm install fluent-bit fluent/fluent-bit -f fluentbit/values.yaml -n logging

Accessing Kibana

kubectl port-forward svc/kibana-kibana 5601:5601 -n logging
  • http://localhost:5601

  • get the elastic user's password

$ kubectl get secrets --namespace=logging elasticsearch-master-credentials -ojsonpath='{.data.password}' | base64 -d
  • username is elastic

sample project deploy

kubectl create namespace backend
kubectl apply -f project.yml

💼 Need DevOps expertise?
📧 hiremostafa@gmail.com
🚀 Available for hire

About

A one-click Kubernetes EFK (Elasticsearch, Fluentbit, Kibana) stack setup for easy log management.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages