LMS/Moodle
Git herunterladen
sudo git clone https://github.com/moodle/moodle.git /var/www/moodle
sudo chmod -R 777 /var/www
cd /var/www/moodle
sudo git tag -l | sort -V
git reset --hard
git checkout v5.1.3
Moodle upgraden
cd /var/www/moodle
git fetch --all
git checkout v5.1.3
Deployment-Skript: Rsync für Moodle
Ersten Mal Installation von Moodle auf einem Produktionsserver. Der folgende `rsync`-Befehl wird verwendet, um eine Moodle-Installation von einem lokalen Server auf einen Produktionsserver zu übertragen. Dabei werden sensible und unnötige Dateien ausgeschlossen:
rsync -avz --dry-run
rsync -avz --delete \
--perms --times \
--exclude '.git/' \
--exclude '.gitignore' \
--exclude 'config.php' \
--exclude 'cache/' \
--exclude 'localcache/' \
--exclude 'muc/' \
--exclude 'sessions/' \
/var/www/moodle/ \
user@prod:/var/www/moodle/
nginx-Konfiguration für Moodle
Die folgende Konfiguration für den Nginx-Webserver ist für die Bereitstellung von Moodle
sudo systemctl stop nginx
sudo certbot certonly --standalone -d lernen.ahrensburg.city
Moodle Einstellungen für Nginx auf dem Server Rechner
Ein Beispiel für eine einfache Nginx-Konfiguration für Moodle auf einem Server Rechner:
<pre>
sudo nano /etc/nginx/conf.d/moodle.conf
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name lernen.ahrensburg.city;
root /var/www/moodle/moodle/public;
index index.php index.html index.htm;
ssl_certificate /etc/letsencrypt/live/lernen.ahrensburg.city/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/lernen.ahrensburg.city/privkey.pem;
location / {
try_files $uri $uri/ =404;
}
location ~ [^/]\.php(/|$) {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass unix:/run/php/php8.4-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
}
location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
expires max;
log_not_found off;
}
}
Moodledata-Verzeichnis erstellen
Das Verzeichnis `moodledata` ist für Moodle zwingend erforderlich und sollte außerhalb des Webroots liegen. Erstellen Sie das Verzeichnis und passen Sie die Berechtigungen an:
sudo mkdir -p /var/www/moodle/moodledata
sudo chown -R www-data:www-data /var/www/moodle/moodledata
sudo chmod -R 770 /var/www/moodle/moodledata
Achten Sie darauf, dass das Verzeichnis nicht über den Webserver erreichbar ist, um die Sicherheit Ihrer Moodle-Installation zu gewährleisten.
PHP und erforderliche Erweiterungen installieren
moodledata-Verzeichnis erstellen und Berechtigungen setzen
Erstelle das Verzeichnis für moodledata und setze die passenden Rechte:
sudo mkdir /var/www/moodledata
sudo chown -R www-data:www-data /var/www/moodledata
sudo chmod 770 -R /var/www/moodledata
Das Verzeichnis moodledata sollte sich außerhalb des Webroots befinden und für den Webserver-Benutzer (z.B. www-data) beschreibbar sein.
PHP-FPM Einstellungen anpassen
Öffne die Konfigurationsdatei für PHP-FPM, um Einstellungen wie z.B. die maximale Dateigröße für Uploads oder die Speicherlimits zu ändern:
sudo nano /etc/php/8.4/fpm/php.ini
Empfohlene Einstellungen für Moodle:
; Mit Strg+W (bzw. Ctrl+W) kannst du im Editor nach allen Werten suchen, um die Einstellung schnell zu finden.
max_input_vars = 5000
upload_max_filesize = 100M
post_max_size = 100M
max_execution_time = 300
memory_limit = 512M
Starte PHP-FPM neu, damit die Änderungen wirksam werden:
sudo systemctl restart php8.4-fpm