These steps describe how to install SEEK directly on the machine (bare-metal).
For how to install and run using Docker, which in many cases is simpler and quicker, please read the Docker Compose guide.
If you have installed SEEK, please take a moment to fill out our very short,optional SEEK Registration Form
If you have any problems or questions, you should contact us. The following link will give you details on how to Contact Us
SEEK is based upon the Ruby on Rails platform. Although the information on this page should provide you with everything you need to get a basic installation of SEEK up and running, some background reading on Ruby on Rails would be beneficial if it is new to you. Documentation and resources describing Ruby on Rails can be found at http://rubyonrails.org/documentation .
SEEK is built upon the 5.2 version of Rails, and requires Ruby 2.4.
We recommend that you run SEEK on a Linux system. This guide is based on an Ubuntu (18.04 LTS) system. However, running on other Linux distributions the main difference is the name of the required packages that have to be installed for that distribution, other than that the steps will be the same. If you want to install on different distribution or version please visit Other Distributions and see if it is listed there.
You will need to have sudo access on the machine you are installing SEEK, or be able to login as root. You will also need an active internet connection throughout the installation process.
Although possible, installing and running Ruby on Rails on a Windows system is troublesome and is not covered here.
These are the packages required to run SEEK with Ubuntu 18.04 (Desktop or Server). For other distributions or versions please visit our Other Distributions notes.
You should run an update first
sudo apt update sudo apt upgrade
Now install the packages:
sudo apt install mysql-server
Pay attention to what you use for the ‘MySQL root’ password when requested - you will need this later.
The remaining packages are:
sudo apt install build-essential git imagemagick libcurl4-gnutls-dev libgmp-dev \ libmagick++-dev libmysqlclient-dev libpq-dev libreadline-dev libreoffice libssl-dev \ libxml++2.6-dev libxslt1-dev nodejs openjdk-8-jdk openssh-server poppler-utils zip
Installing these packages now will make installing Ruby easier later on:
sudo apt install autoconf automake bison curl gawk libffi-dev libgdbm-dev \ libncurses5-dev libsqlite3-dev libyaml-dev sqlite3
SEEK’s Solr implementation currently requires Java 8, so you may need to switch the system’s default Java runtime:
sudo update-alternatives --config java
…and select the version named
/usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java or similar.
Development or Production?
The following steps are suitable for either setting up SEEK for development, or in a production environment. However, when setting up a production environment there are some minor differences - please visit Installing SEEK for Production
Now you are ready for installing SEEK. You can either install directly from Github, or by downloading the files. You can also run SEEK from Docker
Install directly from Github
If you wish to install directly from GitHub, the latest version of SEEK is tagged as (v1.11.1). To fetch this run:
git clone https://github.com/seek4science/seek.git cd seek/ git checkout v1.11.1
Download to install
Alternatively, you can download SEEK from https://github.com/seek4science/seek/archive/v1.11.1.tar.gz
wget -O seek-1.11.1.tar.gz https://github.com/seek4science/seek/archive/v1.11.1.tar.gz
then unpack the file with:
tar zxfv seek-1.11.1.tar.gz mv seek-1.11.1 seek cd seek/
Setting up Ruby and RubyGems with RVM
We strongly encourage that you use RVM for managing your Ruby and RubyGems version. Although you can use the version that comes with your linux distribution, it is more difficult to control the version you use and keep up to date.
To install RVM follow the steps at https://rvm.io/rvm/install . The current basic installation method is to run:
\curl -L https://get.rvm.io | bash
to save restarting your shell run:
if you already had RVM installed, bring it up to date with:
rvm get stable
now install the appropriate version of Ruby
rvm install $(cat .ruby-version)
you may be asked for your password so that some additional packages can be installed. You will then need to wait for Ruby to be downloaded and compiled.
First install bundler, which is used to manage gem versions
gem install bundler
Next install the ruby gems SEEK needs:
Setting up the Database
You first need to setup the database configuration file. You need to copy a default version of this and then edit it:
cp config/database.default.yml config/database.yml nano config/database.yml
IMPORTANT: you should at least change the default username and password. Change this for each environment (development,production,test).
Now you need to grant permissions for the user and password you just used (changing the example below appropriately). You will need the root password you created for mySQL when installing the package. e.g:
> mysql -uroot -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 1522 Server version: 5.5.32-0ubuntu0.12.04.1 (Ubuntu) Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> CREATE USER 'mysqluser'@'localhost' IDENTIFIED BY 'mysqlpassword'; mysql> GRANT ALL PRIVILEGES ON *.* TO 'mysqluser'@'localhost' WITH GRANT OPTION;
Now to create the database for SEEK and seed it with the default data, run:
bundle exec rake db:setup
You can now start SEEK for the first time, just to test things are working
bundle exec rails server
… and visit http://localhost:3000 and a SEEK page should load.
However, before continuing, stop SEEK with CTRL+C and start up some services.
Starting the SEEK services
This describes a quick way to start up the services SEEK needs. If setting up a production server, following these steps is fine to check things are working. However, you should also read the Installation for Production guide for automating these services.
Starting and Stopping the Search Service
For a new installation, by default search is disabled. Before running the service you may need to enable search in the Administration setting. The SEEK server needs restarting whenever search is enabled or disabled.
If search is enabled and the following service is not running, you will get errors when adding or updating information in SEEK.
SEEK search is based upon the Apache Lucene Solr service. To start this service run:
bundle exec rake sunspot:solr:start
and to stop run:
bundle exec rake sunspot:solr:stop
Optionally, there is also a configuration file for configuring the port and host that Solr runs on - which is important if running multiple SEEK installations on the same machine. If you wish to override the default ports then copy config/sunspot.default.yml to sunspot.yml and change the settings.
The following task can also be run at any time if there is need to force all content to be reindexed (such as after a period of running SEEK with search turned off).
bundle exec rake seek:reindex_all
Starting and Stopping the Background Service
SEEK uses Delayed Job to process various asynchronous jobs. It is important this service is running.
To start delayed job run:
bundle exec rake seek:workers:start
and to stop run:
bundle exec rake seek:workers:stop
you can also restart with
bundle exec rake seek:workers:restart
Starting and Stopping the SOFFICE service
SEEK uses the soffice service provided by LibreOffice to convert various document formats to PDF and Text - to allow them to be viewed in a web browser, and to make them indexable to the search. To start soffice run:
soffice --headless --accept="socket,host=127.0.0.1,port=8100;urp;" --nofirststartwizard > /dev/null 2>&1 &
and to stop it run:
killall -15 soffice
You can now start up SEEK again running:
bundle exec rails server
Creating an Administrator
When you first visit SEEK at http://localhost:3000 with no users present, you will be prompted to create a new user. This user will be the administrator of SEEK (you can change to or add other users in the future). Create a username and password, and then fill out your profile, and you will be ready to use SEEK.
You will be prompted to fill out our very short Registration form. Please do if you haven’t done so already, as this greatly assists the future support and funding of SEEK.
If you are setting up SEEK for production use, please now return to our Installing SEEK for Production Guide.
You should also now read our Administration Guide for details of some basic tasks and settings.