Installing SEEK

Introduction

These steps describe how to install SEEK directly on the machine (bare-metal).

Docker is also supported, 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 https://rubyonrails.org/documentation .

SEEK is built upon Rails, and requires Ruby 3.1.

We recommend that you run SEEK on a Linux system. This guide is based on an Ubuntu (20.04 LTS) system, but is also happily being run on Ubuntu 22.04 (24.04 is yet to be tested). When 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.

Installing packages

These are the packages required to run SEEK with Ubuntu 20.04 (Desktop or Server). For other distributions or versions please visit our Other Distributions notes.

First add a repo which contains python versions that may not be available in the default repositories

sudo apt install software-properties-common
sudo add-apt-repository ppa:deadsnakes/ppa

Then ensure everything is up-to-date

sudo apt update
sudo apt upgrade

Now install the packages:

sudo apt install build-essential cmake git graphviz imagemagick libcurl4-gnutls-dev libgmp-dev \
    libmagick++-dev libmysqlclient-dev libpq-dev libreadline-dev libreoffice libssl-dev \
    libxml++2.6-dev libxslt1-dev mysql-server nodejs openjdk-11-jdk openssh-server poppler-utils zip \
    python3.9-dev python3.9-distutils python3-pip

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 11, 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-11-openjdk-amd64/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

Getting SEEK

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.15.2. To fetch this run:

git clone https://github.com/seek4science/seek.git
cd seek/
git checkout v1.15.2

Download to install

Alternatively, you can download SEEK from https://github.com/seek4science/seek/archive/v1.15.2.tar.gz

wget -O seek-1.15.2.tar.gz https://github.com/seek4science/seek/archive/v1.15.2.tar.gz

then unpack the file with:

tar zxfv seek-1.15.2.tar.gz
mv seek-1.15.2 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 on Ubuntu there is package available described at https://github.com/rvm/ubuntu_rvm, the steps being

sudo apt-add-repository -y ppa:rael-gc/rvm
sudo apt-get update
sudo apt-get install rvm
sudo usermod -a -G rvm $USER

… the guide recommends rebooting here, but logging in and out again usually works.

Other ways to install RVM can be found at https://rvm.io/rvm/install .

now install the appropriate version of Ruby

rvm install $(cat .ruby-version)

Installing Gems

First install bundler, which is used to manage gem versions

gem install bundler

Next install the ruby gems SEEK needs ( for production see Bundler Configuration )

bundle install

Install Python dependencies

First, a specific version of setuptools needs to be installed to avoid an issue when installing dependencies

python3.9 -m pip install setuptools==58

Then the other dependencies can be installed

python3.9 -m pip install -r requirements.txt

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).

> sudo mysql
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.

Setting up and starting the Search Service

SEEK uses the Apache Solr Search Engine which since SEEK v1.12 needs setting up separately. It is relatively straightforward and there are instructions on how to do this in Setting Up Solr.

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 SEEK

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.

Final steps

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.