Page tree
Skip to end of metadata
Go to start of metadata

Commandes générales de mise à jour

Voici les commandes à lancer pour effectuer une mise à jour de Pod V2


    pod@pod:~$ cd django_projects/podv2/
    pod@pod:~/django_projects/podv2$ workon django_pod
    (django_pod) pod@pod:~/django_projects/podv2$ git status
    (django_pod) pod@pod:~/django_projects/podv2$ git pull origin master
    (django_pod) pod@pod:~/django_projects/podv2$ pip3 install -r    requirements.txt
    (django_pod) pod@pod:~/django_projects/podv2$ python manage.py    makemigrations
    (django_pod) pod@pod:~/django_projects/podv2$ python manage.py    migrate
    (django_pod) pod@pod:~/django_projects/podv2$ python manage.py    collectstatic
    (django_pod) pod@pod:~/django_projects/podv2$ sudo systemctl restart    uwsgi-pod 

Si vous faites une mise à jour au delà de la version 2.2 :

Migration des Notes vers AdvancedNotes :

(django_pod) pod@pod:~/django_projects/podv2$ python manage.py shell
from pod.video.models import Notes, AdvancedNotes
from django.utils import timezone
if __name__ == "__main__":
    notes = Notes.objects.all()
    for n in notes:
        AdvancedNotes.objects.create(
            video=n.video, user=n.user,
            added_on=timezone.now(),
            modified_on=timezone.now(),
            note=n.note, timestamp=0,
            status='0'
        )


NB : les notes créées avant AdvancedNotes seront enregistrées avec un timestamp à 0 et un status « privé - »  (uniquement l’auteur de la note peut la voir)


Migration à partir de la version 2.3:

Pour l'utilisation de l'autotranscription, il faut suivre la première partie de la documentation disponible à cette adresse : Mise en place de l'autotranscription


Migration 2.5.0 à 2.5.1 :

A partir de la version 2.5.1 Pod utilise des commandes de la librairie deepspeech qui nécessite que les CPU supportent les instructions "AVX".

Ces instructions sont disponibles à partir des "Sandy Bridge" (intel) et "Bulldozer" (amd) en gros après 2011.

Si vous êtes dans une version antérieure à la 2.5.1, vous pouvez tester la compatibilité dans l'environnement podv2 avec la commande :

python -m deepspeech

si la réponse est :

No module named deepspeech.__main__;

'deepspeech' is a package and cannot be directly executed"

c'est bon, si la réponse est

"Illegal instruction (core dumped)"

ce n'est pas bon et il faudra soit utiliser un autre serveur soit désactiver l'autotranscription ainsi que l'importation de la librairie comme expliqué ci dessous.

Migration en 2.6.0 :

lors de la commande

python manage.py    makemigrations

une erreur apparait : Instruction non permise

cette erreur est lié à deepspeech

il faut donc :


pip3 uninstall deepspeech

nano pod/video/transcript.py

commenter la ligne from deepspeech import Model

puis continuer les commandes ...

Update de ElasticSearch

En cas d'update du paquet ElasticSearch, le plugin analysis-icu ne se met pas à jour automatiquement et n'est plus compatible avec la version d'ElasticSearch. il faut le supprimer, le réinstaller, recréer l'index puis réindexer les vidéos.

cd /usr/share/elasticsearch/
bin/elasticsearch-plugin remove analysis-icu
bin/elasticsearch-plugin install analysis-icu
service elasticsearch restart

su - pod
cd django_projects/podv2
python manage.py create_pod_index
python manage.py index_videos --all 

Mise à jour des encodeurs déportés :

pod@pod:~$ cd django_projects/podv2/
pod@pod:~/django_projects/podv2$ workon django_pod
(django_pod) pod@pod:~/django_projects/podv2$ git status
(django_pod) pod@pod:~/django_projects/podv2$ git pull origin master
(django_pod) pod@pod:~/django_projects/podv2$ pip3 install -r    requirements.txt
(django_pod) pod@pod:~/django_projects/podv2$ sudo /etc/init.d/celeryd restart



  • No labels