Table of contents
When OpenSearch bootstraps, PPL plugin will register a few settings in OpenSearch cluster settings. Most of the settings are able to change dynamically so you can control the behavior of PPL plugin without need to bounce your cluster.
You can disable SQL plugin to reject all coming requests.
- The default value is true.
- This setting is node scope.
- This setting can be updated dynamically.
Notes. Calls to _plugins/_ppl include index names in the request body, so they have the same access policy considerations as the bulk, mget, and msearch operations. if rest.action.multi.allow_explicit_index set to false, PPL plugin will be disabled.
You can update the setting with a new value like this.
PPL query:
sh$ curl -sS -H 'Content-Type: application/json' \
... -X PUT localhost:9200/_plugins/_query/settings \
... -d '{"transient" : {"plugins.ppl.enabled" : "false"}}'
{
"acknowledged": true,
"persistent": {},
"transient": {
"plugins": {
"ppl": {
"enabled": "false"
}
}
}
}
Note: the legacy settings of opendistro.ppl.enabled
is deprecated, it will fallback to the new settings if you request an update with the legacy name.
Query result after the setting updated is like:
PPL query:
sh$ curl -sS -H 'Content-Type: application/json' \
... -X POST localhost:9200/_plugins/_ppl \
{
"error": {
"reason": "Invalid Query",
"details": "Either plugins.ppl.enabled or rest.action.multi.allow_explicit_index setting is false",
"type": "IllegalAccessException"
},
"status": 400
}
You can reset the setting to default value like this.
PPL query:
sh$ curl -sS -H 'Content-Type: application/json' \
... -X PUT localhost:9200/_plugins/_query/settings \
... -d '{"transient" : {"plugins.ppl.enabled" : null}}'
{
"acknowledged": true,
"persistent": {},
"transient": {}
}
You can set heap memory usage limit for the query engine. When query running, it will detected whether the heap memory usage under the limit, if not, it will terminated the current query. The default value is: 85%
PPL query:
sh$ curl -sS -H 'Content-Type: application/json' \
... -X PUT localhost:9200/_plugins/_query/settings \
... -d '{"persistent" : {"plugins.query.memory_limit" : "80%"}}'
{
"acknowledged": true,
"persistent": {
"plugins": {
"query": {
"memory_limit": "80%"
}
}
},
"transient": {}
}
Note: the legacy settings of opendistro.ppl.query.memory_limit
is deprecated, it will fallback to the new settings if you request an update with the legacy name.
The size configure the maximum amount of documents to be pull from OpenSearch. The default value is: 200
Notes: This setting will impact the correctness of the aggregation operation, for example, there are 1000 docs in the index, by default, only 200 docs will be extract from index and do aggregation.
Change the size_limit to 1000:
sh$ curl -sS -H 'Content-Type: application/json' \
... -X PUT localhost:9200/_plugins/_query/settings \
... -d '{"persistent" : {"plugins.query.size_limit" : "1000"}}'
{
"acknowledged": true,
"persistent": {
"plugins": {
"query": {
"size_limit": "1000"
}
}
},
"transient": {}
}
Rollback to default value:
sh$ curl -sS -H 'Content-Type: application/json' \
... -X PUT localhost:9200/_plugins/_query/settings \
... -d '{"persistent" : {"plugins.query.size_limit" : null}}'
{
"acknowledged": true,
"persistent": {},
"transient": {}
}
Note: the legacy settings of opendistro.query.size_limit
is deprecated, it will fallback to the new settings if you request an update with the legacy name.