Skip to content

Latest commit

 

History

History
541 lines (210 loc) · 12.3 KB

README.md

File metadata and controls

541 lines (210 loc) · 12.3 KB

VRE-Quickstart

A manual to deploy quickly a VRE

IMPORTANT!!! THIS MANUAL IS A QUICKSTART AND HAS BEEN CREATED USING ALL ISTRUCTIONS AVAILABLE ON THE WEB (I DIDN'T REINVENT THE WHEEL).

YOU CAN FIND MORE DETAILED INSTRUCTIONS (eg. HOW TO SET SSL, CONFIGURATIONS, BUGS, etc.) ON PROJECT'S WEBSITE:

Collaborative Virtual Enviroment

Quick start guide

Virtual research environment (from Wikipedia):

A virtual research environment (VRE) or virtual laboratory is an online system helping researchers collaborate. Features usually include collaboration support (Web forums and wikis), document hosting, and some discipline-specific tools, such as data analysis, visualisation, or simulation management. In some instances, publication management, and teaching tools such as presentations and slides may be included. VREs have become important in fields where research is primarily carried out in teams which span institutions and even countries: the ability to easily share information and research results is valuable.

Note:

We'll use Ubuntu server 22.x

LINUX:

First of all: login as root on linux server and create all users we'll need (each user will access in a separated enviroment on jupyterhub and RStudio)

  • adduser guest1

(Not necessary: adduser guest1 sudo)

  • adduser guest2

(Not necessary: adduser guest2 sudo)

  • adduser guest3

(Not necessary: adduser guest3 sudo)

JUPYTER HUB quick install:

  • apt update

  • apt install python3-pip

  • apt install nodejs npm

  • python3 -m pip install jupyterhub

  • npm install -g configurable-http-proxy

  • python3 -m pip install jupyterlab notebook

  • jupyterhub -h

  • configurable-http-proxy -h

  • nohup jupyterhub &

JULIA Kernel Repeat JULIASHELL for each account

JULIASHELL> using Pkg

JULIASHELL> Pkg.add("IJulia")

JULIASHELL> using IJulia

JULIASHELL> installkernel("Julia")

R kernel

Install

Add kernel to Jupyter

  • R

R SHELL> install.packages('IRkernel')

R SHELL> IRkernel::installspec(user = FALSE)

OCTAVE Kernel Install

  • add-apt-repository ppa:octave/stable

  • apt-get install -y --no-install-recommends octave gnuplot ghostscript

  • pip3 install octave_kernel

  • apt-get install -y --no-install-recommends octave gnuplot ghostscript qt

  • apt-get install -y --no-install-recommends octave gnuplot ghostscript qt5

  • apt-get install -y --no-install-recommends octave octave-symbolic octave-miscellaneous python-sympy gnuplot ghostscript

  • apt-get install -y --no-install-recommends octave octave-miscellaneous gnuplot ghostscript

  • apt install fonts-freefont-otf

MATLAB Kernel

  • pip install matlab_kernel

LUA Kernel

  • pip install ilua

MicroPython Kernel

  • pip install jupyter_micropython_kernel

  • python -m jupyter_micropython_kernel.install

Install voila

Voilà turns Jupyter notebooks into standalone web applications.

Starting with JupyterLab 3.0, the extension is automatically installed after installing voila with

  • pip install voila

Security TIP: Disable Jupyter Terminal!

  • pip3 uninstall -y terminado

Let's go with the browser for JupyterHub:

http://myserver.com:8000/

Install RStudio Server

Add R-base repository

Run update

  • sudo apt update

Install Gdebi

To easily install Rstudio Desktop or Server, we will use the Gdebi Package manager that will automatically fetch and install the required dependencies needed by the tool.

  • sudo apt-get install gdebi-core

Install OLD dependencies (broken in Ububtu 22.x) necessaries for RStudio

Download RStudio Server package

Let's go!

http://mywebserver.org:8787/

Install PostgreSQL database and GITEA repository

  • apt update

  • apt install postgresql postgresql-contrib

  • systemctl start postgresql.service

  • cd /etc/postgresql/14/main/

  • nano postgresql.conf

For remote database setup, confi gure PostgreSQL on database instance to listen to your IP address by editin

listen_addresses on postgresql.conf to:

listen_addresses='localhost, 203.0.113.3'

PostgreSQL uses md5 challenge-response encryption scheme for password authentication by default. Nowascheme is not considered secure anymore. Use SCRAM-SHA-256 scheme instead by editing the postgresql.configuration file on the database server to:

password_encryption=scram-sha-256

  • systemctl restart postgresql.service

#On the database server, login to the database console as superuser:

  • su -c psql - postgres

#Create database user (role in PostgreSQL terms) with login privilege and password.

POSTGRESQL - CREATE ROLE gitea WITH LOGIN PASSWORD 'myStrongPasswordForGitea';

#Create database with UTF-8 charset and owned by the database user created earlier.

POSTGRESQL - CREATE DATABASE giteadb WITH OWNER gitea TEMPLATE template0 ENCODING UTF8 LC_COLLATE 'en_US.UTF-8' LC_CTYPE 'en_US.UTF-8';

  • cd /etc/postgresql/14/main/

  • nano pg_hba.conf

#Allow the database user to access the database created above by adding the following authentication rule to pg_hba.conf.

#For local database:

local giteadb gitea scram-sha-256

#For remote database:

host giteadb gitea 192.0.2.10/32 scram-sha-256

#Replace database name, user, and IP address of Gitea instance with your own.

  • systemctl restart postgresql.service

#On your Gitea server, test connection to the database.

#For local database:

  • psql -U gitea -d giteadb

#For remote database:

#Add repo signing key to apt

#Add repo to apt

#Install

  • apt-get update

  • apt-get install gitea morph027-keyring

#Start

  • systemctl enable --now gitea

Let's go with the browser for Gitea:

http://myserver.com:3000

Install and prepare Maria DB for Mediawiki:

  • apt update

  • apt upgrade

  • apt-get install apache2 mariadb-server php php-mysql libapache2-modphp php-xml php-mbstring

  • apt-get install imagemagick php-curl

  • mysql -u root -p

MYSQL - CREATE USER 'new_mysql_user'@'localhost' IDENTIFIED BY 'MySuperPassword';

Install Wikimedia

Download the MediaWiki software

mysql -u root -p

MYSQL - CREATE DATABASE my_wiki;

MYSQL - CREATE USER 'wikiuser'@'localhost' IDENTIFIED BY 'database_password';

MYSQL - GRANT ALL PRIVILEGES ON my_wiki.* TO 'wikiuser'@'localhost' WITH GRANT OPTION;

Only if your database is not running on the same server as your web server, you need to give the appropriate web server hostname (mediawiki.example.com in the example below):

MYSQL - GRANT ALL PRIVILEGES ON my_wiki.* TO 'wikiuser'@'mediawiki.example.com' IDENTIFIED BY 'database_password';

  1. Open a web browser and browse to the website address or path that you configured for MediaWiki in the web server software.

  2. You will see the version of MediaWiki which you extracted and a link to "Please set up the wiki first." Click on the link to begin the configuration script. For reference (in case you want to go there directly), this is located in MediaWiki's mw-config directory (so using the example above you would go to http://www.example.com/mw-config/, or on a local machine http://localhost/mw-config/).

  3. After selecting the language, the configuration script performs some environmental checks.

NOTE:

If need, you'll have to:

  • ln -s /var/lib/mediawiki /var/www/html/mediawiki

  • phpenmod mbstring

  • phpnmod xml

  • apt-get install php-intl

  • systemctl restart apache2.service

  1. Follow the instructions on the pages to connect to the database, create the MediaWiki administrator account, and to set further settings such as the logo or skin.

  2. The script will populate the database and write a configuration file.

  3. After the configuration script has finished, download the generated configuration file LocalSettings.php and place the file in the base directory of your MediaWiki installation.

LocalSettings.php contains all the information needed by MediaWiki to run.

Let's go with the browser for Mediawiki:

http://myserver.com/mediawiki/

NOTE: for Jupyter some PIP packages needs the root access by shell to install dependencies

eg.

  • apt-get install libgeos-dev

  • pip install Cartopy

PHPBB forum Install

wget https://download.phpbb.com/pub/release/3.3/3.3.10/phpBB-3.3.10.zip

Create the DB

mysql -u root -p

MYSQL - CREATE DATABASE myphpbb;

MYSQL - CREATE USER 'phpbbuser'@'localhost' IDENTIFIED BY 'superPasswordphpbb';

MYSQL - GRANT ALL PRIVILEGES ON myphpbb.* TO 'phpbbuser'@'localhost' WITH GRANT OPTION;

Decompress the phpBB archive to a local directory on your system.

Upload all the files contained in this archive (retaining the directory structure) to a web accessible directory on your server or hosting account.

Change the permissions on config.php to be writable by all (666 or -rw-rw-rw- within your FTP Client)

Change the permissions on the following directories to be writable by all (777 or -rwxrwxrwx within your FTP Client):

store/, cache/, files/ and images/avatars/upload/.

Point your web browser to the location where you uploaded the phpBB files with the addition of install/app.php or simply install/, e.g. http://www.example.com/phpBB3/install/app.php, http://www.example.com/forum/install/.

Click the INSTALL tab, follow the steps and fill out all the requested information.

Change the permissions on config.php to be writable only by yourself (644 or -rw-r--r-- within your FTP Client)

phpBB should now be available, please MAKE SURE you read at least Section 6 below for important, security related post-installation instructions, and also take note of Section 7 regarding anti-spam measures.

Security TIPS - rename (or delete) the "install" directory:

  • mv install/ nopeinstall/

For Apache there are .htaccess files already in place to do this for the most sensitive files and folders. We do however recommend to completely deny all access to the aforementioned folders and their respective subfolders in your Apache configuration.

On Apache 2.4, denying access to the phpbb folder in a phpBB instance located at /var/www/html/ would be accomplished by adding the following access rules to the Apache configuration file (typically apache.conf):

<Directory /var/www/html/phpbb/*>

Require all denied

<Directory /var/www/html/phpbb>

Require all denied