web-dev-qa-db-fra.com

Eclipse utilisant un processeur élevé après la mise à niveau vers Ubuntu 16.04

J'ai récemment mis à niveau l'un de mes systèmes vers la version 16.04 et l'une des nombreuses choses qui ont cessé de fonctionner correctement est l'IDE Eclipse. Il utilise maintenant environ 60% du processeur, même lorsque la fenêtre est réduite au minimum, est très lent et certaines choses ne répondent même pas.

Après cette réponse sur Stack Exchange , j'ai recherché un peu quel thread est à l'origine de ce comportement:

$ ps -mo 'pid lwp stime time pcpu' -C Java
  PID   LWP STIME     TIME %CPU
14475     - 09:55 00:02:05 91.6
    - 14475 09:55 00:00:00  0.0
    - 14476 09:55 00:01:14 54.6

Traduire en hexadécimal:

$ printf "0x%x\n" 14476
0x388c

Dans les journaux, j'ai trouvé ce qui suit concernant ce fil:

"main" #1 prio=6 os_prio=0 tid=0x00007f10c000a000 nid=0x388c runnable [0x00007f10c8c62000]
   Java.lang.Thread.State: RUNNABLE
    at org.Eclipse.swt.internal.gtk.OS._gtk_main_do_event(Native Method)
    at org.Eclipse.swt.internal.gtk.OS.gtk_main_do_event(OS.Java:9326)
    at org.Eclipse.swt.widgets.Display.eventProc(Display.Java:1225)
    at org.Eclipse.swt.internal.gtk.OS._g_main_context_iteration(Native Method)
    at org.Eclipse.swt.internal.gtk.OS.g_main_context_iteration(OS.Java:2435)
    at org.Eclipse.swt.widgets.Display.readAndDispatch(Display.Java:3428)
    at org.Eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$4.run(PartRenderingEngine.Java:1127)
    at org.Eclipse.core.databinding.observable.Realm.runWithDefault(Realm.Java:337)
    at org.Eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.Java:1018)
    at org.Eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.Java:156)
    at org.Eclipse.ui.internal.Workbench$5.run(Workbench.Java:694)
    at org.Eclipse.core.databinding.observable.Realm.runWithDefault(Realm.Java:337)
    at org.Eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.Java:606)
    at org.Eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.Java:150)
    at org.Eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.Java:139)
    at org.Eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.Java:196)
    at org.Eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.Java:134)
    at org.Eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.Java:104)
    at org.Eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.Java:380)
    at org.Eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.Java:235)
    at Sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at Sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.Java:62)
    at Sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.Java:43)
    at Java.lang.reflect.Method.invoke(Method.Java:483)
    at org.Eclipse.equinox.launcher.Main.invokeFramework(Main.Java:669)
    at org.Eclipse.equinox.launcher.Main.basicRun(Main.Java:608)
    at org.Eclipse.equinox.launcher.Main.run(Main.Java:1515)
    at org.Eclipse.equinox.launcher.Main.main(Main.Java:1488)

J'ai également essayé d'augmenter la mémoire disponible, mais cela ne corrige rien. Le contenu de mon fichier Eclipse.ini:

-startup
plugins/org.Eclipse.equinox.launcher_1.3.100.v20150511-1540.jar
--launcher.library
plugins/org.Eclipse.equinox.launcher.gtk.linux.x86_64_1.1.300.v20150602-1417
-product
org.Eclipse.epp.package.jee.product
--launcher.defaultAction
openFile
-showsplash
org.Eclipse.platform
--launcher.XXMaxPermSize
512m
--launcher.defaultAction
openFile
--launcher.appendVmargs
-vmargs
-Dosgi.requiredJavaVersion=1.7
-XX:MaxPermSize=256m
-Xms512m
-Xmx1024m

J'ai un nombre relativement petit de plug-ins installés: TeXlipse, StatET et Papyrus. Cette même configuration avec la même machine virtuelle Java (1.8.0_11) fonctionne parfaitement sur Ubuntu 14.04

6
Luís de Sousa

C'est un bug lié à GTK3. Pour le corriger, il est nécessaire de forcer Eclipse à utiliser GTK2. J'ai remarqué une diminution de la consommation de processeur, mais la consommation reste importante.

Ajoutez ces 2 lignes avant la ligne --launcher.appendVmargs dans Eclipse.ini:

--launcher.GTK_version
2

Plus d'informations à:

7
user547995