IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

Vous êtes nouveau sur Developpez.com ? Créez votre compte ou connectez-vous afin de pouvoir participer !

Vous devez avoir un compte Developpez.com et être connecté pour pouvoir participer aux discussions.

Vous n'avez pas encore de compte Developpez.com ? Créez-en un en quelques instants, c'est entièrement gratuit !

Si vous disposez déjà d'un compte et qu'il est bien activé, connectez-vous à l'aide du formulaire ci-dessous.

Identifiez-vous
Identifiant
Mot de passe
Mot de passe oublié ?
Créer un compte

L'inscription est gratuite et ne vous prendra que quelques instants !

Je m'inscris !

GNOME Shell affecté par un bogue qui se manifeste par l'augmentation de l'espace RAM occupé toutes les minutes
Sur plusieurs distributions Linux

Le , par Patrick Ruiz

135PARTAGES

11  0 
Des utilisateurs de l’environnement de bureau GNOME Shell rapportent que ce dernier est affecté par un bogue qui a un impact sur son empreinte mémoire. Le comportement erratique de l’application concerne les utilisateurs de plusieurs distributions Linux. Les plaintes ont principalement été formulées au travers de la plateforme launchpad.net d’Ubuntu, mais la vidéo de démonstration du bogue a été réalisée sous la distribution Fedora dérivée de RedHat.


En substance, les utilisateurs d’une version non patchée de GNOME 3.26 sur Ubuntu 17.04, 17.10 et Fedora 27 – pour ne citer que ces distributions – devraient pouvoir reproduire le bogue à l’aide d’actions habituelles comme l’ouverture de l’aperçu, la réduction d’une fenêtre, le basculement entre fenêtres (effectuer la combinaison de touches Alt+tab avec plus de trois fenêtres d’applications ouvertes), etc. La description du bogue disponible sur launchpad.net fait état de ce qu’il y a augmentation de l’empreinte mémoire toutes les minutes ; de plus, l’espace consommé peut aller jusqu’à 2 giga-octets en fonction des animations lancées sur l’environnement de bureau.

La situation est fâcheuse pour les systèmes munis de peu de mémoire vive ; par contre, au vu de la description, le bogue pourrait passer incognito pour les possesseurs d’ordinateurs bien fournis en RAM.


Un correctif est disponible pour les utilisateurs de la version 3.26 de l’environnement de bureau. Borislav Anchev – l’auteur de la vidéo de démonstration – rapporte que le bogue est également reproductible sur les builds journalières d’Ubuntu 18.04 livrées avec la version 3.28 de l’environnement de bureau. La première bêta d’Ubuntu 18.04 (Bionic Beaver) est disponible en téléchargement depuis le 13 mars ; la version finale est pour sa part attendue le 26 avril 2018, ce qui signifie que l’on est rendu aux dernières phases du développement. Il semble donc peu probable que le correctif du bogue pour la dernière mouture du système d’exploitation maintenu par Canonical soit disponible dans les temps. GNOME 3.30 est attendu pour le mois d’octobre et devrait intégrer le patch.

Sur les installations affectées, la seule façon de faire usage de l’environnement de bureau sur de longues durées est de programmer un redémarrage de ce dernier à intervalles de temps réguliers. Un Alt+F2 suivie de la pression sur la touche « r » et d’une validation avec la touche entrée devrait permettre de libérer l’espace mémoire.

Sources

Launchpad.net

Gitlab

Votre opinion

Êtes-vous un utilisateur de l’environnement de bureau GNOME Shell ? Si oui, avez-vous fait ce constat ?

Voir aussi

GNOME 3.26 est disponible en version stable : « Manchester » s'accompagne d'une amélioration de la recherche et des emojis en couleur

Une erreur dans cette actualité ? Signalez-nous-la !

Avatar de sergio_is_back
Expert confirmé https://www.developpez.com
Le 22/03/2018 à 20:42
J'ai laissé tomber GNOME (que j'aimais bien) au profit de MATE et CINNAMON depuis l'arrivée du GNOME SHELL que je ne trouve pas
du tout ergonomique.

Après, les bugs, ça arrive à tout le monde.... L'important c'est qu'ils réagissent vite et proposent un correctif efficace, mais là, je n'ai
aucun doute, ce sont de très bons développeurs...
2  0 
Avatar de
https://www.developpez.com
Le 24/04/2018 à 23:17
Citation Envoyé par Steinvikel Voir le message
Si le garbage collector n'est toujours pas implémenté en C++, n'y a t'il actuellement aucun équivalent (en terme de fiabilité) au garbage collector en C ou C++ pour ce qui est de la suppression de fils et parents ?
Le garbage collector est un choix de conception qui a son lot d'inconvénients (latence, non-déterminisme...). Pour la gestion mémoire, C++ propose plutôt le RAII et les smart-pointers (unique_ptr, shared_ptr...).
2  0 
Avatar de sergio_is_back
Expert confirmé https://www.developpez.com
Le 24/04/2018 à 9:18
Citation Envoyé par Steinvikel Voir le message

Je pose alors la question ouverte suivante :
Si le garbage collector n'est toujours pas implémenté en C++, n'y a t'il actuellement aucun équivalent (en terme de fiabilité) au garbage collector en C ou C++ pour ce qui est de la suppression de fils et parents ?
A la lecture de l'article, le problème semble se situer sur l’implémentation GJS (JavaScript bindings for GNOME) et pas au niveau C/C++ (à moins que j'ai mal lu)
1  0 
Avatar de codec_abc
Membre confirmé https://www.developpez.com
Le 24/04/2018 à 9:32
@Steinvikel : Il existe des garbage collector en C++ pour C++ (par exemple Boehm). D'après ce que je comprends c'est que celui utilsé par Gnome semble un peu particulier.
1  0 
Avatar de Dgamax
Membre averti https://www.developpez.com
Le 23/03/2018 à 12:06
j'ai exactement le même soucis avec Cinnamon, obligé de faite un petit ctrl+alt+esc pour redémarrer l'interface après une journée de taff sinno c'est des micro freeze assurés :<
0  0 
Avatar de rempo8
Membre à l'essai https://www.developpez.com
Le 03/04/2018 à 16:22
[QUOTE=sergio_is_back;10109590]J'ai laissé tomber GNOME (que j'aimais bien) au profit de MATE et CINNAMON depuis l'arrivée du GNOME SHELL que je ne trouve pas
du tout ergonomique.

J'utilise personnellement Gnome shell 3.26 avec Fedora 27, que j'apprécie tout particuliérement niveau ergonomie. (la touche "windows +3 lettres pour lancer n'importe quel programme)
Bien paramétré, avec ses raccourcis et certaines extensions, c'est une interface trés versatile utilisable, sur PC ou sur les écrans tactiles de tablettes (si Google ou Microsoft, nous le permettent)
J'utilise également Lxde ou Openbox sur des netbooks ou avec ma clé bootable PuppyLinux.

J'ai bien constaté ce bug effectivement très génant car certaines fois c'est plus quu'une fois par minute.
0  0 
Avatar de Steinvikel
Membre expert https://www.developpez.com
Le 24/04/2018 à 9:01
...Quand on supprime un objet parent il est marqué dans le Garbage Collector. Cette suppression doit normalement entrainer la suppression des objets fils qui lui sont attachés. Contrairement à JavaScript qui trace les objets fils, et par conséquent dont le Garbage Collector supprime tous les objets dépendants, le langage C ne les trace pas. Il conserve uniquement le nombre d’objets dépendants. Ce qui ne permet pas de les supprimer.
je cite un mémoire sur la "Gestion de cycle de vie des objets" en C++ qui date de 2006 :
" Certains langages comme C, CH, Ada, Pascal et bien d'autres utilisent une libération explicite de la mémoire. L'avantage majeur de cette libération par rapport au Garbage Collector est sans doute l'emploi des pointeurs, outil très important permettant un accès direct à certaines zones mémoires et une utilisation plus optimale de l'espace mémoire.
...
Puisqu'il est une extension de l'ANSI-C (on lui pardonnera cette simplification réductrice ^^' ), C++ utilise une gestion explicite de la mémoire avec les delete, new, free et malloc. Pour M. A. Ellis et B. Stroustrup (affirmation sur des publications de 1990 à 2000), la gestion de mémoire explicite via le Garbage Collector n'est pas une composante du langage C++.
Nous proposons dans notre travail de recherche un outil assurant une gestion implicite de la mémoire basé sur la programmation aspect, notamment avec l'extension AspectC++ qui est un préprocesseur pour un compilateur C++ usuel. L'idée est d'implémenter via AspectC++ des compteurs de références pour les objets nouvellement créés. Il s'agit d'attribuer un compteur de références à un objet, d'incrémenter ce compteur chaque fois qu'un autre objet crée une référence vers le premier objet et de décrémenter ce compteur chaque fois qu'une référence est supprimée. L'objet sera détruit dès que son compteur associé sera à zéro. "

Je lie cette citation à cette partie de l'article :
Le prochain passage du ramasse-miette n’est pas strictement connu, sachant qu’il n’est programmé que lorsque le « toggle reference » d’un GObject contenu dans le GJS passe d’une valeur supérieure à 1 à la valeur 1. Par conséquent, il ne survient que lorsque plusieurs GObject sont empilés.
Je pose alors la question ouverte suivante :
Si le garbage collector n'est toujours pas implémenté en C++, n'y a t'il actuellement aucun équivalent (en terme de fiabilité) au garbage collector en C ou C++ pour ce qui est de la suppression de fils et parents ?
0  0 
Avatar de Steinvikel
Membre expert https://www.developpez.com
Le 25/04/2018 à 3:51
Je vais ignorer cette joute plutôt salé, elle me paraît innaproprié.
Citation Envoyé par codec_abc Voir le message
@Steinvikel : Il existe des garbage collector en C++ pour C++ (par exemple Boehm). D'après ce que je comprends c'est que celui utilsé par Gnome semble un peu particulier.
ça me rassure... j'avais lu des choses sur différents mécanismes de suppression il y un certain temps maintenant, et le C avec ce coté manuel qui me rebute n'en n'est pas capable, cela m'étonnait que C++17 ne puisse pas générer un équivalent (s'il n'existe pas encore en natif) au garbage collector... ça serais un comble pour un langage fortement type avec autant de polymorphisme après 20 années de service. ^^'

Citation Envoyé par SimonDecoline Voir le message
Le garbage collector est un choix de conception qui a son lot d'inconvénients (latence, non-déterminisme...). Pour la gestion mémoire, C++ propose plutôt le RAII et les smart-pointers (unique_ptr, shared_ptr...).
Citation Envoyé par sergio_is_back Voir le message
A la lecture de l'article, le problème semble se situer sur l’implémentation GJS (JavaScript bindings for GNOME) et pas au niveau C/C++ (à moins que j'ai mal lu)
" Contrairement à JavaScript qui trace les objets fils, et par conséquent dont le Garbage Collector supprime tous les objets dépendants, le langage C ne les trace pas. Il conserve uniquement le nombre d’objets dépendants. Ce qui ne permet pas de les supprimer. Après la suppression, le Garbage Collector n’a aucun moyen de lier les objets. Seuls les objets directement dépendants sont supprimés. Le prochain passage du ramasse-miette n’est pas strictement connu, sachant qu’il n’est programmé que lorsque le « toggle reference » d’un GObject contenu dans le GJS passe d’une valeur supérieure à 1 à la valeur 1.. "

C'est pour moi également un peut ambigüe, mais à plusieurs on devrait y voir plus clair. : )
Je ne connais ni GObject ni GJS, mais je comprends qu'ici, JS et C sont de concert pour un but commun. De ce que j'en tire, c'est que le JS génère des objet et que l'usage du C ne permet pas (ou le code pas conçu pour ??) au garbage collector (en C ou en JS ??) de faire correctement sont boulot. C'est le C qui fout la merde en ne "traçant pas les dépendances des objets".
A moins que ça implique d'autres tenants et aboutissants que je ne devine pas durant la phase de développement de ce cas de figure (comme communiquer les dépendances de manière détourné ?).
bref. un peu flou techniquement tout ça pour moi, mais l'aspect général du problème était très intéressant. =)
0  0 
Avatar de
https://www.developpez.com
Le 24/04/2018 à 6:49
Le dernier paragraphe de l'article DVP laisse penser à un choix sans optimisation de l'écriture (implémentation) du code source...
C'est surtout gênant avec les scripts en général...

L'impact sur la mémoire RAM était le même en 32 bits et 64 bits ?
0  4