Skip to content

Latest commit

 

History

History
214 lines (154 loc) · 5.39 KB

README.md

File metadata and controls

214 lines (154 loc) · 5.39 KB

Ubuntu Deployment Scripts for mrnaid.dichlab.org

This repository contains the deployment configuration for the public http://mrnaid.dichlab.org/ server.

Adapted from https://github.com/lich-uct/biophi.dichlab.org

First time setup on Ubuntu

Here's how to set up the deployment. You'll need root acces for this (us su root or sudo bash to run as root).

Summary of the following steps:

  • Set up directory and mrnaid user
  • Install Conda
  • Install and set up redis database
  • Set up uwsgi & celery worker services
  • Set up Nginx server and SSL

Some steps might be skipped here. If you get stuck, Google is your friend 😊

Create deployment directory

This directory will host all the settings.

# Create deployment directory (you need root access for this and everything that follows)
mkdir /opt/mrnaid-deployment
cd /opt/mrnaid-deployment
# Clone this repo (or your own fork) into current directory
git clone [email protected]:lich-uct/mrnaid.dichlab.org.git .

Add mrnaid user

useradd mrnaid
addgroup mrnaid staff
addgroup mrnaid www-data
mkdir /home/mrnaid /home/mrnaid/run
chown mrnaid:mrnaid /home/mrnaid /home/mrnaid/run

Create Conda environment

Install Conda or one of the alternatives (Miniconda, Miniforge, Mamba).

# Create the mRNAid conda environment
conda env create -n mRNAid -f /opt/mrnaid-code/backend/flask_app/environment.yml
conda activate mRNAid

Install redis

apt-get install redis-server

This will automatically start it as a service in the background

# Try calling redis
redis-cli PING
# You should get PONG

Clone mRNAid repository

# create directory for code
mkdir /opt/mrnaid-code
cd /opt/mrnaid-code
# clone repository
git clone [email protected]:Merck/mRNAid.git .

Set up uWSGI service

Check the local uWSGI web server config and adjust as needed:

Suggestion: change line 15 in /opt/mrnaid-code/backend/flask_app/app.ini to socket = :8080.

Register the config as a systemd service:

ln -s /opt/mrnaid-deployment/uwsgi/mrnaid-uwsgi.service /etc/systemd/system/mrnaid-uwsgi.service
# Start uWSGI
systemctl start mrnaid-uwsgi
# Register uwsgi at startup (important!)
systemctl enable mrnaid-uwsgi
# Check the status of uwsgi
systemctl status mrnaid-uwsgi

See flask uwsgi log using: journalctl -u mrnaid-uwsgi.service -e

Set up celery service

Check the local celery worker config and adjust as needed:

Register the config as a systemd service:

ln -s /opt/mrnaid-deployment/celery/mrnaid-celery.service /etc/systemd/system/mrnaid-celery.service
# Start celery
systemctl start mrnaid-celery
# Register celery at startup (important!)
systemctl enable mrnaid-celery
# Check the status of celery
systemctl status mrnaid-celery

See celery task log using: journalctl -u mrnaid-celery.service -e

Set up nginx

Nginx will listen to HTTP & HTTPS traffic and serve the uwsgi responses as a proxy server.

Based on: https://www.nginx.com/blog/using-free-ssltls-certificates-from-lets-encrypt-with-nginx/

Remove default config files:

# location may vary based on your system and installation
rm /etc/nginx/conf.d/default.conf

edit config file /opt/mrnaid-code/frontend/config/nginx.conf to contain:

server{
    listen 80;
    
    root /usr/share/nginx/html/;
    index /index.html;
    try_files $uri /index.html$is_args$args =404;
    server_name mrnaid.dichlab.org;
    
    location /api/v1 {
        include uwsgi_params;
        uwsgi_pass 127.0.0.1:8080;
        uwsgi_read_timeout 300;
    }
}

and replace old config files with custom ones:

# target location may vary based on your system and installation
cp ./config/nginx.conf /etc/nginx/conf.d/

Copy the build files:

cp -R /opt/mrnaid-code/frontend/build/* /usr/share/nginx/html

(See mRNAid readme)

Enable the config:

ln -s /etc/nginx/sites-available/mrnaid.dichlab.org /etc/nginx/sites-enabled/mrnaid.dichlab.org
# Restart nginx
systemctl restart nginx
# Check status
systemctl status nginx

Set up HTTPS access

Generate SSL certificate using certbot (see installation guide for Ubuntu 20 or other platforms)

# Generate and install certificate
certbot --nginx -d mrnaid.dichlab.org

Your nginx config file /etc/nginx/sites-available/mrnaid.dichlab.org should now be updated with the SSL config.

# Restart nginx
systemctl restart nginx
# Check status
systemctl status nginx

Done!

You should be all good to go.

Deploying a new release

To deploy a new release, simply run the ./deploy.sh script.