This documentation covers new Ilios installations for users that have never had any current or prior version of Ilios running on their server.
If you are looking to update your installation of Ilios, please see Updating Ilios 3.x.
If you are looking to upgrade a previous v2.x installation of Ilios, please see Upgrading From Ilios 2.x.
To build/deploy the Ilios 3 backend, you will need to install the default Ilios database schema and then follow the steps for deploying code to your webserver(s) and configuring them to connect to the database and serve the API.
Ilios 3 uses a Symfony (PHP/SQL) backend to serve its API, so these tools and their required dependencies need to be installed before you can install the application itself. Here at the Ilios Project, we currently run and recommend running Ilios 3 using a "LAMP" (Linux Apache MySQL PHP) technology stack with the following software packages and versions:
- CentOS 7 - Any modern Linux should work, but we recommend Redhat (RHEL, CentOS, or Fedora) or Ubuntu
- MySQL using the InnoDB database engine (v5.7 or later required, 8+ recommended)
- PHP v8.1+ REQUIRED - In order to ensure the best security and performance of the application overall, we have adopted a policy of requiring the latest version of PHP for running Ilios. Please see ilios_php_version_policy.md for the latest information about the PHP version requirements for Ilios.
NOTE: Several institutions have successfully deployed Ilios using Microsoft IIS on Windows as their webserver, but we do not recommend it as we do not have alot of experience with it ourselves and we've only ever support Ilios on Linux systems. That being said, if you MUST use IIS for Windows and are having trouble getting Ilios running properly, please contact the Ilios Project Support Team at support@iliosproject.org if you have any problems and we might be able to help you out!
PHP should configured with a 'memory_limit' setting of at least 386MB and have the following required packages/modules/extensions enabled:
- php-mbstring - for UTF-8 support
- php-ldap - for ldap-connectivity support (when using LDAP)
- php-xml
- php-pecl-apcu - caching
- php-mysql - DB connectivity
- php-mysqlnd - DB connectivity
- php-pdo - DB connectivity
- php-zip - for native zip package [de]compression during the composer installation process
CentOS, RedHat, and Fedora Linux distributions come with SELinux installed and enabled by default. SELinux, aka "Security-Enhanced Linux", greatly limits many actions typically allowed out-of-the-box on most Linux distros so, if you seem to be having issues with your Ilios installation not working correctly and you have SELinux installed and enabled, we recommend you review your SELinux settings and/or check out our Troubleshooting section below.
You must enable URL-rewriting on your webserver. For those using Apache, this can be done by installing and enabling the 'mod_rewrite' module. In IIS, this is handled via the Microsoft IIS URL Rewrite extension
You will need the Composer PHP package management tool. If you do not have it, you can learn about it and download it at https://getcomposer.org
These steps assume that you are deploying the Ilios 3 backend via a Git clone from the Ilios repository at https://github.com/ilios/ilios.git and building the install using PHP's 'composer' package manager.
All the steps below should be performed in the context of the user that runs your webserver process (typically, 'apache')
- Log into your webserver(s) and change to your web server root ('/web/ilios3' for this example).
- Clone/update Ilios 3 directory tree to this directory (assuming 'git clone' for this example).
sudo -u apache git clone https://github.com/ilios/ilios.git
This will create a folder named 'ilios' in your server root directory. The entire application source tree will be downloaded to this folder and when this process is finished, the 'web' subfolder should be set as your web server's document root ('/web/ilios3/ilios/public') in your webserver configuration.
3. Change into the newly created folder
cd ilios
You should now be in the '/web/ilios3/ilios' directory
- Checkout the latest release tag:
# NOTE: When running this command in the context of your web services user, you can ignore any `Permission denied`
# errors related to git files in your own user's `.config` directory:
sudo -u apache git checkout tags/$(git fetch --tags; git describe --tags `git rev-list --tags --max-count=1`)
- Run the following command to build the packages and its dependencies. This step assumes you have PHP 8.1+ and Composer installed on your system:
sudo -u apache bin/setup
This will install the required PHP Symfony packages and their dependencies and check your system for any issues.
Congratulations! Once you've the completed the above steps, the latest codebase will have been built and deployed!
There are three configuration parameters that must be supplied to ilios for basic functionality. A path to your database connection, a path on the file system to store learning materials, and a secret to use for encrypting user passwords, tokens and other sensitive data. For the initial installation it is sufficient to place this information in the ilios filesystem.
sudo -u apache echo "ILIOS_SECRET='NotSecretChangeMe'" >> .env.local
sudo -u apache echo "ILIOS_DATABASE_URL=mysql://ilios:ilios@127.0.0.1/ilios?serverVersion=8.0" >> .env.local
sudo -u apache echo "ILIOS_FILE_SYSTEM_STORAGE_PATH=/tmp" >> .env.local
These values will need to be adjusted to your environment and setup.
If you are already running a 2.x version of Ilios, you can upgrade your current database by following the intructions at Upgrading From Ilios 2.x.
If you are NOT upgrading from a previous version of Ilios, you can create a new, empty database schema by using the following Symfony console command:
bin/console doctrine:database:create --env=prod
bin/console doctrine:migrations:migrate --env=prod
bin/console ilios:import-default-data --env=prod
bin/console ilios:import-mesh-universe --env-prod
This will create your database schema, with all tables and constraints, and will also load in all the default lookup table data, like competencies and topics --- which you can modify once you're done with setup --- but it won't have any course data or any other unique data about your specific school or curriculum until you log in and add some.
There are a number of automated health checks which will ensure that your system is configured optimally and point to any issues. Run them as:
bin/console monitor:health --group=default --group=production
- Finally, you should clear all cached items from the system, including the Symfony Cache (and its store on the filesystem) and the APC cache:
# clear the Symfony cache...
sudo -u apache bin/console cache:clear --env=prod
# and finally, the APC cache (by restarting the httpd server)
sudo service httpd restart
And that's it! You should now have a working Ilios 3 backend!
To get started with your new version of Ilios, you are going to have to create the 'first user' in order to get into the application. The username for this user will be 'first_user', the password will be 'Ch4nge_m3', and the user will be granted 'root'-level privileges, which will allow you to perform all necessary tasks to start administering the application.
To add the first user, we need to return to the the Ilios application root folder ('/web/ilios3/ilios') and get ready to run the following console command. Before running the command, however, you'll want to gather this information about the user you intend to add:
- The user's email address (eg, ilios_admin@example.edu)
- The id of the school that user will be part of; this will most likely be '1' (School of Medicine)
You will be prompted for the email address and school id info when you run the following command (And don't worry, you can change this info after you login!):
sudo -u apache bin/console ilios:setup:first-user --env=prod
After that, visit the url of your new Ilios 3 site and you should see a login form. Enter 'first_user' in the login field and 'Ch4nge_m3' (without the quotes!) in the password field and submit!
If everything went correctly, you're ready to go! Congratulations on installing Ilios! If not, please see some of our troubleshooting suggestions below.
Make sure to take a look at update for information on staying up to date and authentication for help setting up ilios to use your campus single sign on system.
If you've followed all of the instructions in this document and are still unable to get Ilios work properly, here are some things to try and/or verify:
- Using SELinux? - If you are attempting to run Ilios on a system that has SELinux enabled and running, you may need to run the following commands in order to allow your webserver to connect to your database:
setsebool -P httpd_can_network_connect 1
setsebool -P httpd_can_network_connect_db 1
- If you are making changes to your parameters.yml configuration file and your changes do not seem to be taking effect, remember to clear your Symfony cache any time you make a change to the file. This command must be run from the root directory of your Ilios application, in the context of the user running your web services (eg, 'apache' or 'nginx'):
sudo -u apache bin/console cache:clear --env=prod
If you have tried the above steps without any luck, of if you think we should add another troubleshooting suggestion/solution, please feel free to contact us at support@iliosproject.org if you have any questions, comments, or suggestions!