/search-solr

VM configuration and acceptance testing for a Solr-based search backend.

Primary LanguagePuppet

nsidc-search-solr

This vagrant project stands up a Solr instance for NSIDC Search.

See the CHANGELOG.md for information on past versions.

Requirements and Setup at NSIDC

Requirements

For use at NSIDC, this project requires the vagrant-nsidc-plugin.

Dependencies are defined in the CI configuration and should be available upon machine provision.

Although the search-solr-tools gem can be installed via Bundler, there is also a separate Jenkins job to deploy the gem to a VM. See the entries matching the strings deploy_solr_tools_command and Deploy_solr-search-tools-gem in puppet/ci.yaml.

Setup

The virtual machine will be provisioned using the puppet-nsidc-solr module. NSIDC Search configurations will be applied once Solr is installed.

To provision the machine:

vagrant nsidc up --env=dev

Once provisioning is complete, the Solr dashboard is accessible from http://<environment>.search-solr.apps.int.nsidc.org:8983/solr, where <environment> is one of integration, qa, or staging.

In the developer environment, the Solr dashboard is at http://dev.search-solr.USERNAME.dev.int.nsidc.org:8983/solr.

VM Memory Configuration

Solr appears to persistently run close to the limit of our standard 2GB VM memory allocation. If this becomes an issue, the VM memory allocation can be bumped to 4GB (for example). Commit #f48b172 shows an example of the Vagrantfile modifications needed to increase the memory allocation.

Requirements and Setup for Non-NSIDC users

Requirements

When using the project outside of the NSIDC environment, the configuration that would normally be managed by Puppet will not be applied, and Solr will not be installed. You will have to manually set up an environment with an installed instance of Solr and its dependencies (puppet-nsidc-solr currently installs Solr version 9.3.0.).

Solr provides a deployment script to install the application:

/bin/tar -zxf solr-${solr_version}.tgz solr-${solr_version}/bin/install_solr_service.sh --strip-components=2
./install_solr_service.sh solr-${solr_version}.tgz

See the DEVELOPMENT.md. file for additional instructions and development notes.