How To: Elasticsearch
Use Elasticsearch instead of an RDBMS
The API Manager is configured (by default) to use JPA as the persistence technology for storing all of its data. But this isn’t the only persistence technology supported. Another option is to use Elasticsearch. This section details how to set up apiman to use Elasticsearch instead of an RDBMS to store your API Manager data.
Overview
- 
Download and install Elasticsearch 
- 
Make changes to apiman.propertiesto switch from JPA to Elasticsearch
- 
(Re)start apiman! 
- 
Perform standard admin configuration of apiman (the database will of course be empty!) 
Download and install Elasticsearch
This part is pretty easy - download the Elasticsearch software and get it running. A very good resource for this can be found here:
| As of apiman 1.1.4.Final, an instance of Elasticsearch is included in the default apiman distribution. You may use it as your API Manager persistence store. It is running on port 19200. | 
Make changes to apiman.properties
Once Elasticsearch is running smoothly, you must make some changes to the apiman.properties file in order to tell apiman to use ES instead of a database.
You should modify the apiman.properties file to have the following properties set:
| You can optionally also set the username and password - this is only useful if you are using something like Elasticsearch Shield to enable basic authentication. | 
apiman.es.protocol=http
apiman.es.host=localhost
apiman.es.port=19200
apiman.es.username=
apiman.es.password=
apiman-manager.storage.type=es
apiman-manager.storage.es.protocol=${apiman.es.protocol}
apiman-manager.storage.es.host=${apiman.es.host}
apiman-manager.storage.es.port=${apiman.es.port}
apiman-manager.storage.es.username=${apiman.es.username}
apiman-manager.storage.es.password=${apiman.es.password}
apiman-manager.storage.es.initialize=trueMake sure you enter appropriate values for the apiman.es.protocol, apiman.es.host, and apiman.es.port properties.
These values should reflect the settings of your Elasticsearch instance.
| If you are using a standalone gateway instance you will need to configure it separately to point to the same datastore. For example, conf.jsonfor Vert.x andstandalone.xmlfor Servlet. | 
(Re)start apiman
If apiman was running, you should stop it now.
Once everything is shutdown, and the changes to apiman.properties have been made, go ahead and start apiman up again.
It will pick up the new settings in apiman.properties and attempt to use Elasticsearch instead of the database!
Note that the apiman quickstart overlay ZIP comes pre-configured with a number of settings, including:
- 
Installed policy definitions 
- 
Default configured roles (Organization Owner, API Developer, Application Developer) 
- 
A default configured Gateway 
This built-in configuration will be lost when you switch from JPA to Elasticsearch. You will need to use the apiman admin UI to reconfigure these settings. Refer to the "System Administration" section of the User Guide for more information on this.
Use standalone Elasticsearch instance/cluster
The apiman quickstart overlay ZIP ships by default with an embedded instance of Elasticsearch. This is suitable for getting up and running quickly, but is not a good long term solution. Instead, users are encouraged to install a standalone instance of Elasticsearch and point apiman to it.
High Level Overview
- 
Download and install Elasticsearch 
- 
Make changes to "apiman.properties" to point to your standalone Elasticsearch instance 
- 
(Re)start apiman! 
Download and install Elasticsearch
This part is pretty easy - download the Elasticsearch software and get it running. A very good resource for this can be found here:
Make changes to "apiman.properties"
Once Elasticsearch is running smoothly, you must make some minor changes to the apiman.properties file in order to tell apiman where your Elasticsearch instance is located.
There are a set of global properties used for all apiman components that use Elasticsearch to load data. These properties are:
apiman.es.protocol=http
apiman.es.host=localhost
apiman.es.port=19200
apiman.es.username=
apiman.es.password=Make sure you enter appropriate values for this properties - they should reflect the settings of your Elasticsearch installation.