Elasticsearch est un moteur de recherche et d'analyse en texte intégral distribué open source. Il prend en charge les opérations RESTful et vous permet de stocker, de rechercher et d'analyser de gros volumes de données en temps réel.
Elasticsearch est l'un des moteurs de recherche les plus populaires alimentant des applications qui ont des exigences de recherche complexes telles que les grands magasins de commerce électronique et les applications analytiques.
Ce tutoriel vous guidera tout au long du processus d'installation d'Elasticsearch sur Debian 9.
Prérequis #
Vous devrez être connecté en tant qu'utilisateur avec des privilèges sudo pour pouvoir installer des packages sur votre serveur Debian.
Installation d'Elasticsearch #
Le moyen le plus simple d'installer Elasticsearch sur Debian est via le référentiel officiel Elasticsearch. Au moment de la rédaction de cet article, la dernière version d'Elasticsearch est 7.0.0
et nécessite l'installation de Java 8 sur le système.
Commencez par mettre à jour l'index des packages et installez le apt-transport-https
package nécessaire pour accéder à un référentiel via HTTPS :
sudo apt update
sudo apt install apt-transport-https
Installez OpenJDK 8 :
sudo apt install openjdk-8-jdk
Vérifiez l'installation de Java en imprimant la version de Java :
java -version
Le résultat devrait ressembler à ceci :
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-8u181-b13-2~deb9u1-b13)
OpenJDK 64-Bit Server VM (build 25.181-b13, mixed mode)
L'étape suivante consiste à ajouter le référentiel Elasticsearch.
Importez la clé publique du référentiel en utilisant le wget
suivant commande :
wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo apt-key add -
La commande ci-dessus doit afficher OK
ce qui signifie que la clé a été importée avec succès et que les packages de ce référentiel seront considérés comme fiables.
Ensuite, ajoutez le référentiel Elasticsearch au système en exécutant :
sudo sh -c 'echo "deb https://artifacts.elastic.co/packages/7.x/apt stable main" > /etc/apt/sources.list.d/elastic-7.x.list'
Si vous souhaitez installer une autre version d'Elasticsearch, modifiez 7.x
dans la commande ci-dessus avec la version dont vous avez besoin. Mettez à jour l'index des packages et installez le moteur Elasticsearch :
sudo apt update
sudo apt install elasticsearch
Une fois le processus d'installation terminé, démarrez et activez le service à l'aide des commandes suivantes :
sudo systemctl enable elasticsearch.service
sudo systemctl start elasticsearch.service
Pour vérifier qu'Elasticsearch est en cours d'exécution, envoyez une requête HTTP au port 9200 sur localhost en utilisant le curl
suivant commande :
curl -X GET "localhost:9200/"
Le résultat devrait ressembler à ceci :
{
"name" : "stretch",
"cluster_name" : "elasticsearch",
"cluster_uuid" : "Nj2W3PswRuWvJW8JG75O1Q",
"version" : {
"number" : "7.0.0",
"build_flavor" : "default",
"build_type" : "deb",
"build_hash" : "b7e28a7",
"build_date" : "2019-04-05T22:55:32.697037Z",
"build_snapshot" : false,
"lucene_version" : "8.0.0",
"minimum_wire_compatibility_version" : "6.7.0",
"minimum_index_compatibility_version" : "6.0.0-beta1"
},
"tagline" : "You Know, for Search"
}
Cela peut prendre 5 à 10 secondes pour que le service démarre. Si vous voyez curl: (7) Failed to connect to localhost port 9200: Connection refused
, attendez quelques secondes et réessayez.
Pour afficher les messages enregistrés par le service Elasticsearch, utilisez la commande ci-dessous :
sudo journalctl -u elasticsearch
C'est ça. Elasticsearch a été installé sur votre serveur Debian.
Configuration d'Elasticsearch #
Les données Elasticsearch sont stockées dans /var/lib/elasticsearch
annuaire. Les fichiers de configuration se trouvent dans /etc/elasticsearch
et les options de démarrage Java peuvent être configurées dans /etc/default/elasticsearch
fichier.
Par défaut, Elasticsearch est configuré pour écouter uniquement sur localhost. Si le client qui se connecte à la base de données s'exécute également sur le même hôte et que vous configurez un cluster à nœud unique, vous n'avez pas besoin d'activer l'accès à distance.
Numéro d'accès à distance
Par défaut, Elasticsearch n'implémente pas d'authentification, il est donc accessible à toute personne pouvant accéder à l'API HTTP. Si vous souhaitez autoriser l'accès à distance à votre serveur Elasticsearch, vous devrez configurer votre pare-feu et autoriser l'accès au port Elasticsearch 9200 uniquement à partir de clients de confiance.
Si vous utilisez UFW comme outil de pare-feu de votre choix, exécutez la commande suivante pour autoriser l'évaluation sur le port 9200 à partir de l'adresse IP de confiance distante :
sudo ufw allow from 192.168.100.20 to any port 9200
N'oubliez pas de changer 192.168.100.20
avec votre adresse IP distante. Sinon, si vous utilisez l'ancien iptables, exécutez :
sudo iptables -A INPUT -p tcp -s 192.168.100.20 --dport 9200 -j ACCEPT
Une fois votre pare-feu configuré, l'étape suivante consiste à modifier la configuration et à configurer Elasticsearch pour écouter les connexions externes.
Pour ce faire, ouvrez le elasticsearch.yml
fichier de configuration :
sudo nano /etc/elasticsearch/elasticsearch.yml
Recherchez la ligne qui contient network.host
, décommentez-le et remplacez la valeur par 0.0.0.0
:
network.host: 0.0.0.0
Si vous avez plusieurs interfaces réseau sur votre machine, vous pouvez spécifier l'adresse IP de l'interface qui fera qu'Elasticsearch n'écoutera que sur l'interface spécifiée.
Redémarrez le service Elasticsearch pour que les modifications prennent effet :
sudo systemctl restart elasticsearch
À ce stade, vous devriez pouvoir vous connecter au serveur Elasticsearch depuis votre emplacement distant.