2018-05-25 16:14:56 +01:00
|
|
|
# Setup
|
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
The FulltextSearch module includes support for connecting to Solr.
|
2018-05-25 16:14:56 +01:00
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
It works with Solr in multi-core mode. It needs to be able to update Solr configuration files, and has modes for doing
|
|
|
|
so by direct file access (when Solr shares a server with SilverStripe) and by WebDAV (when it's on a different server).
|
2018-05-25 16:14:56 +01:00
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
See the helpful [Solr Tutorial](http://lucene.apache.org/solr/4_5_1/tutorial.html), for more on cores and querying.
|
2018-05-25 16:14:56 +01:00
|
|
|
|
|
|
|
## Requirements
|
|
|
|
|
|
|
|
Since Solr is Java based, it requires Java 1.5 or greater installed.
|
|
|
|
|
|
|
|
When you're installing it yourself, it also requires a servlet container such as Tomcat, Jetty, or Resin. For
|
2018-06-04 16:55:47 +01:00
|
|
|
development testing there is a standalone version that comes bundled with Jetty (see [Installing Solr](#installing-solr)
|
|
|
|
below).
|
2018-05-25 16:14:56 +01:00
|
|
|
|
|
|
|
See the official [Solr installation docs](http://wiki.apache.org/solr/SolrInstall) for more information.
|
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
Note that these requirements are for the Solr server environment, which doesn't have to be the same physical machine as
|
|
|
|
the SilverStripe webhost.
|
2018-05-25 16:14:56 +01:00
|
|
|
|
|
|
|
## Installing Solr
|
|
|
|
|
|
|
|
### Local installation
|
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
If you'll be running Solr on the same machine as your SilverStripe installation, and the
|
|
|
|
[quick start script](01_getting_started.md#quick-start) doesn't suit your needs, you can use the
|
|
|
|
[fulltextsearch-localsolr module](https://github.com/silverstripe-archive/silverstripe-fulltextsearch-localsolr). This
|
|
|
|
can also be useful as a development dependency. You can bring it in via composer (use `require-dev` if you plan to
|
|
|
|
install Solr remotely in Production):
|
2018-05-25 16:14:56 +01:00
|
|
|
|
|
|
|
```bash
|
|
|
|
composer require silverstripe/fulltextsearch-localsolr
|
|
|
|
```
|
|
|
|
|
|
|
|
Once installed, start the server via CLI:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
cd fulltextsearch-localsolr/server
|
|
|
|
java -jar start.jar
|
|
|
|
```
|
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
Then configure the module to use `file` mode with the following configuration in your `app/_config.php`, making sure
|
|
|
|
that the `path` directory is writeable by the user that started the server (above):
|
2018-05-25 16:14:56 +01:00
|
|
|
|
|
|
|
```php
|
|
|
|
use SilverStripe\FullTextSearch\Solr\Solr;
|
|
|
|
|
|
|
|
Solr::configure_server([
|
|
|
|
'host' => 'localhost',
|
|
|
|
'indexstore' => [
|
|
|
|
'mode' => 'file',
|
|
|
|
'path' => BASE_PATH . '/.solr'
|
|
|
|
]
|
|
|
|
]);
|
|
|
|
```
|
|
|
|
|
|
|
|
### Remote installation
|
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
Alternatively, it can be beneficial to keep the Solr service contained on its own infrastructure, for performance and
|
|
|
|
security reasons. The [Common Web Platform (CWP)](www.cwp.govt.nz) uses Solr in this manner. To do so, you should
|
|
|
|
install the dependencies on the remote server, and then configure the module to use the `webdav` mode like so:
|
2018-05-25 16:14:56 +01:00
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
```php
|
|
|
|
use SilverStripe\FullTextSearch\Solr\Solr;
|
2018-05-25 16:14:56 +01:00
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
Solr::configure_server([
|
|
|
|
'host' => 'remotesolrserver.com', // IP address or hostname
|
|
|
|
'indexstore' => [
|
|
|
|
'mode' => 'webdav',
|
|
|
|
'path' => BASE_PATH . '/webdav',
|
|
|
|
]
|
|
|
|
]);
|
|
|
|
```
|
2018-05-25 16:14:56 +01:00
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
Check all the available [configuration options](03_configuration.md#solr-server-parameters) to fine-tune the module to
|
|
|
|
work with your desired setup.
|
2018-05-25 16:14:56 +01:00
|
|
|
|
2018-06-04 16:55:47 +01:00
|
|
|
This will mean that all configuration files, and the indexes themselves, are stored remotely.
|
2018-05-25 16:14:56 +01:00
|
|
|
|
|
|
|
## Solr admin
|
2018-06-04 16:55:47 +01:00
|
|
|
|
|
|
|
Solr provides an administration interface with a GUI to allow you to get at the finer details of your cores and
|
|
|
|
configuration. You can access it at example.com:<SOLR_PORT>/<SOLR_PATH>/#/ on a local installation
|
|
|
|
(usually example.com:8983/solr/#/).
|
|
|
|
|
|
|
|
There you can access logging, run raw queries against your stored indexes, and get some basic performance metrics.
|
|
|
|
Additionally, you can perform more drastic changes, such as dropping and reloading cores.
|
|
|
|
|
|
|
|
For a comprehensive look at the Solr admin interface, read the
|
|
|
|
[user guide for Solr 4.10](http://archive.apache.org/dist/lucene/solr/ref-guide/apache-solr-ref-guide-4.10.pdf#page=17)
|