linuq-nextcloud2021/installation-machine-virtuelle.md

426 lines
15 KiB
Markdown
Raw Normal View History

# Création de la machine virtuelle avec VirtualBox
## Téléchargement de Debian 10
Depuis le site web de Debian, il est possible de télécharger une version légère "net install" de la version 10. Cliquez simplement sur le bouton "télécharger". Sinon, l'image est disponible via ce lien: [debian-10.8.0-amd64-netinst.iso](https://cdimage.debian.org/debian-cd/current/amd64/iso-cd/debian-10.8.0-amd64-netinst.iso)
Note: il est possible que cette la version de l'image par défaut ait changé depuis la création de ce tutoriel. L'important est que ce soit la version 10 de Debian.
## Création d'une machine virtuelle Debian
2021-03-07 19:30:43 +00:00
On débute par ouvrir le logiciel VirtualBox qui est habituellement disponible via la distribution Linux ou via le [site web de VirtualBox](https://www.virtualbox.org/)
![Accueil de Virtualbox](Nextcloud-Installation-VirtualBox-001.png)
2021-03-07 19:30:43 +00:00
On crée une nouvelle machine virtuelle de Type Linux et de version Debian (64-bit). Le dossier de la machine doit avoir au moins 20 Go d'espace libre pour assurer le bon fonctionnement de la machine virtuelle.
![créer une nouvelle machine virtuelle](Nextcloud-Installation-VirtualBox-002.png)
Choisissez la quantité de mémoire vive. Il est conseillé d'avoir au moins 2048 Mo de disponible pour que Nextcloud fonctionne de façon fluide avec quelques applications additionnelles.
![quantité de mémoire vive](Nextcloud-Installation-VirtualBox-003.png)
Choisissez le type de disque dur VDI
![type de disque dur VDI](Nextcloud-Installation-VirtualBox-005.png)
Choisissez le stockage dynamiquement alloué
![dynamiquement alloué](Nextcloud-Installation-VirtualBox-006.png)
Choisissez la taille du disque à utiliser pour la machine virtuelle. Je conseille d'utiliser au moins 15 Go. Validez que le répertoire d'enregistrement du disque contient suffissamment d'espace.
![taille disque](Nextcloud-Installation-VirtualBox-007.png)
2021-03-07 19:30:43 +00:00
Nous avons maintenant une configuration de base. On ajuste quelques paramètres pour le besoin.
![configuration de base](Nextcloud-Installation-VirtualBox-008.png)
Je conseille de mettre au moins deux processeurs si possible.
![deux processeurs](Nextcloud-Installation-VirtualBox-009.png)
2021-03-07 19:30:43 +00:00
Il est possible d'enregistrer l'installation pour garder une trace pour référence future.
![enregistrer](Nextcloud-Installation-VirtualBox-010.png)
2021-03-07 19:30:43 +00:00
On configure une redirection de port afin de pouvoir se connecter à la machine virtuelle en SSH avec une console virtuelle ou un logiciel tel que PuTTY au lieu de devoir utiliser l'interface de VirtualBox.
![redirection](Nextcloud-Installation-VirtualBox-011.png)
Ajouter la configuration suivante:
- Nom: ssh
- Protocole: TCP
- Port hôte: 3022
- Port invité: 22
![redirection](Nextcloud-Installation-VirtualBox-012.png)
Ensuite, sélectionner Afficher depuis l'écran d'accueil. Ceci démarre l'installation du système d'exploitation.
![configuration de base](Nextcloud-Installation-VirtualBox-008.png)
2021-03-07 19:30:43 +00:00
Sélectionner l'image ISO du système Debian 10 téléchargée préalablement.
![image ISO](Nextcloud-Installation-VirtualBox-013.png)
![image ISO](Nextcloud-Installation-VirtualBox-014.png)
Démarrer l'installation
![installation](Nextcloud-Installation-VirtualBox-015.png)
## Installation de Debian
2021-03-07 19:30:43 +00:00
On installe le système Debian sur la machine virtuelle.
2021-03-07 19:30:43 +00:00
Choisir l'option "install" comme on n'installe pas un système avec une interface graphique.
![install](Nextcloud-Installation-VirtualBox-016.png)
2021-03-07 19:30:43 +00:00
Choisissez la langue. Cette installation fonctionnera dans toutes les langues disponibles.
![langue](Nextcloud-Installation-VirtualBox-017.png)
2021-03-07 19:30:43 +00:00
Choisissez le pays
![pays](Nextcloud-Installation-VirtualBox-018.png)
2021-03-07 19:30:43 +00:00
Choisissez la disposition de clavier
![disposition de clavier](Nextcloud-Installation-VirtualBox-019.png)
Nom de machine: `nextcloud`
Mot de passe root: `nextcloud`
![machine](Nextcloud-Installation-VirtualBox-020.png)
Utilisateur: `demo`
![Utilisateur](Nextcloud-Installation-VirtualBox-021.png)
Mot de passe: `demo`
![Mot de passe](Nextcloud-Installation-VirtualBox-022.png)
Choisissez le partitionnement assisté
![partitionnement assisté](Nextcloud-Installation-VirtualBox-023.png)
Choisissez tout dans une seule partition
![une seule partition](Nextcloud-Installation-VirtualBox-024.png)
Choisissez terminer et appliquer tous les changements
![appliquer](Nextcloud-Installation-VirtualBox-025.png)
Choisissez "oui"
![démarrage installation](Nextcloud-Installation-VirtualBox-026.png)
L'installation des packages du système débute, ceci peut prendre quelques minutes.
Choisissez "non" à cette invite qui demande s'il y a d'autres disques à analyser.
![disque analyser](Nextcloud-Installation-VirtualBox-027.png)
2021-03-07 19:30:43 +00:00
Choisissez le pays pour un miroir. Ici, c'est la proximité géographique qui est la plus importante.
![pays du miroir](Nextcloud-Installation-VirtualBox-028.png)
2021-03-07 19:30:43 +00:00
Choisissez ensuite un miroir pour télécharger les packages additionnels de Debian qui seront installés.
![miroir](Nextcloud-Installation-VirtualBox-029.png)
2021-03-07 19:30:43 +00:00
Laissez le champ du mandataire vide sauf si applicable (c'est très rare sur un réseau résidentiel)
2021-03-07 19:30:43 +00:00
Un autre ensemble de packages sera téléchargé puis installé. En cours de route, il faut répondre à un invite sur popularity-contest. Le choix recommandé est `Non`.
![popularity-contest](Nextcloud-Installation-VirtualBox-030.png)
2021-03-07 19:30:43 +00:00
L'installation se poursuivre par la suite. On aura à choisir différentes options. On réduit ces options au minimum, car Yunohost a son propre script d'installation qui se chargera du reste.
![sélection logiciels](Nextcloud-Installation-VirtualBox-031.png)
Sélectionner "oui" pour l'installation du système d'amorçage.
![sélection logiciels](Nextcloud-Installation-VirtualBox-032.png)
Choisir le disque `/dev/sda`
![sélection logiciels](Nextcloud-Installation-VirtualBox-033.png)
Ensuite, choisissez "continuer" et la machine virtuelle redémarrera. Debian est maintenant installé.
## Se connecter en SSH sur la machine virtuelle
2021-03-07 19:30:43 +00:00
Pour se connecter sur la machine virtuelle, on utilise le port configuré lors de la création de la machine virtuelle ainsi que l'utilisateur demo.
Dans un terminal, saisir:
```bash
ssh -p 3022 demo@localhost
```
2021-03-07 19:30:43 +00:00
S'authentifier avec le mot de passe `demo`
Avec PuTTY
![putty hote](Nextcloud-Installation-VirtualBox-034.png)
![putty user](Nextcloud-Installation-VirtualBox-035.png)
Ensuite, se connecter en tant que root avec `su -` et saisir le mot de passe root `nextcloud` entré lors de l'installation de Debian.
2021-03-07 19:30:43 +00:00
Nous sommes maintenant connecté en tant qu'administrateur sur la machine virtuelle Debian 10 et prêts à installer Yunohost.
```text
(base) ~ ssh -p 3022 demo@localhost
demo@localhost's password:
Linux yunohost 4.19.0-14-amd64 #1 SMP Debian 4.19.171-2 (2021-01-30) x86_64
The programs included with the Debian GNU/Linux system are free software;
the exact distribution terms for each program are described in the
individual files in /usr/share/doc/*/copyright.
Debian GNU/Linux comes with ABSOLUTELY NO WARRANTY, to the extent
permitted by applicable law.
Last login: Sat Mar 6 17:20:55 2021 from 10.0.2.2
demo@yunohost:~$ su -
Mot de passe :
root@yunohost:~#
```
Avec PuTTY:
![putty user](Nextcloud-Installation-VirtualBox-036.png)
2021-03-07 19:30:43 +00:00
**Note**: Dans un terminal, l'invite de commandes est précédé d'un dièse lorsque connecté en root.
## Installation de screen (optionnel)
2021-03-07 19:30:43 +00:00
Pour rouler des commandes qui prennent un temps considérable à exécuter, il est recommandé d'utiliser des sessions screen, qui permettent de garder une session active sur le serveur même si la connexion fait défaut.
```bash
sudo apt install -y screen
```
2021-03-07 19:30:43 +00:00
Pour la suite de ce tutoriel, on assume que la [section d'introduction du manuel](https://www.gnu.org/software/screen/manual/screen.html#Getting-Started) de screen ou les principales fonctionnalités sont connues.
## Installation de Yunohost
Exécuter les commandes suivantes en tant que root
```bash
apt install -y curl
curl https://install.yunohost.org | bash
```
Lancez l'installation
![débuter installation](Nextcloud-Installation-VirtualBox-037.png)
2021-03-07 19:30:43 +00:00
Laisser Yunohost gérer le SSH. À la prochaine connexion, l'utilisateur administrateur sera `admin`. C'est un rôle intermédiaire entre `demo` et `root` en terme de permissions.
![gestion ssh](Nextcloud-Installation-VirtualBox-038.png)
2021-03-07 19:30:43 +00:00
Une fois l'installation terminée, il faut effectuer la post-installation.
2021-03-07 19:30:43 +00:00
Un nom de domaine est requis pour l'installation. On utilisera `nextcloud.local`.
Le mot de passe d'administration sera `nextcloud`.
2021-03-07 19:30:43 +00:00
On crée un premier utilisateur `utilisateur`
```bash
yunohost user create utilisateur
```
Le résultat est:
```text
Succès ! Lutilisateur a été créé
fullname: utilisateur nouveau
mail: utilisateur@nextcloud.local
username: utilisateur
```
2021-03-07 19:30:43 +00:00
## Accès à la machine virtuelle comme un serveur séparé sur le réseau local
2021-03-07 19:30:43 +00:00
On onfigure maintenant la machine virtuelle en mode "pont" afin qu'elle ait sa propre adresse IP. Le nom de domaine pourra être associé à cette adresse pour simplifier les manipulations futures. Ceci va simuler comme si on avait une machine physique séparée ou un serveur avec une adresse IP publique tel un serveur privé virtuel (VPS).
![reseau pont](Nextcloud-Installation-VirtualBox-039.png)
2021-03-07 19:30:43 +00:00
Ensuite, redémarrer la machine virtuelle depuis VirtualBox (Menu Machine/Redémarrage).
Une fois redémarrée, l'affichage VirtualBox de la machine virtuelle affiche son adresse IP. Dans cet exemple, c'est 192.168.0.151.
![reseau pont](Nextcloud-Installation-VirtualBox-040.png)
2021-03-07 19:30:43 +00:00
Dans le configuration de routeur DHCP à la maison, figer cette adresse. Voici un exemple pour un routeur D-Link
![figer IP](Nextcloud-Installation-VirtualBox-041.png)
2021-03-07 19:30:43 +00:00
On ajoute le domaine au fichier "hosts".
- Sur Windows (éditer en mode administrateur): `C:\Windows\System32\drivers\etc\hosts`
- Sur Linux (éditer avec sudo): `/etc/hosts`
- Sur MacOS (éditer avec sudo): `/private/etc/hosts`
2021-03-07 19:30:43 +00:00
Ajouter la ligne suivante au fichier (Changer selon l'adressse IP de la machine virtuelle):
```text
192.168.0.151 nextcloud.local
```
2021-03-07 19:30:43 +00:00
On se connecte à l'instance Yunohost via l'adresse `https://nextcloud.local` dans le navigateur. Attention, ça va demander d'accepter le risque d'une adresse sans certificat valide.
![accepter https](Nextcloud-Installation-VirtualBox-042.png)
2021-03-07 19:30:43 +00:00
Une fois arrivé à la fenêtre de connexion, on entre `utilisateur` et `nextcloud`
![connexion](Nextcloud-Installation-VirtualBox-043.png)
2021-03-07 19:30:43 +00:00
Nous avons réussi ! L'installation de Yunohost est fonctionnelle.
![accueil yunohost](Nextcloud-Installation-VirtualBox-044.png)
## Installation de Nextcloud
On se connecte en SSH sur le serveur en utilisant le domaine cette fois-ci.
```bash
ssh -p 22 admin@nextcloud.local
```
On installe une instance de Nextcloud.
2021-03-07 19:30:43 +00:00
```bash
sudo yunohost app install nextcloud
```
2021-03-07 19:30:43 +00:00
On conserve les paramètres par défaut proposés à moins d'utiliser un sous-domaine. Les paramètres de l'installation devraient ressembler à ceci.
```text
Choose the domain where this app should be installed [nextcloud.local] (default: nextcloud.local):
Choose the path where this app should be installed (default: /nextcloud):
Choose an administrator user for this app [utilisateur] (default: utilisateur):
Access the users home folder from Nextcloud? [yes | no] (default: no):
```
## Validation de l'installation
2021-03-07 19:30:43 +00:00
Pour s'assurer que l'installation de Nextcloud est bien fonctionnelle, ouvrez l'URL suivante dans le navigateur: `https://nextcloud.local/nextcloud`
![Interface Nextcloud](Nextcloud-Installation-VirtualBox-045.png)
## Installation d'Elasticsearch
2021-03-07 19:30:43 +00:00
On installe Elasticsearch comme engin de recherche plein texte
```bash
wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo apt-key add -
sudo apt-get install apt-transport-https openjdk-11-jre-headless
echo "deb https://artifacts.elastic.co/packages/6.x/apt stable main" | sudo tee -a /etc/apt/sources.list.d/elastic-6.x.list
sudo apt-get update && sudo apt-get install elasticsearch
```
Il faut maintenant mettre en place et activer le service pour qu'Elasticsearch roule en arrière-plan.
```bash
sudo systemctl enable elasticsearch.service
```
2021-03-07 19:30:43 +00:00
Enfin, il faut installer et activer le plugin d'indexations de documents pour Elasticsearch
```bash
/usr/share/elasticsearch/bin/elasticsearch-plugin install --batch ingest-attachment
```
Pour terminer, on redémarre le service
```bash
sudo systemctl restart elasticsearch.service
```
## Installation de l'engin de recherche plein texte de Nextcloud
Depuis le navigateur web, ouvrir l'URL suivante: `https://nextcloud.local/nextcloud/settings/apps`
Dans la section Rechercher, cliquez sur **Télécharger et activer** pour les trois applications suivantes:
- Full text search
- Full text search - Files
- Full text search - Elasticsearch Platform
![applications full text search](Nextcloud-Installation-VirtualBox-046.png)
Maintenant, allons dans la section Paramètres de Nextcloud pour configurer ces applications. Sélectionner `Elasticsearch` comme plateforme de recherche.
Indiquer `http://localhost:9200` comme adresse du Servlet et `nc_index` comme index
![Configuration full text search](Nextcloud-Installation-VirtualBox-047.png)
## Initialiser l'index
2021-03-07 19:30:43 +00:00
Depuis la session SSH, idéalement dans un screen, on initialise l'index Elasticsearch. Exécuter en tant que root.
```bash
cd /var/www/nextcloud
chmod a+x occ
sudo -u nextcloud php ./occ fulltextsearch:index
```
![initialiser l'index](Nextcloud-Installation-VirtualBox-048.png)
## Activer l'indexation en continu
2021-03-07 19:30:43 +00:00
Tous les nouveaux documents ajoutés dans Nextcloud devraient être indexés. Pour ce faire, on crée un service dans systemd qui permet l'indexation en continu.
Avec un éditeur de texte, ouvrir et modifier le fichier "unit" du service.
```bash
sudo nano /etc/systemd/system/nextcloud-fulltext-elasticsearch-worker.service
```
Insérer le contenu suivant:
```text
[Unit]
Description=Elasticsearch Worker for Nextcloud Fulltext Search
After=network.target
[Service]
User=nextcloud
Group=nextcloud
WorkingDirectory=/var/www/nextcloud
ExecStart=/usr/bin/php /var/www/nextcloud/occ fulltextsearch:live -q
ExecStop=/usr/bin/php /var/www/nextcloud/occ fulltextsearch:stop
Nice=19
Restart=always
[Install]
WantedBy=multi-user.target
```
2021-03-07 19:30:43 +00:00
Apres avoir modifié un fichier "unit" il faut recharger systemd avant d'activer et de démarrer le service.
```bash
systemctl daemon-reload
systemctl enable nextcloud-fulltext-elasticsearch-worker.service
systemctl start nextcloud-fulltext-elasticsearch-worker.service
```
2021-03-07 19:30:43 +00:00
Valider ensuite que le service est bien activé:
```bash
systemctl status nextcloud-fulltext-elasticsearch-worker.service
```
![service d'indexation en continu](Nextcloud-Installation-VirtualBox-049.png)
2021-03-07 17:28:46 +00:00
On peut utiliser la recherche plein texte depuis l'URL suivante: `https://nextcloud.local/nextcloud/apps/fulltextsearch/`
2021-03-07 19:30:43 +00:00
![exemple recherche](Nextcloud-Installation-VirtualBox-050.png)