| Avertissement |
|---|
Les commandes suivantes ont été lancées sur une distribution Debian 11.4 |
| Sommaire |
|---|
Environnement
Création de l'utilisateur Pod
...
| Bloc de code |
|---|
pod@pod:~$ sudo python3 -V pod@pod:~$ sudo python -V pod@pod:~$ sudo apt-get install -y python3-pip pod@pod:~$ sudo pip3 install virtualenvwrapper |
Depuis python 3.10, il n'est plus possible d'installer avec pip en dehors d'un environnement. Pour pouvoir installer virtualenvwrapper il faut ajouter à la fin de la ligne --break-system-packages
À la fin du .bashrc, il faut ajouter ces lignes :
...
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get install ffmpeg (django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get install ffmpegthumbnailer (django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get install imagemagick |
Redis
ffmpegthumbnailer imagemagick |
Redis
Voir la doc officielle https://redis.io/docs/getting-Voir la doc officielle https://redis.io/docs/getting-started/
Pour installer le cache Redis
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get install redis-server |
En théorie le service démarre automatiquement. Si vous avez installé Redis sur la même machine que Pod, rien à faire de plus. Pour vérifier si le service est bien démarré :
...
| Bloc de code | ||
|---|---|---|
| ||
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://<my_redis_host>:6379/3",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
},
"KEY_PREFIX": "pod",
},
"select2": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://<my_redis_host>:6379/2",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
},
},
}
SESSION_ENGINE = "redis_sessions.session"
SESSION_REDIS = {
"host": "<my_redis_host>",
"port": 6379,
"db": 4,
"prefix": "session",
"socket_timeout": 1,
"retry_on_timeout": False,
} |
Elasticsearch
Installation de Java
Pour utiliser Elasticsearch, il faut avoir java 11 sur sa machine.
Selon la version d'Elasticsearch que vous allez utiliser, les versions des dépendances peuvent changer. Les versions 6 et 7 ne sont actuellement plus maintenues. La version 8 est à configurer plus bas. La version 6 est celle par défaut dans Pod.
Elasticsearch 6
Pour utiliser Elasticsearch 6, il faut avoir java 11 sur sa machine.
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get install openjdk-11-jre |
Puis pour installer Elasticsearch sur Debian en utilisant les paquets, il faut suivre les instructions situées à cette adresse : https://www.elastic.co/guide/en/elasticsearch/reference/current/deb.html.Vous pouvez installer Elasticsearch en version 6 ou en version 7.
Voici :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo apt-key add - OK (django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get install apt-transport-https |
Pour Elasticsearch 6 :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ echo "deb https://artifacts.elastic.co/packages/6.x/apt stable main" | sudo tee -a /etc/apt/sources.list.d/elastic-6.x.list deb https://artifacts.elastic.co/packages/6.x/apt stable main
(django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get update && sudo apt-get install elasticsearch |
Pour Elasticsearch 7 Ensuite il faut paramétrer l’instance :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ echosudo "debvim https:/etc/elasticsearch/elasticsearch.yml |
Puis préciser ces valeurs :
| Bloc de code |
|---|
cluster.name: pod-application
node.name: pod-1
discovery.zen.ping.unicast.hosts: ["127.0.0.1"] |
Elasticsearch 7 et 8
Pour utiliser Elasticsearch 7 ou 8, il faut avoir java 17 sur sa machine.
| Bloc de code |
|---|
artifacts.elastic.co/packages/7.x/apt stable main" | sudo tee /etc/apt/sources.list.d/elastic-7.x.list (django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get update && sudo apt-get install elasticsearch |
Ensuite il faut paramétrer l’instance :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ sudo vim /etc/elasticsearch/elasticsearch.yml |
Pour préciser ces valeurs :
Pour Elasticsearch 6 :
| Bloc de code |
|---|
cluster.name: pod-application
node.name: pod-1
discovery.zen.ping.unicast.hosts: ["127.0.0.1"] |
Pour Elasticsearch 7 :
| Bloc de code |
|---|
cluster.name: pod-application
node.name: pod-1
discovery.seed_hosts: ["127.0.0.1"]
cluster.initial_master_nodes: ["pod-1"] |
Il faut enfin le lancer et vérifier son bon fonctionnement :
...
install default-jdk |
Puis pour installer Elasticsearch sur Debian en utilisant les paquets, il faut suivre les instructions situées à cette adresse : https://www.elastic.co/guide/en/elasticsearch/reference/current/deb.html.
Vous pouvez installer Elasticsearch en version 7 (plus maintenue) ou en version 8.
Voici pour ES7 :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo gpg --dearmor -o /usr/share/keyrings/elasticsearch-keyring.gpg OK (django_pod3) pod@pod:~/django_projects/ |
...
podv3$ sudo apt-get install apt-transport-https (django_pod3) |
...
pod@pod:~/django_projects/ |
...
podv3$ echo "deb [signed-by=/usr/share/keyrings/elasticsearch-keyring.gpg] https://artifacts.elastic.co/packages/7.x/apt stable main" | sudo tee /etc/apt/sources.list.d/elastic-7.x.list
(django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get update && sudo apt-get install elasticsearch |
Voici pour ES8 :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo gpg --dearmor -o /usr/share/keyrings/elasticsearch-keyring.gpg
OK
(django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get install apt-transport-https
(django_pod3) pod@pod:~/django_projects/podv3$ echo "deb [signed-by=/usr/share/keyrings/elasticsearch-keyring.gpg] https://artifacts.elastic.co/packages/8.x/apt stable main" | sudo tee /etc/apt/sources.list.d/elastic-8.x.list
(django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get update && sudo apt-get install elasticsearch |
Ensuite il faut paramétrer l’instance
...
| Bloc de code |
|---|
{
"name" : "pod-1",
"cluster_name" : "pod-application",
"cluster_uuid" : "5yhs9zc4SRyjaKYyW7uabQ",
"version" : {
"number" : "8.4.0",
"build_flavor" : "default",
"build_type" : "deb",
"build_hash" : "f56126089ca4db89b631901ad7cce0a8e10e2fe5",
"build_date" : "2022-08-19T19:23:42.954591481Z",
"build_snapshot" : false,
"lucene_version" : "9.3.0",
"minimum_wire_compatibility_version" : "7.17.0",
"minimum_index_compatibility_version" : "7.0.0"
},
"tagline" : "You Know, for Search"
} |
Pour utiliser la recherche dans Pod, nous allons avoir besoin également du plugin ICU :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ cdsudo vim /usretc/share/elasticsearch/ (django_pod3) pod@pod:/usr/share/elasticsearch$ sudo bin/elasticsearch-plugin install analysis-icu -> Downloading analysis-icu from elastic [=================================================] 100% -> Installed analysis-icu (django_pod3) pod@pod:/usr/share/elasticsearch$ sudo /etc/init.d/elasticsearch restart [ ok ] Restarting elasticsearch (via systemctl): elasticsearch.service. |
Création de l'index Pod
...
Pour une utilisation d'elasticsearch 7.X, il faut absolument :
Ajouter ES_VERSION = 7 dans votre fichier de settings et modifiez la version du client elasticsearch dans le fichier requirements.txt
elasticsearch==7.17.9
(django_pod3) pod@podv3:~/django_projects/podv3$ pip3 install -r requirements.txtelasticsearch/elasticsearch.yml |
Puis préciser ces valeurs :
| Bloc de code |
|---|
cluster.name: pod-application
node.name: pod-1
discovery.seed_hosts: ["127.0.0.1"]
cluster.initial_master_nodes: ["pod-1"] |
Il est recommandé d'utiliser le mode security d'ES8.
Générer l'utilisateur pod pour ES :
| Bloc de code |
|---|
cd /etc/elasticsearch/
touch users
touch users_roles
chown root:elasticsearch users
chown root:elasticsearch users_roles
sudo /usr/share/elasticsearch/bin/elasticsearch-users useradd pod -p podpod -r superuser |
Génération des certificats (CA + cert) :
| Bloc de code |
|---|
sudo /usr/share/elasticsearch/bin/elasticsearch-certutil ca
sudo /usr/share/elasticsearch/bin/elasticsearch-certutil cert --ca elastic-stack-ca.p12
sudo /usr/share/elasticsearch/bin/elasticsearch-keystore add xpack.security.http.ssl.keystore.secure_password
sudo /usr/share/elasticsearch/bin/elasticsearch-keystore add xpack.security.http.ssl.truststore.secure_password |
Copier le fichier .p12 dans /etc/elasticsearch/
| Bloc de code |
|---|
sudo cp /usr/share/elasticsearch/elastic-stack-ca.p12 /usr/share/elasticsearch/elastic-certificates.p12 /etc/elasticsearch/
sudo chown pod:pod /etc/elasticsearch/elastic-stack-ca.p12 /etc/elasticsearch/elastic-certificates.p12
sudo chmod +r /etc/elasticsearch/elastic-stack-ca.p12 /etc/elasticsearch/elastic-certificates.p12 |
Dans /etc/elasticsearch/elasticsearch.yml :
| Bloc de code |
|---|
xpack.security.http.ssl.enabled: true
xpack.security.http.ssl.verification_mode: certificate
xpack.security.http.ssl.keystore.path: /etc/elasticsearch/elastic-certificates.p12
xpack.security.http.ssl.truststore.path: /etc/elasticsearch/elastic-certificates.p12
|
Lancement et vérification d'Elasticsearch
Il faut enfin le lancer et vérifier son bon fonctionnement :
(django_pod3) pod@pod:~/django_projects/podv3$ sudo /etc/init.d/elasticsearch start
(django_pod3) pod@pod:~/django_projects/podv3$ curl -XGET "127.0.0.1:9200"
ou pour ES8 (django_pod3) pod@pod:~/django_projects/podv3$ curl -k -XGET 'https://127.0.0.1:9200' -u pod:podpod
| Bloc de code |
|---|
{
"name" : "pod-1",
"cluster_name" : "pod-application",
"cluster_uuid" : "5yhs9zc4SRyjaKYyW7uabQ",
"version" : {
"number" : "8.4.0",
"build_flavor" : "default",
"build_type" : "deb",
"build_hash" : "f56126089ca4db89b631901ad7cce0a8e10e2fe5",
"build_date" : "2022-08-19T19:23:42.954591481Z",
"build_snapshot" : false,
"lucene_version" : "9.3.0",
"minimum_wire_compatibility_version" : "7.17.0",
"minimum_index_compatibility_version" : "7.0.0"
},
"tagline" : "You Know, for Search"
} |
Pour utiliser la recherche dans Pod, nous allons avoir besoin également du plugin ICU :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ cd /usr/share/elasticsearch/
(django_pod3) pod@pod:/usr/share/elasticsearch$ sudo bin/elasticsearch-plugin install analysis-icu
-> Downloading analysis-icu from elastic
[=================================================] 100%
-> Installed analysis-icu
(django_pod3) pod@pod:/usr/share/elasticsearch$ sudo /etc/init.d/elasticsearch restart
[ ok ] Restarting elasticsearch (via systemctl): elasticsearch.service. |
Si vous utilisez derrière un proxy :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ cd /usr/share/elasticsearch/
(django_pod3) pod@pod:/usr/share/elasticsearch$ sudo ES_JAVA_OPTS="-Dhttp.proxyHost=proxy.univ.fr -Dhttp.proxyPort=3128 -Dhttps.proxyHost=proxy.univ.fr -Dhttps.proxyPort=3128" /usr/share/elasticsearch/bin/elasticsearch-plugin install analysis-icu
-> Downloading analysis-icu from elastic
[=================================================] 100%
-> Installed analysis-icu
(django_pod3) pod@pod:/usr/share/elasticsearch$ sudo /etc/init.d/elasticsearch restart
[ ok ] Restarting elasticsearch (via systemctl): elasticsearch.service. |
Attention, pour ES8 derrière un proxy :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ cd /usr/share/elasticsearch/
(django_pod3) pod@pod:/usr/share/elasticsearch$ sudo CLI_JAVA_OPTS="-Dhttp.proxyHost=proxy.univ.fr -Dhttp.proxyPort=3128 -Dhttps.proxyHost=proxy.univ.fr -Dhttps.proxyPort=3128" /usr/share/elasticsearch/bin/elasticsearch-plugin install analysis-icu
-> Downloading analysis-icu from elastic
[=================================================] 100%
-> Installed analysis-icu
(django_pod3) pod@pod:/usr/share/elasticsearch$ sudo /etc/init.d/elasticsearch restart
[ ok ] Restarting elasticsearch (via systemctl): elasticsearch.service. |
Création de l'index Pod
| Avertissement |
|---|
Pour une utilisation d'elasticsearch 7 ou 8, il faut absolument : Ajouter ES_VERSION = 7 ou ES_VERSION = 8 dans votre fichier de settings et modifiez la version du client elasticsearch dans le fichier requirements.txt elasticsearch==7.17.9 ou elasticsearch==8.9.0 Et ne pas oublier de relancer (django_pod3) pod@podv3:~/django_projects/podv3$ pip3 install -r requirements.txt |
Nous pouvons enfin vérifier le bon fonctionnement de l'ensemble (l’erreur affichée lors de la deletion est normale puisque l'indice n'existe pas, mais nous devons supprimer avant de créer un index dans ES) :
| Bloc de code |
|---|
(django_pod3) pod@pod:/usr/share/elasticsearch$ cd ~/django_projects/podv3
(django_pod3) pod@pod:~/django_projects/podv3$ python manage.py create_pod_index
DELETE http://127.0.0.1:9200/pod [status:404 request:0.140s]
An error occured during index video deletion: 404-index_not_found_exception : no such index
Successfully create index Video
(django_pod3) pod@pod:~/django_projects/podv3$ curl -XGET "127.0.0.1:9200/pod/_search"
{"took":35,"timed_out":false,"_shards":{"total":2,"successful":2,"skipped":0,"failed":0},"hits":{"total":0,"max_score":null,"hits":[]}} |
Si la commande python ne fonctionne pas, créez d'abord l'index à la main avec un curl -XPUT "http://127.0.0.1:9200/pod" (options -k --noproxy -u <user>:<pwd> à prévoir si ES8 en mode security)
Si vous déportez l'elastic search sur une autre machine, rajoutez dans le fichier settings_local.py son URL d'accès :
| Bloc de code |
|---|
Nous pouvons enfin vérifier le bon fonctionnement de l'ensemble (l’erreur affichée lors de la deletion est normale puisque l'indice n'existe pas, mais nous devons supprimer avant de créer un index dans ES) :
| Bloc de code |
|---|
(django_pod3) pod@pod:/usr/share/elasticsearch$ cd ~/django_projects/podv3 (django_pod3) pod@pod:~/django_projects/podv3$ python manage.py create_pod_index DELETE http://127.0.0.1:9200/pod [status:404 request:0.140s] An error occured during index video deletion: 404-index_not_found_exception : no such index Successfully create index Video (django_pod3) pod@pod:~/django_projects/podv3$ curl -XGET "127.0.0.1:9200/pod/_search" {"took":35,"timed_out":false,"_shards":{"total":2,"successful":2,"skipped":0,"failed":0},"hits":{"total":0,"max_score":null,"hits":[]}} |
Si vous déportez l'elastic search sur une autre machine, rajoutez dans le fichier settings_local.py son URL d'accès :
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ vim pod/custom/settings_local.py |
Copiez la ligne suivante :
vim pod/custom/settings_local.py |
Copiez la ligne suivante :
| Bloc de code |
|---|
ES_URL = ['http://elastic.domaine.fr:9200/'] |
Avec le mode security et ES8, vous devrez parametrer les éléments suivants dans votre settings_local.py :
| Bloc de code | ||
|---|---|---|
| ||
ES_URL = ['https://127.0.0.1:9200/'] # ou votre instance déportée
ES_OPTIONS = {'verify_certs' : False, 'basic_auth' : ('es_user', 'password')} | ||
| Bloc de code | ||
ES_URL = ['http://elastic.domaine.fr:9200/'] |
Installation des dépendances
Pour installer les dépendances, il faut en premier installer nodejs, npm et yarmyarn. L'installation ne fonctionne pas avec nodejs 12.x
La référence est ici: https://github.com/nodesource/distributions
| Bloc de code |
|---|
(django_pod3) pod@pod:~/django_projects/podv3$ sudo apt-get update
|
| Bloc de code |
(django_pod3) pod@pod:~/django_projects/podv3$ curlsudo apt-sL https://deb.nodesource.com/setup_18.x | sudo bash -get install -y ca-certificates curl gnupg (django_pod3) pod@pod:~/django_projects/podv3$ sudo aptmkdir install nodejs-p /etc/apt/keyrings (django_pod3) pod@pod:~/django_projects/podv3$ curl -sSfsSL https://dldeb.yarnpkgnodesource.com/debian/pubkey.gpg | sudo apt-key add -/gpgkey/nodesource-repo.gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg (django_pod3) pod@pod:~/django_projects/podv3$ NODE_MAJOR=18 && echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://dldeb.yarnpkgnodesource.com/debian/ stablenode_$NODE_MAJOR.x nodistro main" | sudo tee /etc/apt/sources.list.d/yarnnodesource.list (django_pod3) pod@pod:~/django_projects/podv3$ sudo apt update && sudo apt install -y nodejs (django_pod3) pod@pod:~/django_projects/podv3$ sudo aptcorepack install yarnenable |
| Info | ||
|---|---|---|
| ||
Alternativement, si vous êtes sur CentOS 8, installez les dépendances nodejs+npm et yarn ainsi : root@pod:~/$ dnf module reset nodejs root@pod:~/$ dnf module enable nodejs:14 root@pod:~/$ dnf module -y update nodejs root@pod:~/$ yum install nodejs root@pod:~/$ npm install yarn -g |
Se placer dans le répertoire où est installé le package.json
...
Vous trouverez l'ensemble des variables disponibles sur cette page :
Configuration de la plateforme
SuperUtilisateur
Il faut créer un premier utilisateur qui aura tous les pouvoirs sur votre instance.
...
| Bloc de code |
|---|
(django_pod3) pod@Pod:~/django_projects/podv3$ python3 manage.py runserver @IP/DNS:8080 --insecurinsecure |
--> exemple : (django_pod3) pod@pod:~/django_projects/podv3$ python manage.py runserver pod.univ.fr:8080 --insecure
- Attention -
...
Quand le site est lancé, il faut se rendre dans la partie administration puis dans site pour renseigner le nom de domaine de votre instance de Pod (par défaut 'example.com').
Avant la mise en production, il faut vérifier le fonctionnement de la plateforme dont l'ajout d'une vidéo, son encodage et sa suppression.
Attention, pour ajouter une vidéo, il doit y avoir au moins un type de vidéo disponible. Si vous avez correctement peuplé votre base de données avec le fichier initial_data.json vous devez au moins avoir other/autres.
il faut vérifier l'authentification CAS, le moteur de recherche etc.