A Dockerfile that installs the latest RosarioSIS. This file pulls from the default branch, but can be easily modified to pull from any other available branch or tagged release.
Minimum requirements: Docker & Git working.
You can pull the image from DockerHub or:
git clone https://gitlab.com/francoisjacquet/docker-rosariosis.git
cd docker-rosariosis
docker build -t rosariosis .
Note: a docker-compose.yml
file is also available.
RosarioSIS uses a PostgreSQL database:
docker run -d \
--name rosariosisdb \
-e "POSTGRES_USER=rosario" \
-e "POSTGRES_PASSWORD=rosariopwd" \
-e "POSTGRES_DB=rosariosis" \
-v ./plan/db:/var/lib/postgresql/data \
postgres:15
This command will
- run the postgres image (version 15)
- name it "rosariosisdb"
- set database name "rosariosis", user "rosario" and password "rosariopwd"
- a volume will persist data on your host inside
./plan/db
Run RosarioSIS (DockerHub image) and link the PostgreSQL container:
docker run -d \
--name rosariosis \
-e "ROSARIOSIS_ADMIN_EMAIL=admin@example.com" \
-e "PGHOST=rosariosisdb" \
--link rosariosisdb:rosariosisdb \
-p 80:80 \
-v ./plan/rosariosis:/var/www/html \
rosariosis/rosariosis:master
This command will
- run the latest rosariosis/rosariosis:master image
- name it "rosariosis"
- set the notification email to "admin@example.com" (see available environment variables below)
- link the "rosariosisdb" container
- expose port 80 of container to port 80 on host (
host:container
) - a volume will persist data on your host inside
./plan/rosariosis
Port 80 will be exposed, so you can visit http://localhost/InstallDatabase.php to get started. Default username and password: admin
.
Note: you may have to add sudo
before the docker
command.
Warning: since image for RosarioSIS version 12.1.1, the image was upgraded to Debian 12 bookworm, PHP 8.1 and should use PostgreSQL 15. Database upgrade should be done manually.
The RosarioSIS image uses several environment variables which are easy to miss. While none of the variables are required, they may significantly aid you in using the image.
Database type: postgresql or mysql (defaults to postgresql).
Host of the database.
This optional environment variable is used in conjunction with PGPASSWORD to set a user and its password for the database.
This optional environment variable is used in conjunction with PGUSER to set a user and its password for the database.
This optional environment variable can be used to define a different name for the database.
This optional environment variable can be used to define a different port for the database.
This optional environment variable can be used to define the default school year in RosarioSIS settings.
Only change after Rollover.
This optional environment variable can be used to define an email address where to send error and new administrator notifications.
This optional environment variable is for RosarioSIS to show another language.
Values are fr_FR
for French and es_ES
for Spanish.
You must also generate the fr_FR.utf8
(for example) locale. To do so run these commands:
sudo docker exec -it rosariosis bash
dpkg-reconfigure locales
This optional environment variable is used to set the required version of RosarioSIS.
RosarioSIS will attempt to send mail via the host's port 25. In order for this to work you must set the hostname of the rosariosis container to that of host
(or some other hostname that can appear on a legal FROM
line) and configure the host to accept SMTP from the container. For postfix this means adding the container IP addresses to /etc/postfix/main.cf
as in:
mynetworks = 192.168.0.0/16 172.16.0.0/12 10.0.0.0/8 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128
Note: alternatively, you can use the Email SMTP plugin for RosarioSIS.