| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347 | [[plugin-management]]== Plugin management[discrete]=== Managing plugins on {ess}Refer to the {cloud}/ec-adding-plugins.html[{ess} documentation] for informationabout managing plugins on {ecloud}.[discrete]=== Managing plugins for self-managed deploymentsUse the `elasticsearch-plugin` command line tool to install, list, and remove plugins. It islocated in the `$ES_HOME/bin` directory by default but it may be in adifferent location depending on which Elasticsearch package you installed:* {ref}/targz.html#targz-layout[Directory layout of `.tar.gz` archives]* {ref}/zip-windows.html#windows-layout[Directory layout of Windows `.zip` archives]* {ref}/deb.html#deb-layout[Directory layout of Debian package]* {ref}/rpm.html#rpm-layout[Directory layout of RPM]Run the following command to get usage instructions:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin -h-----------------------------------[IMPORTANT].Running as root=====================If Elasticsearch was installed using the deb or rpm package then run`/usr/share/elasticsearch/bin/elasticsearch-plugin` as `root` so it can write to the appropriate files on disk.Otherwise run `bin/elasticsearch-plugin` as the user that owns all of the Elasticsearchfiles.=====================[discrete][[plugin-management-docker]]=== DockerIf you run {es} using Docker, you can manage plugins using a<<manage-plugins-using-configuration-file,configuration file>>.[[installation]]=== Installing pluginsThe documentation for each plugin usually includes specific installationinstructions for that plugin, but below we document the various availableoptions:[discrete]=== Core Elasticsearch pluginsCore Elasticsearch plugins can be installed as follows:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin install [plugin_name]-----------------------------------For instance, to install the core <<analysis-icu,ICU plugin>>, just run thefollowing command:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin install analysis-icu-----------------------------------This command will install the version of the plugin that matches yourElasticsearch version and also show a progress bar while downloading.[[plugin-management-custom-url]]=== Custom URL or file systemA plugin can also be downloaded directly from a custom location by specifying the URL:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin install [url] <1>-----------------------------------<1> must be a valid URL, the plugin name is determined from its descriptor.--Unix::To install a plugin from your local file system at `/path/to/plugin.zip`, you could run:+[source,shell]-----------------------------------sudo bin/elasticsearch-plugin install file:///path/to/plugin.zip-----------------------------------Windows::To install a plugin from your local file system at `C:\path\to\plugin.zip`, you could run:+[source,shell]-----------------------------------bin\elasticsearch-plugin install file:///C:/path/to/plugin.zip-----------------------------------+NOTE: Any path that contains spaces must be wrapped in quotes!+NOTE: If you are installing a plugin from the filesystem the plugin distributionmust not be contained in the `plugins` directory for the node that you areinstalling the plugin to or installation will fail.HTTP::To install a plugin from an HTTP URL:+[source,shell]-----------------------------------sudo bin/elasticsearch-plugin install https://some.domain/path/to/plugin.zip-----------------------------------+The plugin script will refuse to talk to an HTTPS URL with an untrustedcertificate. To use a self-signed HTTPS cert, you will need to add the CA certto a local Java truststore and pass the location to the script as follows:+[source,shell]-----------------------------------sudo CLI_JAVA_OPTS="-Djavax.net.ssl.trustStore=/path/to/trustStore.jks" bin/elasticsearch-plugin install https://host/plugin.zip-------------------------------------[[installing-multiple-plugins]]=== Installing multiple pluginsMultiple plugins can be installed in one invocation as follows:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin install [plugin_id] [plugin_id] ... [plugin_id]-----------------------------------Each `plugin_id` can be any valid form for installing a single plugin (e.g., thename of a core plugin, or a custom URL).For instance, to install the core <<analysis-icu,ICU plugin>>, run the following command:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin install analysis-icu-----------------------------------This command will install the versions of the plugins that matches yourElasticsearch version. The installation will be treated as a transaction, sothat all the plugins will be installed, or none of the plugins will be installedif any installation fails.[[mandatory-plugins]]=== Mandatory pluginsIf you rely on some plugins, you can define mandatory plugins by adding`plugin.mandatory` setting to the `config/elasticsearch.yml` file, forexample:[source,yaml]--------------------------------------------------plugin.mandatory: analysis-icu,lang-js--------------------------------------------------For safety reasons, a node will not start if it is missing a mandatory plugin.[[listing-removing-updating]]=== Listing, removing and updating installed plugins[discrete]=== Listing pluginsA list of the currently loaded plugins can be retrieved with the `list` option:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin list-----------------------------------Alternatively, use the {ref}/cluster-nodes-info.html[node-info API] to findout which plugins are installed on each node in the cluster[discrete]=== Removing pluginsPlugins can be removed manually, by deleting the appropriate directory under`plugins/`, or using the public script:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin remove [pluginname]-----------------------------------After a Java plugin has been removed, you will need to restart the node tocomplete the removal process.By default, plugin configuration files (if any) are preserved on disk; this isso that configuration is not lost while upgrading a plugin. If you wish topurge the configuration files while removing a plugin, use `-p` or `--purge`.This can option can be used after a plugin is removed to remove any lingeringconfiguration files.[discrete][[removing-multiple-plugins]]=== Removing multiple pluginsMultiple plugins can be removed in one invocation as follows:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin remove [pluginname] [pluginname] ... [pluginname]-----------------------------------[discrete]=== Updating pluginsExcept for text analysis plugins that are created using the<<creating-stable-plugins,stable plugin API>>, plugins are built for a specificversion of {es}, and must be reinstalled each time {es} is updated.[source,shell]-----------------------------------sudo bin/elasticsearch-plugin remove [pluginname]sudo bin/elasticsearch-plugin install [pluginname]-----------------------------------=== Other command line parametersThe `plugin` scripts supports a number of other command line parameters:[discrete]=== Silent/verbose modeThe `--verbose` parameter outputs more debug information, while the `--silent`parameter turns off all output including the progress bar. The script mayreturn the following exit codes:[horizontal]`0`:: everything was OK`64`:: unknown command or incorrect option parameter`74`:: IO error`70`:: any other error[discrete]=== Batch modeCertain plugins require more privileges than those provided by default in coreElasticsearch. These plugins will list the required privileges and ask theuser for confirmation before continuing with installation.When running the plugin install script from another program (e.g. installautomation scripts), the plugin script should detect that it is not beingcalled from the console and skip the confirmation response, automaticallygranting all requested permissions. If console detection fails, then batchmode can be forced by specifying `-b` or `--batch` as follows:[source,shell]-----------------------------------sudo bin/elasticsearch-plugin install --batch [pluginname]-----------------------------------[discrete]=== Custom config directoryIf your `elasticsearch.yml` config file is in a custom location, you will needto specify the path to the config file when using the `plugin` script. Youcan do this as follows:[source,sh]---------------------sudo ES_PATH_CONF=/path/to/conf/dir bin/elasticsearch-plugin install <plugin name>---------------------[discrete]=== Proxy settingsTo install a plugin via a proxy, you can add the proxy details to the`CLI_JAVA_OPTS` environment variable with the Java settings `http.proxyHost`and `http.proxyPort` (or `https.proxyHost` and `https.proxyPort`):[source,shell]-----------------------------------sudo CLI_JAVA_OPTS="-Dhttp.proxyHost=host_name -Dhttp.proxyPort=port_number -Dhttps.proxyHost=host_name -Dhttps.proxyPort=https_port_number" bin/elasticsearch-plugin install analysis-icu-----------------------------------Or on Windows:[source,shell]------------------------------------set CLI_JAVA_OPTS="-Dhttp.proxyHost=host_name -Dhttp.proxyPort=port_number -Dhttps.proxyHost=host_name -Dhttps.proxyPort=https_port_number"bin\elasticsearch-plugin install analysis-icu------------------------------------=== Plugins directoryThe default location of the `plugins` directory depends on which package you install:* {ref}/targz.html#targz-layout[Directory layout of `.tar.gz` archives]* {ref}/zip-windows.html#windows-layout[Directory layout of Windows `.zip` archives]* {ref}/deb.html#deb-layout[Directory layout of Debian package]* {ref}/rpm.html#rpm-layout[Directory layout of RPM][[manage-plugins-using-configuration-file]]=== Manage plugins using a configuration file[IMPORTANT].Docker only=====================This feature is only available for https://www.docker.elastic.co/[official {es}Docker images]. Other {es} distributions will not start with aplugin configuration file.=====================If you run {es} using Docker, you can manage plugins using a declarative configuration file.When {es} starts up, it will compare the plugins in the file with thosethat are currently installed, and add or remove plugins as required. {es}will also upgrade official plugins when you upgrade {es} itself.The file is called `elasticsearch-plugins.yml`, and must be placed in theElasticsearch configuration directory, alongside `elasticsearch.yml`. Hereis an example:[source,yaml]----plugins:  - id: analysis-icu  - id: repository-azure  - id: custom-mapper    location: https://example.com/archive/custom-mapper-1.0.0.zip----This example installs the official `analysis-icu` and`repository-azure` plugins, and one unofficial plugin. Every plugin must providean `id`. Unofficial plugins must also provide a `location`. This istypically a URL, but Maven coordinates are also supported. The downloadedplugin's name must match the ID in the configuration file.While {es} will respect thehttps://docs.oracle.com/javase/8/docs/technotes/guides/net/proxies.html[standardJava proxy system properties] when downloading plugins, you can also configure anHTTP proxy to use explicitly in the configuration file. For example:[source,yaml]----plugins:  - id: custom-mapper    location: https://example.com/archive/custom-mapper-1.0.0.zipproxy: proxy.example.com:8443----
 |