- Python Client: other versions:
- Overview
- Getting started
- Installation
- Connecting
- Configuration
- Migrating to 8.0
- Integrations
- Examples
- Client helpers
- Release notes
Release notes
editRelease notes
edit- 8.17.0 (2024-12-13)
- 8.16.0 (2024-11-12)
- 8.15.1 (2024-09-08)
- 8.15.0 (2024-08-09)
- 8.14.0 (2024-06-06)
- 8.13.2 (2024-05-24)
- 8.13.1 (2024-05-03)
- 8.13.0 (2024-03-22)
- 8.12.1 (2024-02-22)
- 8.12.0 (2024-01-19)
- 8.11.1 (2023-12-08)
- 8.11.0 (2023-11-13)
- 8.10.1 (2023-10-13)
- 8.10.0 (2023-09-22)
- 8.9.0 (2023-08-10)
- 8.8.1 (2023-07-06)
- 8.8.0 (2023-05-25)
- 8.7.0 (2023-04-06)
- 8.6.2 (2023-02-16)
- 8.6.1 (2023-01-27)
- 8.6.0 (2023-01-10)
- 8.5.3 (2022-12-08)
- 8.5.2 (2022-11-23)
- 8.5.1 (2022-11-21)
- 8.5.0 (2022-11-2)
- 8.4.3 (2022-10-06)
- 8.4.2 (2022-09-20)
- 8.4.1 (2022-09-06)
- 8.4.0 (2022-08-25)
- 8.3.3 (2022-08-01)
- 8.3.2 (2022-08-01)
- 8.3.1 (2022-06-30)
- 8.3.0 (2022-06-29)
- 8.2.3 (2022-06-15)
- 8.2.2 (2022-06-01)
- 8.2.1 (2022-06-01)
- 8.2.0 (2022-05-03)
- 8.1.2 (2022-03-30)
- 8.1.1 (2022-03-22)
- 8.1.0 (2022-03-08)
- 8.0.0 (2022-02-10)
8.17.0 (2024-12-13)
edit- Allow simsimd again on Python 3.13 (#2722)
-
Update APIs:
- Mark all Inference APIs as stable.
-
Add
allow_partial_search_results
to the Open Point in Time API -
Add
keep_alive
to the Get async search status API -
Remove the
keep_alive
,pre_filter_shard_size
andscroll
parameters from the Submit async search API. They were never supported. -
Add
master_timeout
andtimeout
to all autoscaling policy APIs -
Add
master_timeout
to the Alias exists and Get alias APIs -
Add
list_executed_pipelines
andrequire_data_stream
to Bulk API -
Add
include_model_definition
to Get trained models API -
Add
meta
to Create data frame analytics API -
Add
aggs
to Create datafeeds API -
Add
allow_no_indices
,expand_wildcards
,ignore_throttled
andignore_unavailable
to Create anomaly detection jobs API
8.16.0 (2024-11-12)
edit- Support Python 3.13 (#2689)
- Emit Python warnings for beta and tech preview APIs (#2685)
- Vectorstore: use a retriever query for hybrid search (#2682)
- Allow retries for statuses other than 429 in streaming bulk (#2702)
-
Make
BulkIndexError
andScanError
serializable (#2700) -
Fix import when
trace
is missing fromopentelemetry
package (#2705) -
Update APIs:
-
Fix
nodes
parameter in Task management API - Add Test query rule API
- Add Create Cross-Cluster API key and Update Cross-Cluster API key APIs
- Add Verify snapshot repository API
-
Add
data_stream_name
andsettings
to Delete auto-follow pattern API -
Add
max_samples_per_key
to Get async EQL status API -
Add
lifecycle
and remove unuseddata_retention
anddownsampling parameters
from Put data stream lifecycle API -
Add
include_remotes
and removeflat_settings
from Cluster stats API -
Add
remote_indices
to Create or update application privileges and Create or update roles APIs
-
Fix
Note that the new Python warnings can be disabled as follows:
import warnings from elasticsearch.exceptions import GeneralAvailabilityWarning warnings.filterwarnings("ignore", category=GeneralAvailabilityWarning)
8.15.1 (2024-09-08)
edit8.15.0 (2024-08-09)
edit- Added the Connector API (#2623)
- Added support for semantic_text and semantic query.
- Added support for sequences of job id, model id and tags where applicable in ML APIs
-
Added
dry_run
andforce
parameters to the Perform inference API - Added optional Arrow deserialization support (#2632)
- Merged Query Ruleset API into new Query Rules API (#2607)
- Added mapping code examples (#2596)
- Fixed reference docs (#2629)
- Dropped Python 3.7 support (#2618)
8.14.0 (2024-06-06)
edit-
Fixed
node_pool_class
override (#2581, contributed by Tallak Hellebust) -
Added
retriever
to the Search API -
Added
deprecated
and removedallow_auto_create
from the Create or update component template API -
Added
allow_auto_create
,cause
,deprecated
,ignore_missing_component_templates
andmaster_timeout
to the Create or update index template API -
Added
cause
, removedflat_settings
andtimeout
from the Create or update index template legacy API - Removed various unsupported parameters from the Simulate index API
- Added various supported paramters to the Simulate index template API
-
Added the
completion
andrerank
task types to the Inference APIs -
Added the
query
andtimeout
parameters to the Perform inference API -
Added
typed_keys
to the Search Application Search API -
Added
with_profile_uid
to the Get API key information and Query API key information APIs
8.13.2 (2024-05-24)
edit-
Added the
ml.update_trained_model_deployment
API - Marked Requests 2.32.2 as incompatible with the Elasticsearch client
8.13.1 (2024-05-03)
edit-
Added
force_synthetic_source
to the Get API -
Added
wait_for_completion
to the Create trained model API -
Added
typed_keys
to the Query API key information API
8.13.0 (2024-03-22)
edit- Added native OpenTelemetry support
-
Added optional
orjson
(a fast, correct JSON library) serialization support -
Added the
text_structure.test_grok_pattern
API -
Added the
indices.resolve_cluster
API -
Renamed the
model_id
parameter toinference_id
in theinference
APIs -
Changed all
synonyms
APIs from experimental to stable. - Fixed API key documentation
8.12.1 (2024-02-22)
edit- Fixed but deprecated parameter aliases in body parameter
- Added mappings and bulk to quickstart page
8.12.0 (2024-01-19)
edit- Dropped support for Python 3.6
-
Allowed unrestricted
body
parameter again - Added the Inference APIs
- Added the ES|QL API
-
Added
active_only
parameter tosecurity.get_api_key
API -
Added
expiration
parameter tosecurity.update_api_key
API
8.11.1 (2023-12-08)
edit-
Added missing
role_templates
tosecurity.put_role_mapping
API - Added interactive examples page to documentation
- Changed API reference to have one page per sub-client
8.11.0 (2023-11-13)
edit- Support Python 3.12
-
Added missing
scores
parameter to create trained model vocabulary API -
Added missing
delete_dest_index
parameter to delete transform API
8.10.1 (2023-10-13)
edit-
Removed deprecation warnings when using
body
parameter - Fixed some type hints to use covariant Sequence instead of invariant List
8.10.0 (2023-09-22)
edit- Added the Query rules APIs
- Added the Synonyms APIs
8.9.0 (2023-08-10)
edit-
Added the
cluster.info
API -
Updated the
inference_config
argument inml.put_trained_model
API to reflect an improvement in the specification
8.8.1 (2023-07-06)
edit-
Added the
rank
parameter to thesearch
API
8.8.0 (2023-05-25)
edit-
Added
include_defaults
parameter to thecluster.get_component_template
,indices.get_data_stream
, andindices.get_index_template
API -
Added the
indices.delete_data_lifecycle
,indices.explain_data_lifecycle
,indices.get_data_lifecycle
, andindices.put_data_lifecycle
APIs -
Added the experimental
search_application.delete
,search_application.delete_behavioral_analytics
,search_application.get
,search_application.get_behavioral_analytics
,search_application.list
,search_application.put
,search_application.put_behavioral_analytics
, andsearch_application.search
APIs.
8.7.0 (2023-04-06)
edit-
Added the
health_report
API -
Added the
transform.schedule_now_transform
API -
Added the
from_
request parameter to thetransform.start_transform
API -
Added the
buffer
,grid_agg
, andwith_labels
parameters to thesearch_mvt
API -
Added the
allow_auto_create
parameter to thecluster.create_component_template
API -
Added the
delete_user_annotations
parameter to theml.delete_job
,ml.reset_job
API -
Added the
start
andend
parameters to theml.preview_datafeed
API -
Added the
priority
parameter to theml.start_datafeed
API -
Added the
job_id
parameter to theml.update_datafeed
API -
Added the
model_prune_window
parameter to theml.update_job
API -
Added the
feature_states
parameter to thesnapshot.restore_snapshot
API -
Added the
timeout
parameter to thetransform.get_transform_stats
API -
Added the
from_
parameter to thetransform.start_transform
API -
Changed the
input
parameter of theml.put_trained_models
API from required to optional -
Fixed the
cluster.create_component_template
API by removing the erroneously providedaliases
,mappings
, andsettings
parameters. Only thetemplate
parameter should be used for specifying component templates.
8.6.2 (2023-02-16)
edit- Client is compatible with Elasticsearch 8.6.2
8.6.1 (2023-01-27)
edit- Client is compatible with Elasticsearch 8.6.1
Core
edit-
Added the
expand_wildcards
,preference
, androuting
parameters to theopen_point_in_time
API.
8.6.0 (2023-01-10)
edit- Client is compatible with Elasticsearch 8.6.0
Core
edit-
Changed the
fields
parameter of thefield_caps
API to be encoded in the HTTP request body. -
Changed the
index
parameter of therank_eval
API to be optional. -
Changed the
requests
parameter of therank_eval
API to be optional.
CAT
edit-
Added the
time
parameter to thecat.indices
API
Machine Learning
edit-
Fixed the
model_id
parameter of theml.clear_trained_model_deployment_cache
API to be required.
8.5.3 (2022-12-08)
edit- Client is compatible with Elasticsearch 8.5.3
8.5.2 (2022-11-23)
edit- Client is compatible with Elasticsearch 8.5.2
8.5.1 (2022-11-21)
edit- Client is compatible with Elasticsearch 8.5.1
8.5.0 (2022-11-2)
editIndices
edit-
Added the experimental
indices.downsample
API
Rollup
edit-
Removed the deprecated
rollup.rollup
API.
Snapshot
edit-
Added the
index_names
parameter to thesnapshot.get
API.
Machine Learning
edit-
Added the beta
ml.clear_trained_model_deployment_cache
API. -
Changed the
ml.put_trained_model_definition_part
API from experimental to stable. -
Changed the
ml.put_trained_model_vocabulary
API from experimental to stable. -
Changed the
ml.start_trained_model_deployment
API from experimental to stable. -
Changed the
ml.stop_trained_model_deployment
API from experimental to stable.
Security
edit-
Added the
with_limited_by
parameter to theget_api_key
API. -
Added the
with_limited_by
parameter to thequery_api_keys
API. -
Added the
with_profile_uid
parameter to theget_user
API. -
Changed the
security.activate_user_profile
API from beta to stable. -
Changed the
security.disable_user_profile
API from beta to stable. -
Changed the
security.enable_user_profile
API from beta to stable. -
Changed the
security.get_user_profile
API from beta to stable. -
Changed the
security.suggest_user_profiles
API from beta to stable. -
Changed the
security.update_user_profile_data
API from beta to stable. -
Changed the
security.has_privileges_user_profile
API from experimental to stable.
8.4.3 (2022-10-06)
edit- Client is compatible with Elasticsearch 8.4.3
8.4.2 (2022-09-20)
editDocuments
edit-
Added the
error_trace
,filter_path
,human
andpretty
parameters to theget_source
API. -
Added the
ext
parameter to thesearch
API.
Async Search
edit-
Added the
ext
parameter to theasync_search.submit
API.
Fleet
edit-
Added the
ext
parameter to thefleet.search
API.
8.4.1 (2022-09-06)
edit- Client is compatible with Elasticsearch 8.4.1
8.4.0 (2022-08-25)
editSearch
edit-
Added the
knn
parameter to thesearch
API. -
Added the
knn
parameter to theasync_search.submit
API.
Machine Learning
edit-
Added the
cache_size
parameter to theml.start_trained_model_deployment
API.
Security
edit-
Added the
security.update_api_key
API.
8.3.3 (2022-08-01)
edit- Client is compatible with Elasticsearch 8.3.3
8.3.2 (2022-08-01)
editSecurity
edit-
Added the
refresh
parameter to thesecurity.create_service_token
API.
8.3.1 (2022-06-30)
editSecurity
edit-
Added the experimental
security.has_privileges_user_profile
API. -
Added the
hint
parameter to the experimentalsecurity.suggest_user_profiles
API.
8.3.0 (2022-06-29)
edit- Client is compatible with Elasticsearch 8.3.0
8.2.3 (2022-06-15)
editDocuments
edit-
Added the
routing
parameter to themsearch
API.
CAT
edit-
Added the
cat.component_templates
API.
Ingest
edit-
Added the
if_version
parameter to theingest.put_pipeline
API.
Security
edit-
Changed the
name
parameter for thesecurity.create_service_token
API from required to optional. -
Added the
refresh
parameter to thesecurity.create_service_token
API. -
Changed the name of
access
parameter to thelabels
parameter in thesecurity.update_user_profile_data
API.
Shutdown
edit-
Added the
timeout
andmaster_timeout
parameters to theshutdown.get_node
,shutdown.delete_node
, andshutdown.put_node
APIs. -
Added the
reason
,type
,allocation_delay
, andtarget_node_name
parameters to theshutdown.put_node
API.
8.2.2 (2022-06-01)
edit- Client is compatible with Elasticsearch 8.2.2
8.2.1 (2022-06-01)
editMachine Learning
edit-
Added the
inference_config
parameter to theml.infer_trained_model_deployment
API
8.2.0 (2022-05-03)
editClient
edit-
Re-introduced support for passing
requests.auth.BaseAuth
objects to thehttp_auth
parameter which was available in 7.x.
Search
edit-
Added the
filter
parameter to the experimentalknn_search
API
Documents
edit-
Changed the
source
anddest
parameters for thereindex
API from optional to required
Indices
edit-
Added the
indices.field_usage_stats
API -
Added the
indices.modify_data_stream
API -
Added the
fields
andtypes
parameters to thefield_caps
API -
Added the
ignore_unvailable
parameter to theopen_point_in_time
API -
Added the
master_timeout
andtimeout
parameters to theindices.delete
API -
Added the
features
parameter to theindices.get
API
Machine Learning
edit-
Added the
ml.get_memory_stats
API
Migrations
edit-
Added the
migrations.get_feature_upgrade_status
API -
Added the
migrations.post_feature_upgrade
API
Nodes
edit-
Added the
nodes.clear_repositories_metering_archive
API -
Added the
nodes.get_repositories_metering_info
API
Security
edit-
Added the beta
security.activate_user_profile
API -
Added the beta
security.disable_user_profile
API -
Added the beta
security.enable_user_profile
API -
Added the beta
security.get_user_profile
API -
Added the beta
security.suggest_user_profiles
API -
Added the beta
security.update_user_profile_data
API
SQL
edit-
Added the
catalog
,index_using_frozen
,keep_alive
,keep_on_completion
,runtime_mappings
, andwait_for_completion_timeout
parameters to thesql.query
API
8.1.2 (2022-03-30)
edit- Client is compatible with Elasticsearch 8.1.2
8.1.1 (2022-03-22)
editDocuments
edit-
Changed the
source
anddest
parameters of thereindex
API to be required.
Mappings
edit-
Changed the
fields
parameter of thefield_caps
API to be required.
8.1.0 (2022-03-08)
editTransforms
edit-
Added the
transform.reset_transform
API
8.0.0 (2022-02-10)
editAdded
edit-
Added the top-level
.options()
method toElasticsearch
andAsyncElasticsearch
for modifying transport options. - Added parameters corresponding to JSON request body fields for all APIs
-
Added
basic_auth
parameter for specifying username and password authentication -
Added
bearer_auth
parameter for specifying an HTTP bearer token or service token -
Added the
meta
property toApiError
to access the HTTP response metadata of an error. -
Added a check that a compatible version of the
elastic-transport
package is installed.
Changed
edit-
Changed the transport layer to use the
elastic-transport
package -
Changed user-defined
body
parameters to have semantic names (e.gindex(document={...})
instead ofindex(body={...})
). -
Changed responses to be objects with two properties,
meta
for response metadata (HTTP status, headers, node, etc) andbody
for a typed body. -
Changed
AsyncElasticsearch
to always be available, regardless of whetheraiohttp
is installed -
Changed exception hierarchy, the major change is a new exception
ApiError
which differentiates between an error that’s raised from the transport layer (previouslyelasticsearch.exceptions.TransportError
, nowelastic_transport.TransportError
) and one raised from the API layer -
Changed the name of
JSONSerializer
toJsonSerializer
for consistency with other serializer names. Added an alias to the old name for backwards compatibility -
Changed the default mimetypes (
application/json
) to instead use compatibility mimetypes (application/vnd.elasticsearch+json
) which always request for responses compatibility with version 8.x.
Removed
edit- Removed support for Python 2.7 and Python 3.5, the library now supports only Python 3.6+
-
Removed the
elasticsearch.connection
module as all functionality has been moved to theelastic-transport
package -
Removed the default URL of
http://localhost:9200
due to Elasticsearch 8.0 default configuration beinghttps://localhost:9200
. The client’s connection to Elasticsearch now must be specified with scheme, host, and port or with thecloud_id
parameter - Removed the ability to use positional arguments with API methods. Going forward all API parameters must be keyword-only parameters
-
Removed the
doc_type
,include_type_name
, andcopy_settings
parameters from many document and index APIs
Deprecated
edit-
Deprecated the
body
andparams
parameters on all APIs -
Deprecated setting transport options
http_auth
,api_key
,ignore
,request_timeout
,headers
, andopaque_id
All of these settings should instead be set via the.options()
method -
Deprecated the
elasticsearch.transport
andelasticsearch.client
modules. These modules will be removed in a future version
CAT
edit-
Removed the deprecated
local
parameter from thecat.indices
,cat.nodes
,cat.shards
API -
Removed the deprecated
allow_no_datafeeds
parameter from thecat.ml_datafeeds
API -
Removed the deprecated
allow_no_jobs
parameter from thecat.ml_jobs
API -
Removed the deprecated
size
parameter from thecat.thread_pool
API -
Added the
time
parameter to thecat.thread_pool
API
Documents
edit-
Removed the deprecated
size
parameter from thedelete_by_query
API -
Removed the deprecated
size
parameter from theupdate_by_query
API
Indices
edit-
Removed the deprecated
indices.flush_synced
API -
Removed the deprecated
indices.freeze
API -
Removed the deprecated
indices.get_upgrade
API -
Removed the deprecated
indices.upgrade
API -
Removed the deprecated
indices.exist_type
API -
Removed the deprecated parameter
copy_settings
from theindices.shrink
API -
Deprecated the
verbose
parameter of theindices.segments
API
License / X-Pack
edit-
Deprecated the
accept_enterprise
parameter of thelicense.get
API -
Deprecated the
accept_enterprise
parameter of thexpack.info
API
Machine Learning
edit-
Added the experimental
ml.infer_trained_model_deployment
API -
Added the experimental
ml.put_trained_model_definition_part
API -
Added the experimental
ml.put_trained_model_vocabulary
API -
Added the experimental
ml.start_trained_model_deployment
API -
Added the experimental
ml.stop_trained_model_deployment
API -
Added the
timeout
parameter to theml.delete_trained_model
API -
Removed the deprecated
allow_no_jobs
parameter from theml.close_job
API -
Removed the deprecated
ml.find_text_structure
API -
Removed the deprecated
allow_no_datafeeds
parameter from theml.get_datafeed_stats
API -
Removed the deprecated
allow_no_datafeeds
parameter from theml.get_datafeeds
API -
Removed the deprecated
allow_no_jobs
parameter from theml.get_job_stats
API -
Removed the deprecated
allow_no_jobs
parameter from theml.get_jobs
API -
Removed the deprecated
allow_no_jobs
parameter from theml.get_overall_buckets
API
Search
edit-
Added the experimental
knn_search
API
Searchable Snapshots
edit-
Removed the deprecated
searchable_snapshots.repository_stats
API
Snapshots
edit-
Changed the
snapshot.delete
API to accept multiple snapshots
Security
edit-
Added the
security.enroll_kibana
API -
Added the
security.enroll_node
API
On this page
- 8.17.0 (2024-12-13)
- 8.16.0 (2024-11-12)
- 8.15.1 (2024-09-08)
- 8.15.0 (2024-08-09)
- 8.14.0 (2024-06-06)
- 8.13.2 (2024-05-24)
- 8.13.1 (2024-05-03)
- 8.13.0 (2024-03-22)
- 8.12.1 (2024-02-22)
- 8.12.0 (2024-01-19)
- 8.11.1 (2023-12-08)
- 8.11.0 (2023-11-13)
- 8.10.1 (2023-10-13)
- 8.10.0 (2023-09-22)
- 8.9.0 (2023-08-10)
- 8.8.1 (2023-07-06)
- 8.8.0 (2023-05-25)
- 8.7.0 (2023-04-06)
- 8.6.2 (2023-02-16)
- 8.6.1 (2023-01-27)
- Core
- 8.6.0 (2023-01-10)
- Core
- CAT
- Machine Learning
- 8.5.3 (2022-12-08)
- 8.5.2 (2022-11-23)
- 8.5.1 (2022-11-21)
- 8.5.0 (2022-11-2)
- Indices
- Rollup
- Snapshot
- Machine Learning
- Security
- 8.4.3 (2022-10-06)
- 8.4.2 (2022-09-20)
- Documents
- Async Search
- Fleet
- 8.4.1 (2022-09-06)
- 8.4.0 (2022-08-25)
- Search
- Machine Learning
- Security
- 8.3.3 (2022-08-01)
- 8.3.2 (2022-08-01)
- Security
- 8.3.1 (2022-06-30)
- Security
- 8.3.0 (2022-06-29)
- 8.2.3 (2022-06-15)
- Documents
- CAT
- Ingest
- Security
- Shutdown
- 8.2.2 (2022-06-01)
- 8.2.1 (2022-06-01)
- Machine Learning
- 8.2.0 (2022-05-03)
- Client
- Search
- Documents
- Indices
- Machine Learning
- Migrations
- Nodes
- Security
- SQL
- 8.1.2 (2022-03-30)
- 8.1.1 (2022-03-22)
- Documents
- Mappings
- 8.1.0 (2022-03-08)
- Transforms
- 8.0.0 (2022-02-10)
- Added
- Changed
- Removed
- Deprecated
- CAT
- Documents
- Indices
- License / X-Pack
- Machine Learning
- Search
- Searchable Snapshots
- Snapshots
- Security
Was this helpful?
Thank you for your feedback.