-
Notifications
You must be signed in to change notification settings - Fork 100
Setup guide
SciNote is developed in Ruby on Rails. It also makes use of Docker technology, so the easiest way to run it is inside Docker containers.
-
make
, - Docker,
- docker-compose.
The following are minimal steps needed to start SciNote in development environment:
- Clone this Git repository onto your development machine.
- Create a file
config/application.yml
. Populate it with mandatory environmental variables (see environmental variables). - In SciNote folder, run the following command:
make docker
. This can take a while, since Docker must first pull an image from the Internet, and then also install all neccesary Gems required by SciNote. - Once the Docker image is created, run
make run
command. This will install all the required Gems, and spin-off a (not-yet-working) server. - Once all Gems are installed, and server starts, stop it (
Ctrl + C
). Runmake cli
command. Once inside the running Docker container, run the following commands:rails db:drop
-rails db:create
-rails db:migrate
-rails db:seed
. This should initialize the database and fill it with (very minimal) seed data. - Exit the Docker container by typing
exit
. - To start the server, run command
make run
. Wait until the server starts listening on port3000
. - Inside another CLI window (also from SciNote folder), run command
make worker
. This command should start the background worker process which is used by SciNote for a lot of demanding tasks. - Open your favourite browser and navigate to http://localhost:3000. Use the seeded administrator account from seeds.rb (or account set up using environmental variables) to login, or sign up for a new account.
If you need to run server in production please check this section.
Debian
- Install Docker and add user
1000
to the docker group as described here. - Install Docker Compose as described here.
- Follow Quick Start Guide above as user
1000
.
Mac OS X
- Install command line developer tools (there are many resources online, like this).
- Install Docker Toolbox as described here.
- Inside CLI, run
git clone https://github.com/biosistemika/scinote-web.git
. - Run Docker Quickstart Terminal (also described here).
- Inside this terminal, navigate to cloned Git folder.
- Follow the Quick Start Guide above.
- When opening SciNote in browser, instead of navigating to
localhost:3000
, navigate to<docker-machine-ip>:3000
(you can get the docker machine IP by running commanddocker-machine ip default
).
Windows XP, Vista, 7, 8
There is currently no good way to deploy SciNote onto older Windows operating systems. You can run SciNote inside Docker Machine - the trouble is that Docker Machine is basically a lightweight Linux VirtualBox VM inside which Docker runs, and is very slow (due to nested virtualization), as well as having problems with file system mounting.
Windows 10
On Windows 10, you can use Docker for Windows - this will install Docker inside a Hyper-V container, which is much faster than Docker Machine. We still suggest to ramp-up the VM's memory to at least 4GB though (right click Docker icon in Windows taskbar -> Settings...
-> Advanced
).
- Install latest version of Docker for Windows.
- Check version of docker-compose by running
docker-compose -v
from command prompt. It needs to be at least version1.9.0
for SciNote docker-compose scripts to work. If you have an older version of docker-compose, download newer version for Windows from releases repository, and overwrite the.exe
file of current docker-compose (it should be located in<docker-install-dir>/Docker/resources/bin
directory). - Follow the Quick Start Guide above.
Important! As of right now, SciNote does not provide any Windows
make
script (Linuxmake
command will not work on Windows), therefore you need to call docker-compose commands directly. See Makefile to inspect which docker-compose callsmake
commands execute.
For version 1.10.0 and later
When starting SciNote application in development mode it runs in a Docker container called scinote_web_development
, which uses volume scinote_development_files
for storing uploaded files and scinote_development_bundler
for storing program dependencies. The database runs in a separate container, called scinote_db_development
. This database container makes use of a persistent volume called scinote_development_postgres
for storing database files.
For versions prior to 1.10.0 The main SciNote application runs in a Docker container called web. The database runs in a separate container, called db. This database container makes use of a special, persistent container called dbdata.
For running application in production please check this section
Call make
commands to build Docker images and build Rails environment, including database.
Following commands are available:
Command | Description |
---|---|
make docker |
Downloads the Docker image and build Gems. This should be called whenever Gemfile is changed. |
make db-cli |
Runs a /bin/bash inside the db container. |
make run |
Runs the db container & starts the Rails server in web container. |
make start |
Runs the db container & starts the Rails server in web container in background. |
make stop |
Stops the db & web containers. |
make worker |
Runs the rails jobs:work (worker process) in web container. |
make cli |
Runs a /bin/bash inside the web container. |
make tests |
Execute all Rails tests. |
make console |
Enters the Rails console in web container. |
make export |
Zips the head of this Git repository into a .tar.gz file. |
SciNote reads configuration parameters from system environment parameters. On production servers, this can simply be system environmental variables, while for development, a file config/application.yml
can be created to specify those variables.
Below is an example application.yml
file, which should get the server running; for full reference, check the dedicated page (below) to see all available variables.
# Secrets
SECRET_KEY_BASE: "<<secret_key_base>>"
PAPERCLIP_HASH_SECRET: "<<paperclip_hash_secret>>"
# File storage
# For local file storage
PAPERCLIP_STORAGE: "filesystem"
# For S3 file storage
#PAPERCLIP_STORAGE: "s3"
#AWS_ACCESS_KEY_ID: ""
#AWS_REGION: ""
#AWS_SECRET_ACCESS_KEY: ""
#S3_BUCKET: ""
#S3_HOST_NAME: ""
# Mailer settings
MAIL_FROM: "Example SciNote Assistant <[email protected]>"
MAIL_REPLYTO: "Example SciNote Assistant <[email protected]>"
SMTP_ADDRESS: "your.yoursmtp.com"
SMTP_PORT: "25"
SMTP_DOMAIN: "yoursmtp.com"
SMTP_USERNAME: "[email protected]"
SMTP_PASSWORD: "<<smtp_password>>"
SMTP_AUTH_METHOD: "plain"
MAIL_SERVER_URL: "scinote.yourdomain.com"
# Sign-up process
NEW_TEAM_ON_SIGNUP: "true"
ENABLE_EMAIL_CONFIRMATIONS: "false"
ENABLE_USER_REGISTRATION: "true"
For complete list of variables, see Environmental variables page.
New functionality for running in production mode was introduced with SciNote version 1.10.0. In order to run SciNote application in production inside Docker you'll need the following:
- docker engine (version 1.12.0+),
- docker-compose (version 1.6.0+).
You'll also need to set environment variables in production.env
file; variables are the same as described in Environmental variables section, the only differences are:
- format of records is changed - use
KEY=VALUE
record format; - you should set
DATABASE_URL=postgresql://postgres@db/scinote_production
without quotation marks.
The mentioned variable is used to configure database connection and by default it contains credentials to connect to the PostgreSQL database inside db
container; you will need to change this variable if you decide to use another DB or set password for default db user.
You can generate default (minimal) production.env
file with the following command: make config-production
. This command will also generate SECRET_KEY_BASE
and PAPERCLIP_HASH_SECRET
variables automatically.
After setting all the required variables you need to build the Docker image with make docker-production
; this command will install all needed Gems and precompile assets.
When the above build is finished, database needs to be initialized (if you're performing a new install). This can be done by running make database-production
. This will initialize the database and start a running process; the database will be hosted in the scinote_db_production
container. This container is configured to keep all database files in the persistent Docker volume named scinote_production_postgres
, which is (by default) placed in /var/lib/docker/volumes
of the host system.
There is also another persistent Docker volume called scinote_production_files
; this container is used for storing generated and uploaded files if you configure local file storage.
All these volumes will be kept safe in case you delete your Docker containers. Running docker rm
with -v
flag, however, will also delete these volumes (same thing happens if you run docker-compose down
with -v
flag).
Background jobs worker will be running in another separate container called scinote_jobs_production
.
Now (finally), you can start SciNote with the following command: docker-compose -f ./docker-compose.production.yml up
. Or you can use docker-compose -f ./docker-compose.production.yml up -d
to start the server in background mode. Please consult docker-compose
documentation for the rest of supported commands.
In short, the sequence of commands to setup SciNote (for fresh install) would be:
make config-production
make docker-production
make database-production
docker-compose -f ./docker-compose.production.yml up
If you are using some old/custom setup, and want to switch to production mode which was introduced in version 1.10.0 (see above), you will need to perform the following steps before updating the application files.
1. Migrate database data
You will need to migrate database data from old database to the new one running in scinote_db_production
container. The easiest way to do this is to dump data from the old container and restore it into the new one. You can do this by using your preferred database client and login credentials from your config file. For example, you can do it inside the web container after entering shell with make cli
and pg_dump
or with any GUI tool (like pgAdmin). You can find the IP address of the local database container by running docker inspect
and inspecting the output (in most cases, name of the database container will be similar to e.g. web_db_1
).
Important! You should extract the old database dump before updating the source code tree of the application.
2. Migrate files
If you are using local file storage, you will also need to move user's files from ./public/system
directory in application directory to the Docker volume scinote_production_files
.
3. Migrate ENV variables
Don't forget to migrate ENV variables from config/application.yml
into production.env
. See previous section on rules for production.env
.
4. Update source files
After all of the above steps are done, you can finally update application files and run DB migrations as described here.
After downloading the new version of SciNote application files, the following needs to be done to upgrade a running SciNote instance running in production Docker mode.
1. Rebuild Docker images
First of all, you will need to rebuild Docker images using the new version of SciNote. That means that you need to stop the current instance (if it is running), and then run the command make docker-production
.
2. Migrate database data
Open command prompt inside the web container with make cli-production
and, once inside it, run migrations with the following command: rails db:migrate
. On rare occasions, you will also need to run additional migration scripts, please check Release Notes for that.
3. Restart
After migrations are finished, you can start the application normally with the command docker-compose -f ./docker-compose.production.yml up
.
SciNote uses delayed jobs library to do background processing, mostly for the following tasks:
- Sending emails,
- Extracting text from uploaded files (full-text search),
- Generating introduction tutorials,
- Copying/cloning large database objects,
- etc.
Best option to run delayed jobs is inside a worker process. To start a background worker process that will execute delayed jobs, run the following command:
rails jobs:work
To clear all currently queued jobs, you can use the following command:
rails jobs:clear
Warning! This is not advised to do on production environments.
To simplify adding of new users to the system, couple of special rails
tasks have been created.
The first, rails db:add_user
simply queries all the information for a specific user via STDIN, and then proceeds to create the user.
The second task, rails db:load_users[file_path,create_orgs]
takes 2 parameters as an input:
- Path to
.yml
file containing list of users & teams to be added. The YAML file needs to be structured properly - field names must match those in the database, users need to have a nameuser_<id>
, and teams nameteam_<id>
. For an example load users file, see db/load_users_template.yml file. - A boolean ('true' or 'false') whether to create individual teams for each user or not.
To check current login statistics of registered users, use rails web_stats:login
task. To check the last login of any user to the system, use rails web_stats:last_login
task.
Execute rails data:clean_temp_files
to remove all temporary files. Temporary files are used when importing samples.
Execute rails data:clean_unconfirmed_users
to remove all users that registered, but never confirmed their email.
Calling rails data:clean
will execute both above tasks.
To generate a new system notification that will be sent to all SciNote users, execute rails notifications:new_system[title, message]
. Title & message can contain HTML
tags.
SciNote needs a configured SMTP mail server to work properly. See environmental variables for configuration of the mailer.
SciNote can be integrated with an Office Online Server to enable viewing and edition of documents directly in the browser. To enable this integration using the Microsoft Office Online servers, you will need to join the Office Cloud Storage Partner Program and set up the WOPI_*
environment variables.
Before deploying to Heroku, install heroku client as describe on offical website. To use existing heroku application, add new git remote repository.
git remote add heroku [email protected]:my-random-app-name.git
Or create new heroku application by executing following command.
heroku create
Add additional heroku buildpacks in the same order as specified in .buildpacks:
heroku buildpacks:add --index <i> <buildpack>
e.g. for adding graphviz write:
heroku buildpacks:add --index 2 https://github.com/weibeld/heroku-buildpack-graphviz.git
Before pushing to heroku master branch, some environmental variables should be set.
For deployment of SciNote onto Heroku, additional environmental variables need to be specified.
Variable | Mandatory | Description |
---|---|---|
LANG | Yes | The default localization language (e.g. en_US.UTF-8 ). |
RAILS_ENV | Yes | Rails environment: production , test or development . |
RACK_ENV | Yes | Rack environment: production , test or development . |
RAILS_SERVE_STATIC_FILES | Yes | Whether to serve static files. Must be set to enabled . |
WEB_CONCURRENCY | Yes | The concurrency of the server. See Heroku specifications for details. |
MAX_THREADS | Yes | The max. number of threads. See Heroku specifications for details. |
PORT | Yes | The port on which the application should run. See Heroku specifications for details. |
RAILS_FORCE_SSL | Yes | If set to 1 , enforce SSL communication on all levels of application. |
DATABASE_URL | Yes | Full URL for connecting to PostgreSQL database. |
In current version, only model tests are implemented for SciNote. To execute them, call rails test:models
.