Abitti 2 – Installing Linux Server for IT Pros
Normally the Abitti 2 server is created using Naksu 2 utility tool. This document describes manual Abitti 2 server installation for special purposes for Ubuntu 22.04 server installation.
Note: The official method for installing Abitti 2 server is Naksu 2 utility. Therefore, these instructions may change without notice or be outdated. In case of problems contact Abitti support.
Installation procedure
- Install required packages:
sudo apt install -y docker-compose-v2 apache2-utils jq
- Add your user to group “docker” in order to give it access to Docker services::
sudo adduser YOUR-USERNAME docker
- Create a directory which will contain files used by the Abitti 2 containers:
mkdir ktp-jako
- Create username and password for the supervisor user interface:
htpasswd -c ktp-jako/htpasswd SUPERVISOR-USERNAME
There can be multiple username-password combinations. - Get a script to generate DNS record and corresponding SSL certificate:
wget https://static.abitti.fi/abitti-2-test/app/create-certificate.sh
- Get an installation key from the Abitti support.
Execution process
Replace version number (0.8.0) with the latest Abitti 2 version.
- Get the Docker Compose file for the Abitti 2 version which you want to execute:
wget https://static.abitti.fi/naksu2/docker-compose.prod.v0.8.0.yml
- Get or update the DNS record and/or certificate:
bash ./create-certificate.sh
- Set an environment variable containing the DNS record fetched by the previous script:
export HOST_NAME=$(cat certs/domain.txt)
- Set username and password for database. These should be completely random strings, as they never need to be rewritten.
export COUCHDB_USER=random-admin-username
export COUCHDB_PASSWORD=random-admin-password
- Log in to the Docker repository:
curl -s https://oma.abitti.fi/digabi2/ecr-credentials | jq -r '.password' | docker login -u AWS --password-stdin https://863419159770.dkr.ecr.eu-north-1.amazonaws.com
- Install (if required) and execute the server according to the Docker Compose file:
docker compose -f docker-compose.prod.v0.8.0.yml up --force-recreate --renew-anon-volumes
The create-certificate.sh
reads following environment variables:
HOST_IP
– External IP of the server. This IP is given to the random DNS record (e.g.export HOST_IP=192.168.0.2
)API_KEY
– Installation code given by the Abitti support (e.g.export API_KEY=Pdq2bzheMQHC
)
The server container reads following variables:
KTP_KOE_PORT
– The port to the candidates’ interface, SSL (defaults to 8010)KTP_SUPO_PORT
– The port of the supervisors’ interface, SSL (443)
Uninstalling server and removing data
An existing server and its data can be removed by issuing a following command:
docker compose -f docker-compose.prod.v0.8.0.yml down --remove-orphans --volumes
In this case the version number must point to the installed Abitti 2 version. It is possible that the future Abitti 2 versions may require that previous version will be uninstalled before installing a new one.
Firewall
Abitti 2 client and server communicate using multiple TCP ports. TCP traffic through these ports must be allowed to make Abitti 2 clients and all applications to work.
443 | Supervisor’s web access (console) |
8010 | Candidate’s web access |
8011, 8081-8090 | Candidate’s application servers |
8012 | Candidate’s cloud storage (WOPI) |