.. tip::
If you are uncomfortable with linux permissions follow the steps below as the root user. Some commands do not behave the same when run with sudo.
Alliance Auth can be installed on any operating system. Dependencies are provided below for two of the most popular server platforms, Ubuntu and CentOS. To install on your favourite flavour of linux, identify and install equivalent packages to the ones listed here.
.. hint::
CentOS: A few packages are included in a non-default repository. Add it and update the package lists. ::
yum -y install https://centos7.iuscommunity.org/ius-release.rpm
yum update
Alliance Auth requires python3.4 or higher. Ensure it is installed on your server before proceeding.
Ubuntu:
apt-get install python3 python3-dev python3-venv python3-setuptools python3-pip
CentOS:
yum install python36u python36u-devel python36u-setuptools python36u-pip
It’s recommended to use a database service instead of sqlite. Many options are available, but this guide will use MariaDB.
Ubuntu:
apt-get install mariadb-server mysql-client libmysqlclient-dev
CentOS:
yum install mariadb-server mariadb-devel mariadb
A few extra utilities are also required for installation of packages.
Ubuntu:
apt-get install unzip git redis-server curl libssl-dev libbz2-dev libffi-dev
CentOS:
yum install gcc gcc-c++ unzip git redis curl bzip2-devel
.. important::
CentOS: Make sure redis is running before continuing. ::
systemctl enable redis.service
systemctl start redis.service
Alliance Auth needs a MySQL user account and database. Open an SQL shell with mysql -u root -p
and create them as follows, replacing PASSWORD
with an actual secure password:
CREATE USER 'allianceserver'@'localhost' IDENTIFIED BY 'PASSWORD';
CREATE DATABASE alliance_auth CHARACTER SET utf8;
GRANT ALL PRIVILEGES ON alliance_auth . * TO 'allianceserver'@'localhost';
Close the SQL shell and secure your database server with the mysql_secure_installation
command.
If you’re updating from v1, populate this database with a copy of the data from your v1 database.
mysqldump -u root -p v1_database_name_here | mysql -u root -p alliance_auth
Note this command will prompt you for the root password twice.
For security and permissions, it’s highly recommended you create a separate user to install auth under. Do not log in as this account.
Ubuntu:
adduser --disabled-login allianceserver
CentOS:
useradd -s /bin/nologin allianceserver
Create a Python virtual environment and put it somewhere convenient (e.g. /home/allianceserver/venv/auth/
)
python3 -m venv /home/allianceserver/venv/auth/
.. warning::
The python3 command may not be available on all installations. Try a specific version such as python3.6 if this is the case.
.. tip::
A virtual environment provides support for creating a lightweight "copy" of Python with their own site directories. Each virtual environment has its own Python binary (allowing creation of environments with various Python versions) and can have its own independent set of installed Python packages in its site directories. You can read more about virtual environments on the Python_ docs.
.. _Python: https://docs.python.org/3/library/venv.html
Activate the virtualenv using source /home/allianceserver/venv/auth/bin/activate
. Note the /bin/activate
on the end of the path.
.. hint::
Each time you come to do maintenance on your Alliance Auth installation, you should activate your virtual environment first. When finished, deactivate it with the 'deactivate' command.
Ensure wheel is available with pip install wheel
before continuing.
You can install the library using pip install allianceauth
. This will install Alliance Auth and all its python dependencies. You should also install gunicorn with pip install gunicorn
before proceeding.
Now you need to create the application that will run the Alliance Auth install. Ensure you are in the allianceserver home directory by issuing cd /home/allianceserver
.
The allianceauth start myauth
command bootstraps a Django project which will run Alliance Auth. You can rename it from myauth
to anything you’d like: this name is shown by default as the site name but that can be changed later.
The settings file needs configuring. Edit the template at myauth/myauth/settings/local.py
. Be sure to configure the EVE SSO and Email settings.
Django needs to install models to the database before it can start.
python /home/allianceserver/myauth/manage.py migrate
Now we need to round up all the static files required to render templates. Make a directory to serve them from and populate it.
mkdir -p /var/www/myauth/static
python /home/allianceserver/myauth/manage.py collectstatic
Check to ensure your settings are valid.
python /home/allianceserver/myauth/manage.py check
And finally ensure the allianceserver user has read/write permissions to this directory before proceeding.
chown -R allianceserver:allianceserver /home/allianceserver/myauth
To run the auth website a WSGI Server is required. Gunicorn is highly recommended for its ease of configuring. It can be manually run with gunicorn myauth.wsgi
or automatically run using supervisor.
The default configuration is good enough for most installations. Additional information is available in the gunicorn doc.
Supervisor is a process watchdog service: it makes sure other processes are started automatically and kept running. It can be used to automatically start the WSGI server and celery workers for background tasks. Installation varies by OS:
Ubuntu:
apt-get install supervisor
CentOS:
yum install supervisor
systemctl enable supervisord.service
systemctl start supervisord.service
Once installed it needs a configuration file to know which processes to watch. Your Alliance Auth project comes with a ready-to-use template which will ensure the celery workers, celery task scheduler and gunicorn are all running.
Ubuntu:
ln -s /home/allianceserver/myauth/supervisor.conf /etc/supervisor/conf.d/myauth.conf
CentOS:
ln -s /home/allianceserver/myauth/supervisor.conf /etc/supervisord.d/myauth.ini
And activate it with supervisorctl reload
.
You can check the status of the processes with supervisorctl status
. Logs from these processes are available in /home/allianceserver/myauth/log
named by process.
.. note::
Any time the code or your settings change you'll need to restart gunicorn and celery. ::
supervisorctl restart myauth:
Once installed, decide on whether you’re going to use NGINX or Apache and follow the respective guide.
Before using your auth site it is essential to create a superuser account. This account will have all permissions in Alliance Auth. It’s OK to use this as your personal auth account.
python /home/allianceserver/myauth/manage.py createsuperuser
The superuser account is accessed by logging in via the admin site at https://example.com/admin
.
If you intend to use this account as your personal auth account you need to add a main character. Navigate to the normal user dashboard (at https://example.com
) after logging in via the admin site and select Change Main
. Once a main character has been added it is possible to use SSO to login to this account.
Periodically new releases are issued with bug fixes and new features. To update your install, simply activate your virtual environment and update with pip install --upgrade allianceauth
. Be sure to read the release notes which will highlight changes.
Some releases come with changes to settings: update your project’s settings with allianceauth update /home/allianceserver/myauth
.
Some releases come with new or changed models. Update your database to reflect this with python /home/allianceserver/myauth/manage.py migrate
.
Always restart celery and gunicorn after updating.