How to Deploy the Elastic Stack on Kubernetes
Updated by Linode Written by Tyler Langlois
What is the Elastic Stack?
The Elastic Stack is a collection of open source projects from Elastic that help collect and visualize a wide variety of data sources. Elasticsearch can store and aggregate data such as log files, container metrics, and more. The products in the stack include: Elasticsearch, Logstash, Kibana, and now Beats.
In this guide:
- You will configure and deploy a number of Helm charts in a Kubernetes cluster in order to set up components of the Elastic Stack.
- Configure and run Kibana in the web browser.
- Install Metricbeat and deploy dashboards to Kibana to explore Kubernetes cluster data.
At the end of this guide, you will have a deployment installed and configured that you can further use for application logs or monitoring Kubernetes itself.
CautionThis guide’s example instructions will create the following billable resources on your Linode account: four (4) Linodes and three (3) Block Storage volumes. If you do not want to keep using the example cluster that you create, be sure to delete the cluster Linodes and volumes when you have finished the guide.
If you remove the resources afterward, you will only be billed for the hour(s) that the resources were present on your account. Consult the Billing and Payments guide for detailed information about how hourly billing works and for a table of plan pricing.
Before You Begin
NoteThis guide uses Kubernetes services which are private by default. Local listeners are opened which allow you to access the services on your local browser, however, web servers and NodeBalancers are out scope for this guide. Due to this, you should complete the steps of this guide from your local computer or from a computer that you will give you access the web browser. If you wish to be able to access these services from a public domain, please see our guide on Getting Started with NodeBalancers.
Install the Kubernetes CLI (
kubectl
) on your computer, if it is not already.Follow the How to Deploy Kubernetes on Linode with the k8s-alpha CLI guide to set up a Kubernetes cluster. This guide will use a three node + master node cluster. You can use the following Linode k8s-alpha CLI command to create your cluster:
linode-cli k8s-alpha create example-cluster --node-type g6-standard-2 --nodes 3 --master-type g6-standard-2 --region us-east --ssh-public-key ~/.ssh/id_rsa.pub
You should use this guide instead of manual installation via a method such as
kubeadmin
, as the k8s-alpha tool will setup support for persistent volume claims.Node sizes are important when configuring Elasticsearch, and this guide assumes 4GB Linode instances.
This guide also assumes that your cluster has role-based access control (RBAC) enabled. This feature became available in Kubernetes 1.6. It is enabled on clusters created via the
k8s-alpha
Linode CLI.
You should also make sure that your Kubernetes CLI is using the right cluster context. Run the
get-contexts
subcommand to check:kubectl config get-contexts
Set up Helm in your Kubernetes cluster by following the How to Install Apps on Kubernetes with Helm guide and stop following the steps in this guide upon reaching the Use Helm Charts to Install Apps section.
Configure Helm
After following the prerequisites for this guide, you should have a Kubernetes cluster with Helm installed and configured.
Add the
elastic
chart repository to your local installation of Helm:helm repo add elastic https://helm.elastic.co
Fetch the updated list of charts from all configured chart repositories:
helm repo update
Search for the official
elasticsearch
chart to confirm Helm has been configured correctly. Note that this chart released by Elastic differs from the chart bundled with the default installation of Helm.helm search elasticsearch --version 7
This command should return results similar to the following. Note that your exact version numbers may be different.
NAME CHART VERSION APP VERSION DESCRIPTION elastic/elasticsearch 7.3.2 7.3.2 Official Elastic helm chart for Elasticsearch
Your Helm environment is now prepared to install official Elasticsearch charts into your kubernetes cluster.
Install Charts
Install Elasticsearch
Before installing the chart, ensure that resources are set appropriately. By default, the elasticsearch
chart allocates 1G of memory to the JVM heap and sets Kubernetes resource requests and limits to 2G. Using a Linode 4GB instance is compatible with these defaults, but if you are using a different instance type, you will need to provide different values to the chart at install time in order to ensure that running pods are within the resource constraints of the node sizes you have chosen.
Install the
elasticsearch
chart. This command will wait to complete until all pods are started and ready:helm install --name elasticsearch --wait --timeout=600 elastic/elasticsearch
A three-node Elasticsearch cluster is now configured and available locally to the Kubernetes cluster. To confirm this, first port-forward a local port to the Elasticsearch service. You should leave this command running in a terminal window or tab in in the background for the remainder of this tutorial.
kubectl port-forward svc/elasticsearch-master 9200:9200
In another terminal window, send a request to this port:
curl http://localhost:9200/
You should see a response similar to the following:
{ "name" : "elasticsearch-master-0", "cluster_name" : "elasticsearch", "cluster_uuid" : "o66WYOm5To2znbZ0kOkDUw", "version" : { "number" : "7.3.2", "build_flavor" : "default", "build_type" : "docker", "build_hash" : "1c1faf1", "build_date" : "2019-09-06T14:40:30.409026Z", "build_snapshot" : false, "lucene_version" : "8.1.0", "minimum_wire_compatibility_version" : "6.8.0", "minimum_index_compatibility_version" : "6.0.0-beta1" }, "tagline" : "You Know, for Search" }
Note that your specific version numbers and dates may be different in this json response. Elasticsearch is operational, but not receiving or serving any data.
Install Filebeat
In order to start processing data, deploy the filebeat
chart to your Kubernetes cluster. This will collect all pod logs and store them in Elasticsearch, after which they can be searched and used in visualizations within Kibana.
Deploy the
filebeat
chart. No customvalues.yaml
file should be necessary:helm install --name filebeat --wait --timeout=600 elastic/filebeat
Confirm that Filebeat has started to index documents into Elasticsearch by sending a request to the locally-forwarded Elasticsearch service port:
curl http://localhost:9200/_cat/indices
At least one
filebeat
index should be present, and output should be similar to the following:green open filebeat-7.3.12-2019.09.30-000001 peGIaeQRQq-bfeSG3s0RWA 1 1 9886 0 5.7mb 2.8mb
Install Kibana
Kibana will provide a frontend to Elasticsearch and the data collected by Filebeat.
Deploy the
kibana
chart:helm install --name kibana --wait --timeout=600 elastic/kibana
Port-forward the
kibana-kibana
service in order to access Kibana locally. Leave this command running in the background as well for the remainder of this tutorial.kubectl port-forward svc/kibana-kibana 5601:5601
Configure Kibana
Before visualizing pod logs, Kibana must be configured with an index pattern for Filebeat’s indices.
With the previous
port-forward
command running in another terminal window, open your browser and navigate to http://localhost:5601A page similar to the following should render in your browser.
To begin configuring index patterns, scroll down until the Index Patterns button appears, and click it.
The Index Patterns page should be displayed. Click the Create index pattern button to begin.
From this page, enter “filebeat-*” into the Index pattern text box, then click the Next step button.
In the following page, select
@timestamp
from the Time Filter field name dropdown menu, then click the Create index pattern button.A page with the index pattern details will then be shown. Click the Discover compass icon from the sidebar to view incoming logs.
The Discover page provides a realtime view of logs as they are ingested by Elasticsearch from your Kubernetes cluster. The histogram provides a view of log volume over time, which by default, spans the last 15 minutes. The sidebar on the left side of the user interface displays various fields parsed from json fields sent by Filebeat to Elasticsearch.
Use the Filters box to search only for logs arriving from Kibana pods by filtering for
kubernetes.container.name : "kibana"
. Click the Update button to apply the search filter.Note
When searching in the filters box, field names and values are auto-populated.In order to expand a log event, click the arrow next to an event in the user interface.
Scroll down to view the entire log document in Kibana. Observe the fields provided by Filebeat, including the
message
field, which contains standard out and standard error messages from the container, as well as the kubernetes node and pod name in fields prefixed withkubernetes
.Look closely at the
message
field in the log representation and note that the text field is formatted as json. While the terms in this field can be searched with free text search terms in Kibana, parsing this field will generally yield better results. The following section explains how to configure Filebeat and Kibana to achieve this.
Update Stack Configuration
At this point, the Elastic stack is functional and provides an interface to visualize and create dashboards for your logs from Kubernetes. This section will explain how to further configure the various components of the stack for greater visibility into your Kubernetes environment.
Create a values file for Filebeat. This configuration will add the ability to provide autodiscover hints. Instead of changing the Filebeat configuration each time parsing differences are encountered, autodiscover hints permit fragments of Filebeat configuration to be defined at the pod level dynamically so that applications can instruct Filebeat as to how their logs should be parsed.
- filebeat-values.yml
-
1 2 3 4 5 6 7 8 9 10
--- filebeatConfig: filebeat.yml: | filebeat.autodiscover: providers: - type: kubernetes hints.enabled: true output.elasticsearch: hosts: '\${ELASTICSEARCH_HOSTS:elasticsearch-master:9200}'
Upgrade the
filebeat
deployment to use this new configuration file:helm upgrade --values filebeat-values.yml --wait --timeout=600 filebeat elastic/filebeat
Once this command completes, Filebeat’s
DaemonSet
will have successfully updated all running pods.Next, create a Kibana values file to append annotations to the Kibana
Deployment
that will indicate that Filebeat should parse certain fields as json values. This configuration file will instruct Filebeat to parse themessage
field as json and store the parsed object underneath thekibana
field.- kibana-values.yml
-
1 2 3 4 5
--- podAnnotations: co.elastic.logs/processors.decode_json_fields.fields: message co.elastic.logs/processors.decode_json_fields.target: kibana
Upgrade the Kibana Helm release in your Kubernetes cluster, passing this file as an argument for the Chart values.
helm upgrade --values kibana-values.yml --wait --timeout=600 kibana elastic/kibana
Note, triggering a rolling pod update of Kibana will cause the previous
port-forward
to lose track of running pods. Terminate the previous Kibanaport-forward
command in the background terminal withCtrl-C
and start the command again:kubectl port-forward svc/kibana-kibana 5601:5601
Open a browser window to http://localhost:5601 and navigate to the same Index Patterns page again:
From the Index Patterns page, select the
filebeat-*
index pattern.From the index pattern page for
filebeat-*
, select the Refresh field list button.Confirm this action by selecting the Refresh button in the pop-up dialog.
Navigate to the “Discover” page.
Filter for
kibana
containers again, scroll down, and expand a log document. Note that various fields have been parsed into thekibana
field, such askibana.req.method
, indicating which HTTP verb was issued for a request for Kibana.
Metricbeat
In addition to collecting logs with Filebeat, Metricbeat can collect pod and node metrics in order to visualize information such as resource utilization.
Install Metricbeat
Deploy the
metricbeat
chart.helm install --name metricbeat --wait --timeout=600 elastic/metricbeat
Confirm that Metricbeat has started to index documents into Elasticsearch by sending a request to the locally-forwarded Elasticsearch service port:
curl http://localhost:9200/_cat/indices
At least one
metricbeat
index should be present, similar to the following:green open metricbeat-7.3.2-2019.09.30-000001 N75uVk_hTpmVbDKZE0oeIw 1 1 455 0 1.1mb 567.9kb
Load Dashboards
Metricbeat can install default Dashboards into Kibana to provide out-of-the-box visualizations for data collected by Kubernetes.
Before following these steps, ensure that the port-forward
command to expose Kibana over port 5601
locally is still running.
Run the following commands on your local machine. This will communicate with Kibana over 127.0.0.1:5601
to import default Dashboards that will be populated by data from Metricbeat.
NoteYour commands should use the same version of Metricbeat deployed to your Kubernetes cluster. You can find this version by issuing the following command:
helm get values --all metricbeat | grep imageTag
For Linux
Get the Metricbeat package.
wget https://artifacts.elastic.co/downloads/beats/metricbeat/metricbeat-7.3.2-linux-x86_64.tar.gz
Unzip the package.
tar xvzf metricbeat-7.3.2-linux-x86_64.tar.gz
Navigate to the directory.
cd metricbeat-7.3.2-linux-x86_64
Setup the dashboards.
./metricbeat setup --dashboards
For MacOS
Get the Metricbeat package.
wget https://artifacts.elastic.co/downloads/beats/metricbeat/metricbeat-7.3.2-darwin-x86_64.tar.gz
Unzip the package.
tar xvzf metricbeat-7.3.2-darwin-x86_64.tar.gz
Navigate to the directory.
cd metricbeat-7.3.2-darwin-x86_64
Setup the dashboards.
./metricbeat setup --dashboards
Explore Dashboards
Open a browser window to http://localhost:5601 and click the Dashboards icon on the left sidebar.
In the search box, enter “kubernetes” and press
Enter
. Select the [Metricbeat Kubernetes] Overview ECS dashboard.The following dashboard displays several types of metrics about your Kubernetes cluster.
You can explore the various visualizations on this page in order to view metrics about pods, nodes, and the overall health of the Kubernetes cluster.
Next Steps
From this point onward, any additional workloads started in Kubernetes will be processed by Filebeat and Metricbeat in order to collect logs and metrics for later introspection within Kibana. As Kubernetes nodes are added or removed, the Filebeat and Metricbeat DaemonSets
will automatically scale out pods to monitor nodes as they join the Kubernetes cluster.
More Information
You may wish to consult the following resources for additional information on this topic. While these are provided in the hope that they will be useful, please note that we cannot vouch for the accuracy or timeliness of externally hosted materials.
Join our Community
Find answers, ask questions, and help others.
This guide is published under a CC BY-ND 4.0 license.