summaryrefslogtreecommitdiff
path: root/deploiement.txt
blob: 9a83fd220fb0c21635968d982daafc8bd81ec84a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
déploiement


=> procédure spécifique sur un hébergement "normal" avec un accès SSH.
=> avec un hébergement non-pro d'OVH, SSH n'est pas disponible, par contre il y a un phpmyadmin,
pour le reste il faut contourner avec des scripts PHP faisant des exec()

=> pour utiliser PHP-cli il faut utiliser le chemin de PHP, quelque chose comme /usr/local/php8.4/bin/
ou l'ajouter au PATH en éditant .bash_profile (facile avec filezilla):
trouver la ligne PATH=$PATH:$HOME/bin
et y coller :$HOME/usr/local/php8.4/bin

=> utiliser PHP-cli depuis un script web:
$param = '-r echo hello world 2>&1';
$commande = 'php ' . $param; // OU
$commande = '/usr/local/php8.4/bin/php ' . $param;
$sortie = null;
$code_retour = null;
exec($commande, $sortie, $code_retour);


=> avec SSH

1/ se connecter au serveur en ssh et télécharger les fichiers:
cd dossier_parent_du_site 
git clone lien_git

2/ renommer le dossier du site pour apache
mv nageurs nom_de_domaine

3/ selon l'hébergement, si apache utilise son propre utilisateur (www-data),
changer les permissions parce qu'on veut utiliser composer et la console de doctrine avec cet utilisateur
chown -R www-data:www-data dossier_du_site

on ajoutera ensuite "sudo -u www-data" devant les commandes

4/ si nécessaire, trouver PHP-cli!
placer sur le site un fichier php contenant:
<?php phpinfo();

un fichier de config devrait être trouvé, du genre:
/usr/local/php8.4/etc/php.ini

l'exécutable est donc (à vérifier dans filezilla):
/usr/local/php8.4/bin/php

optionnel: l'ajouter au PATH en éditant .bash_profile (facile avec filezilla):
trouver la ligne PATH=$PATH:$HOME/bin
et y coller :$HOME/usr/local/php8.4/bin

5/ installer composer, si n'y est pas:
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php composer-setup.php

on appelera donc composer en faisant: php composer.phar

6/ installer les dépendances
sudo -u www-data php composer.phar install

cette commande exécute du PHP écrit dans composer.json qui réalise la copie de fichiers dans /vendor vers /public/js
si une erreur se présente, il doit y avoir un problème de permission avec /public/js/tinymce et /public/js/tinymce-langs

7/ générer l'autoloader
php composer.phar dump-autoload -o

8/ se connecter à la BDD et créer la base:
mysql/mariadb -u root -p
CREATE DATABASE nageurs CHARACTER SET utf8mb4;

9/ droits de l'utilisateur sur la base de données
l'utilisateur de la BDD doit avoir les droits SELECT, INSERT, UPDATE, DELETE, CREATE, DROP et ALTER

10/ avec FTP, envoyer le fichier config.ini et le placer dans /config
ce fichier contient les codes de la BDD

11/ créer les tables avec composer:
sudo -u www-data php bin/doctrine orm:schema-tool:create

12/ éventuellement: remplir la base de données:
=> phpmyadmin ou ligne de commande
mariadb -D nageurs -u utilisateur_mysql -p < bdd_nageurs.sql

13/ associer le domaine au dossier du site dans l'espace client de l'hébergeur
par sécurité, choisir comme racine le dossier /public du site et non la vraie racine!