- Elastic Cloud on Kubernetes:
- Overview
- Quickstart
- Operating ECK
- Orchestrating Elastic Stack applications
- Run Elasticsearch on ECK
- Node configuration
- Volume claim templates
- Storage recommendations
- Transport settings
- Virtual memory
- Settings managed by ECK
- Secure settings
- Custom configuration files and plugins
- Init containers for plugin downloads
- Update strategy
- Pod disruption budget
- Nodes orchestration
- Advanced Elasticsearch node scheduling
- Create automated snapshots
- Remote clusters
- Readiness probe
- Pod PreStop hook
- Elasticsearch autoscaling
- JVM heap dumps
- Security Context
- Run Kibana on ECK
- Run APM Server on ECK
- Run standalone Elastic Agent on ECK
- Run Fleet-managed Elastic Agent on ECK
- Run Elastic Maps Server on ECK
- Run Enterprise Search on ECK
- Run Beats on ECK
- Run Logstash on ECK
- Elastic Stack Helm Chart
- Recipes
- Secure the Elastic Stack
- Access Elastic Stack services
- Customize Pods
- Manage compute resources
- Autoscaling stateless applications
- Elastic Stack configuration policies
- Upgrade the Elastic Stack version
- Connect to external Elastic resources
- Run Elasticsearch on ECK
- Advanced topics
- Troubleshooting ECK
- Reference
- API Reference
- agent.k8s.elastic.co/v1alpha1
- apm.k8s.elastic.co/v1
- apm.k8s.elastic.co/v1beta1
- autoscaling.k8s.elastic.co/v1alpha1
- beat.k8s.elastic.co/v1beta1
- common.k8s.elastic.co/v1
- common.k8s.elastic.co/v1alpha1
- common.k8s.elastic.co/v1beta1
- elasticsearch.k8s.elastic.co/v1
- elasticsearch.k8s.elastic.co/v1beta1
- enterprisesearch.k8s.elastic.co/v1
- enterprisesearch.k8s.elastic.co/v1beta1
- kibana.k8s.elastic.co/v1
- kibana.k8s.elastic.co/v1beta1
- logstash.k8s.elastic.co/v1alpha1
- maps.k8s.elastic.co/v1alpha1
- stackconfigpolicy.k8s.elastic.co/v1alpha1
- Glossary
- Third-party dependencies
- API Reference
- Release highlights
- 2.16.1 release highlights
- 2.16.0 release highlights
- 2.15.0 release highlights
- 2.14.0 release highlights
- 2.13.0 release highlights
- 2.12.1 release highlights
- 2.12.0 release highlights
- 2.11.1 release highlights
- 2.11.0 release highlights
- 2.10.0 release highlights
- 2.9.0 release highlights
- 2.8.0 release highlights
- 2.7.0 release highlights
- 2.6.2 release highlights
- 2.6.1 release highlights
- 2.6.0 release highlights
- 2.5.0 release highlights
- 2.4.0 release highlights
- 2.3.0 release highlights
- 2.2.0 release highlights
- 2.1.0 release highlights
- 2.0.0 release highlights
- 1.9.1 release highlights
- 1.9.0 release highlights
- 1.8.0 release highlights
- 1.7.1 release highlights
- 1.7.0 release highlights
- 1.6.0 release highlights
- 1.5.0 release highlights
- 1.4.1 release highlights
- 1.4.0 release highlights
- 1.3.2 release highlights
- 1.3.1 release highlights
- 1.3.0 release highlights
- 1.2.2 release highlights
- 1.2.1 release highlights
- 1.2.0 release highlights
- 1.1.2 release highlights
- 1.1.1 release highlights
- 1.1.0 release highlights
- 1.0.1 release highlights
- 1.0.0 release highlights
- 1.0.0-beta1 release highlights
- Release notes
- Elastic Cloud on Kubernetes version 2.16.1
- Elastic Cloud on Kubernetes version 2.16.0
- Elastic Cloud on Kubernetes version 2.15.0
- Elastic Cloud on Kubernetes version 2.14.0
- Elastic Cloud on Kubernetes version 2.13.0
- Elastic Cloud on Kubernetes version 2.12.1
- Elastic Cloud on Kubernetes version 2.12.0
- Elastic Cloud on Kubernetes version 2.11.1
- Elastic Cloud on Kubernetes version 2.11.0
- Elastic Cloud on Kubernetes version 2.10.0
- Elastic Cloud on Kubernetes version 2.9.0
- Elastic Cloud on Kubernetes version 2.8.0
- Elastic Cloud on Kubernetes version 2.7.0
- Elastic Cloud on Kubernetes version 2.6.2
- Elastic Cloud on Kubernetes version 2.6.1
- Elastic Cloud on Kubernetes version 2.6.0
- Elastic Cloud on Kubernetes version 2.5.0
- Elastic Cloud on Kubernetes version 2.4.0
- Elastic Cloud on Kubernetes version 2.3.0
- Elastic Cloud on Kubernetes version 2.2.0
- Elastic Cloud on Kubernetes version 2.1.0
- Elastic Cloud on Kubernetes version 2.0.0
- Elastic Cloud on Kubernetes version 1.9.1
- Elastic Cloud on Kubernetes version 1.9.0
- Elastic Cloud on Kubernetes version 1.8.0
- Elastic Cloud on Kubernetes version 1.7.1
- Elastic Cloud on Kubernetes version 1.7.0
- Elastic Cloud on Kubernetes version 1.6.0
- Elastic Cloud on Kubernetes version 1.5.0
- Elastic Cloud on Kubernetes version 1.4.1
- Elastic Cloud on Kubernetes version 1.4.0
- Elastic Cloud on Kubernetes version 1.3.2
- Elastic Cloud on Kubernetes version 1.3.1
- Elastic Cloud on Kubernetes version 1.3.0
- Elastic Cloud on Kubernetes version 1.2.2
- Elastic Cloud on Kubernetes version 1.2.1
- Elastic Cloud on Kubernetes version 1.2.0
- Elastic Cloud on Kubernetes version 1.1.2
- Elastic Cloud on Kubernetes version 1.1.1
- Elastic Cloud on Kubernetes version 1.1.0
- Elastic Cloud on Kubernetes version 1.0.1
- Elastic Cloud on Kubernetes version 1.0.0
- Elastic Cloud on Kubernetes version 1.0.0-beta1
Manage licenses in ECK
editManage licenses in ECK
editWhen you install the default distribution of ECK, you receive a Basic license. Any Elastic stack application you manage through ECK will also be Basic licensed. Go to https://www.elastic.co/subscriptions to check which features are included in the Basic license for free.
ECK is only offered in two licensing tiers: Basic and Enterprise. Similar to the Elastic Stack, customers can download and use ECK with a Basic license for free. Basic license users can obtain support from GitHub or through our community. A paid Enterprise subscription is required to engage the Elastic support team. For more details, check the Elastic subscriptions.
In this section, you are going to learn how to:
Start a trial
editIf you want to try the features included in the Enterprise subscription, you can start a 30-day trial. To start a trial, create a Kubernetes secret as shown in this example. Note that it must be in the same namespace as the operator:
cat <<EOF | kubectl apply -f - apiVersion: v1 kind: Secret metadata: name: eck-trial-license namespace: elastic-system labels: license.k8s.elastic.co/type: enterprise_trial annotations: elastic.co/eula: accepted EOF
By setting this annotation to |
You can initiate a trial only if a trial has not been previously activated.
At the end of the trial period, the Platinum and Enterprise features operate in a degraded mode. You can revert to a Basic license, extend the trial, or purchase an Enterprise subscription.
Add a license
editIf you have a valid Enterprise subscription or a trial license extension, you will receive a link to download a license as a JSON file.
When downloading the license choose the "Orchestration license" option.
The downloaded JSON file contains the Enterprise orchestration license which enables ECK Enterprise features. Embedded in the orchestration license are also Enterprise stack licenses for recent Elasticsearch versions and Platinum licenses for older Elasticsearch versions that do not support Enterprise licenses.
To add the license to your ECK installation, create a Kubernetes secret of the following form:
apiVersion: v1 kind: Secret metadata: labels: license.k8s.elastic.co/scope: operator name: eck-license type: Opaque data: license: "JSON license in base64 format"
You can easily create this secret using kubectl
built-in support for secrets. Note that it must be in the same namespace as the operator:
kubectl create secret generic eck-license --from-file=my-license-file.json -n elastic-system kubectl label secret eck-license "license.k8s.elastic.co/scope"=operator -n elastic-system
After you install a license into ECK, the Enterprise features of the operator are available, like Elasticsearch autoscaling and support for Elastic Maps Server. All the Elastic Stack applications you manage with ECK will have Platinum and Enterprise features enabled. The _license
API reports that individual Elasticsearch clusters are running under an Enterprise license, and the elastic-licensing ConfigMap contains the current license level of the ECK operator. The applications created before you installed the license are upgraded to Platinum or Enterprise features without interruption of service after a short delay.
The Elasticsearch _license
API for versions before 8.0.0 reports a Platinum license level for backwards compatibility even if an Enterprise license is installed.
Update your license
editBefore your current Enterprise license expires, you will receive a new Enterprise license from Elastic (provided that your subscription is valid).
You can check the expiry date of your license in the elastic-licensing ConfigMap. Enterprise licenses are container licenses that include multiple licenses for individual Elasticsearch clusters with shorter expiry. Therefore, you get a different expiry in Kibana or through the Elasticsearch _license
API. ECK automatically updates the Elasticsearch cluster licenses until the expiry date of the ECK Enterprise license is reached.
To avoid any unintended downgrade of individual Elasticsearch clusters to a Basic license while installing the new license, we recommend installing the new Enterprise license as a new Kubernetes secret next to your existing Enterprise license. Just replace eck-license
with a different name in the Kubernetes secret example. ECK will use the correct license automatically.
Once you have created the new license secret you can safely delete the old license secret.
Get usage data
editThe operator periodically writes the total amount of Elastic resources under management to a configmap named elastic-licensing
, which is in the same namespace as the operator. Here is an example of retrieving the data:
> kubectl -n elastic-system get configmap elastic-licensing -o json | jq .data { "apm_memory": "0.50GiB", "apm_memory_bytes": "536870912", "eck_license_expiry_date": "2025-01-01T00:59:59+01:00", "eck_license_level": "enterprise", "elasticsearch_memory": "18.00GiB", "elasticsearch_memory_bytes": "19327352832", "enterprise_resource_units": "1", "enterprise_search_memory": "4.00GiB", "enterprise_search_memory_bytes": "4294967296", "kibana_memory": "1.00GiB", "kibana_memory_bytes": "1073741824", "logstash_memory": "2.00GiB", "logstash_memory_bytes": "2147483648", "max_enterprise_resource_units": "250", "timestamp": "2024-07-26T12:40:42+02:00", "total_managed_memory": "25.50GiB", "total_managed_memory_bytes": "27380416512" }
If the operator metrics endpoint is enabled with the --metrics-port
flag (check Configure ECK), license usage data will be included in the reported metrics.
> curl "$ECK_METRICS_ENDPOINT" | grep elastic_licensing # HELP elastic_licensing_enterprise_resource_units_max Maximum number of enterprise resource units available # TYPE elastic_licensing_enterprise_resource_units_max gauge elastic_licensing_enterprise_resource_units_max{license_level="enterprise"} 250 # HELP elastic_licensing_enterprise_resource_units_total Total enterprise resource units used # TYPE elastic_licensing_enterprise_resource_units_total gauge elastic_licensing_enterprise_resource_units_total{license_level="enterprise"} 1 # HELP elastic_licensing_memory_gibibytes_apm Memory used by APM server in GiB # TYPE elastic_licensing_memory_gibibytes_apm gauge elastic_licensing_memory_gibibytes_apm{license_level="enterprise"} 0.5 # HELP elastic_licensing_memory_gibibytes_elasticsearch Memory used by Elasticsearch in GiB # TYPE elastic_licensing_memory_gibibytes_elasticsearch gauge elastic_licensing_memory_gibibytes_elasticsearch{license_level="enterprise"} 18 # HELP elastic_licensing_memory_gibibytes_enterprise_search Memory used by Enterprise Search in GiB # TYPE elastic_licensing_memory_gibibytes_enterprise_search gauge elastic_licensing_memory_gibibytes_enterprise_search{license_level="enterprise"} 4 # HELP elastic_licensing_memory_gibibytes_kibana Memory used by Kibana in GiB # TYPE elastic_licensing_memory_gibibytes_kibana gauge elastic_licensing_memory_gibibytes_kibana{license_level="enterprise"} 1 # HELP elastic_licensing_memory_gibibytes_logstash Memory used by Logstash in GiB # TYPE elastic_licensing_memory_gibibytes_logstash gauge elastic_licensing_memory_gibibytes_logstash{license_level="enterprise"} 2 # HELP elastic_licensing_memory_gibibytes_total Total memory used in GiB # TYPE elastic_licensing_memory_gibibytes_total gauge elastic_licensing_memory_gibibytes_total{license_level="enterprise"} 25.5
Logstash resources managed by ECK will be counted towards ERU usage for informational purposes. Billable consumption depends on license terms on a per customer basis (See Self Managed Subscription Agreement)
ElasticON events are back!
Learn about the Elastic Search AI Platform from the experts at our live events.
Register now