OpenSearch/docs/reference/modules/memcached.asciidoc

70 lines
2.0 KiB
Plaintext

[[modules-memcached]]
== memcached
The memcached module allows to expose *Elasticsearch*
APIs over the memcached protocol (as closely
as possible).
It is provided as a plugin called `transport-memcached` and installing
is explained
https://github.com/elastic/elasticsearch-transport-memcached[here]
. Another option is to download the memcached plugin and placing it
under the `plugins` directory.
The memcached protocol supports both the binary and the text protocol,
automatically detecting the correct one to use.
[discrete]
=== Mapping REST to Memcached Protocol
Memcached commands are mapped to REST and handled by the same generic
REST layer in Elasticsearch. Here is a list of the memcached commands
supported:
[discrete]
==== GET
The memcached `GET` command maps to a REST `GET`. The key used is the
URI (with parameters). The main downside is the fact that the memcached
`GET` does not allow body in the request (and `SET` does not allow to
return a result...). For this reason, most REST APIs (like search) allow
to accept the "source" as a URI parameter as well.
[discrete]
==== SET
The memcached `SET` command maps to a REST `POST`. The key used is the
URI (with parameters), and the body maps to the REST body.
[discrete]
==== DELETE
The memcached `DELETE` command maps to a REST `DELETE`. The key used is
the URI (with parameters).
[discrete]
==== QUIT
The memcached `QUIT` command is supported and disconnects the client.
[discrete]
=== Settings
The following are the settings the can be configured for memcached:
[cols="<,<",options="header",]
|===============================================================
|Setting |Description
|`memcached.port` |A bind port range. Defaults to `11211-11311`.
|===============================================================
It also uses the common
<<modules-network,network settings>>.
[discrete]
=== Disable memcached
The memcached module can be completely disabled and not started using by
setting `memcached.enabled` to `false`. By default it is enabled once it
is detected as a plugin.