249 lines
6.1 KiB
Markdown
249 lines
6.1 KiB
Markdown
# Guide de Déploiement - Fiche Agent
|
|
|
|
Ce document décrit la procédure pas à pas pour déployer l'application **Fiche Agent** sur un serveur de test (Linux Ubuntu/Debian recommandé).
|
|
|
|
## 1. Prérequis Serveur
|
|
|
|
Assurez-vous que votre serveur dispose des dépendances suivantes :
|
|
|
|
* **OS** : Ubuntu 22.04 / 24.04 ou Debian 11/12
|
|
* **Serveur Web** : Nginx (recommandé) ou Apache
|
|
* **PHP** : Version 8.2 ou supérieure
|
|
* Extensions requises : `bcmath`, `ctype`, `fileinfo`, `json`, `mbstring`, `pdo_mysql`, `tokenizer`, `xml`, `zip`, `gd` (pour les PDF/Images), `intl`.
|
|
* **Base de données** : MySQL 8.0+ ou MariaDB 10.6+
|
|
* **Composer** : Gestionnaire de dépendances PHP
|
|
* **Node.js & NPM** : Version 18+ ou 20+ (pour compiler les assets Vue.js)
|
|
* **Git** : Pour récupérer le code
|
|
|
|
## 2. Préparation du système (Exemple Ubuntu/Debian)
|
|
|
|
Mettez à jour les paquets et installez les dépendances :
|
|
|
|
```bash
|
|
# Mise à jour
|
|
sudo apt update && sudo apt upgrade -y
|
|
|
|
# Installation de Nginx, Git, Zip, Unzip, Curl
|
|
sudo apt install -y nginx git zip unzip curl
|
|
|
|
# Installation de PHP 8.2 et des extensions
|
|
sudo apt install -y php8.2 php8.2-fpm php8.2-mysql php8.2-mbstring php8.2-xml php8.2-bcmath php8.2-curl php8.2-zip php8.2-intl php8.2-gd
|
|
|
|
# Installation de Composer
|
|
curl -sS https://getcomposer.org/installer | php
|
|
sudo mv composer.phar /usr/local/bin/composer
|
|
|
|
# Installation de Node.js (via NodeSource)
|
|
curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash -
|
|
sudo apt install -y nodejs
|
|
```
|
|
|
|
## 3. Configuration de la Base de Données
|
|
|
|
Connectez-vous à MySQL/MariaDB et créez la base de données :
|
|
|
|
```sql
|
|
# Connexion
|
|
sudo mysql -u root -p
|
|
|
|
# Commandes SQL
|
|
CREATE DATABASE fiche_agent CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
|
|
CREATE USER 'fiche_agent_user'@'localhost' IDENTIFIED BY 'votre_mot_de_passe_securise';
|
|
GRANT ALL PRIVILEGES ON fiche_agent.* TO 'fiche_agent_user'@'localhost';
|
|
FLUSH PRIVILEGES;
|
|
EXIT;
|
|
```
|
|
|
|
## 4. Installation de l'Application
|
|
|
|
### 4.1 Récupération du Code
|
|
Naviguez vers le répertoire web (ex: `/var/www`) et clonez le dépôt :
|
|
|
|
```bash
|
|
cd /var/www
|
|
sudo git clone <votre-url-git-repository> fiche-agent
|
|
# OU transférez les fichiers via SFTP si vous n'avez pas de dépôt git distant
|
|
```
|
|
|
|
### 4.2 Permissions
|
|
Assurez-vous que l'utilisateur du serveur web (souvent `www-data`) est propriétaire des fichiers, et donnez les droits d'écriture aux dossiers de stockage :
|
|
|
|
```bash
|
|
cd /var/www/fiche-agent
|
|
sudo chown -R www-data:www-data .
|
|
sudo chmod -R 775 storage bootstrap/cache
|
|
```
|
|
|
|
### 4.3 Installation des Dépendances PHP
|
|
Installez les dépendances en mode production :
|
|
|
|
```bash
|
|
composer install --optimize-autoloader --no-dev
|
|
```
|
|
|
|
### 4.4 Configuration de l'Environnement
|
|
Copiez le fichier d'exemple et configurez-le :
|
|
|
|
```bash
|
|
cp .env.example .env
|
|
nano .env
|
|
```
|
|
|
|
Modifiez les lignes suivantes dans le fichier `.env` :
|
|
|
|
```ini
|
|
APP_NAME="Fiche Agent"
|
|
APP_ENV=production
|
|
APP_DEBUG=false
|
|
APP_URL=http://votre-domaine-ou-ip.com
|
|
|
|
DB_CONNECTION=mysql
|
|
DB_HOST=127.0.0.1
|
|
DB_PORT=3306
|
|
DB_DATABASE=fiche_agent
|
|
DB_USERNAME=fiche_agent_user
|
|
DB_PASSWORD=votre_mot_de_passe_securise
|
|
|
|
QUEUE_CONNECTION=database
|
|
```
|
|
|
|
Générez la clé d'application :
|
|
|
|
```bash
|
|
php artisan key:generate
|
|
```
|
|
|
|
### 4.5 Base de Données & Migrations
|
|
Lancez les migrations pour créer les tables :
|
|
|
|
```bash
|
|
php artisan migrate --force
|
|
```
|
|
*(Optionnel) Si vous voulez des données de test initiales :*
|
|
```bash
|
|
php artisan db:seed --force
|
|
```
|
|
|
|
## 5. Compilation des Assets (Frontend)
|
|
|
|
Installez les dépendances JS et compilez pour la production :
|
|
|
|
```bash
|
|
npm install
|
|
npm run build
|
|
```
|
|
|
|
## 6. Configuration du Serveur Web (Nginx)
|
|
|
|
Créez un fichier de configuration Nginx :
|
|
|
|
```bash
|
|
sudo nano /etc/nginx/sites-available/fiche-agent
|
|
```
|
|
|
|
Contenu suggéré :
|
|
|
|
```nginx
|
|
server {
|
|
listen 80;
|
|
server_name votre-domaine-ou-ip.com;
|
|
root /var/www/fiche-agent/public;
|
|
|
|
add_header X-Frame-Options "SAMEORIGIN";
|
|
add_header X-Content-Type-Options "nosniff";
|
|
|
|
index index.php;
|
|
|
|
charset utf-8;
|
|
|
|
location / {
|
|
try_files $uri $uri/ /index.php?$query_string;
|
|
}
|
|
|
|
location = /favicon.ico { access_log off; log_not_found off; }
|
|
location = /robots.txt { access_log off; log_not_found off; }
|
|
|
|
error_page 404 /index.php;
|
|
|
|
location ~ \.php$ {
|
|
fastcgi_pass unix:/var/run/php/php8.2-fpm.sock;
|
|
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
|
|
include fastcgi_params;
|
|
}
|
|
|
|
location ~ /\.(?!well-known).* {
|
|
deny all;
|
|
}
|
|
}
|
|
```
|
|
|
|
Activez le site et relancez Nginx :
|
|
|
|
```bash
|
|
sudo ln -s /etc/nginx/sites-available/fiche-agent /etc/nginx/sites-enabled/
|
|
sudo nginx -t
|
|
sudo systemctl reload nginx
|
|
```
|
|
|
|
## 7. Configuration des Queues (Supervisor)
|
|
|
|
Pour que l'envoi d'emails et la génération de PDF fonctionnent en arrière-plan, configurez Supervisor.
|
|
|
|
Installez Supervisor :
|
|
```bash
|
|
sudo apt install -y supervisor
|
|
```
|
|
|
|
Créez un fichier de configuration :
|
|
```bash
|
|
sudo nano /etc/supervisor/conf.d/fiche-agent-worker.conf
|
|
```
|
|
|
|
Contenu :
|
|
```ini
|
|
[program:fiche-agent-worker]
|
|
process_name=%(program_name)s_%(process_num)02d
|
|
command=php /var/www/fiche-agent/artisan queue:work database --sleep=3 --tries=3 --max-time=3600
|
|
autostart=true
|
|
autorestart=true
|
|
stopasgroup=true
|
|
killasgroup=true
|
|
user=www-data
|
|
numprocs=2
|
|
redirect_stderr=true
|
|
stdout_logfile=/var/www/fiche-agent/storage/logs/worker.log
|
|
stopwaitsecs=3600
|
|
```
|
|
|
|
Activez Supervisor :
|
|
```bash
|
|
sudo supervisorctl reread
|
|
sudo supervisorctl update
|
|
sudo supervisorctl start fiche-agent-worker:*
|
|
```
|
|
|
|
## 8. Finalisation
|
|
|
|
Votre application devrait être accessible via l'URL configurée.
|
|
|
|
### Commandes utiles pour la maintenance
|
|
|
|
* **Mettre à jour l'application :**
|
|
```bash
|
|
cd /var/www/fiche-agent
|
|
git pull origin main
|
|
composer install --optimize-autoloader --no-dev
|
|
php artisan migrate --force
|
|
npm run build
|
|
php artisan cache:clear
|
|
php artisan config:cache
|
|
php artisan route:cache
|
|
php artisan view:cache
|
|
supervisorctl restart fiche-agent-worker:*
|
|
```
|
|
|
|
* **Vérifier les logs :**
|
|
* Laravel : `tail -f storage/logs/laravel.log`
|
|
* Worker : `tail -f storage/logs/worker.log`
|
|
* Nginx : `/var/log/nginx/error.log`
|