org.eclipse.swt.SWTError: Não há mais identificadores [gtk_init_check () falhou] durante a execução do eclipse no ubuntu

24

Eu estava tentando abrir o eclipse na minha VM do ubuntu com o comando abaixo .. E assim que faço isso, sempre recebo a exceção abaixo -

ubuntu@username-dyn-vm1-48493:~$ eclipse
Eclipse:
An error has occurred. See the log file
/home/ubuntu/.eclipse/org.eclipse.platform_3.8_155965261/configuration/1381367113197.log.

então, quando fui para esse arquivo de log específico, é isso que posso ver no log -

ubuntu@username-dyn-vm1-48493:~$ more /home/ubuntu/.eclipse/org.eclipse.platform_3.8_155965261/configuration/1381367113197.log
!SESSION 2013-10-10 01:05:13.088 -----------------------------------------------
eclipse.buildId=debbuild
java.version=1.7.0_25
java.vendor=Oracle Corporation
BootLoader constants: OS=linux, ARCH=x86_64, WS=gtk, NL=en_US
Command-line arguments:  -os linux -ws gtk -arch x86_64

!ENTRY org.eclipse.osgi 4 0 2013-10-10 01:05:17.555
!MESSAGE Application error
!STACK 1
org.eclipse.swt.SWTError: No more handles [gtk_init_check() failed]
        at org.eclipse.swt.SWT.error(SWT.java:4387)
        at org.eclipse.swt.widgets.Display.createDisplay(Display.java:914)
        at org.eclipse.swt.widgets.Display.create(Display.java:900)
        at org.eclipse.swt.graphics.Device.<init>(Device.java:156)
        at org.eclipse.swt.widgets.Display.<init>(Display.java:498)
        at org.eclipse.swt.widgets.Display.<init>(Display.java:489)
        at org.eclipse.ui.internal.Workbench.createDisplay(Workbench.java:716)
        at org.eclipse.ui.PlatformUI.createDisplay(PlatformUI.java:161)
        at org.eclipse.ui.internal.ide.application.IDEApplication.createDisplay(IDEApplication.java:154)
        at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:96)
        at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196)
        at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110)
        at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79)
        at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:353)
        at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:180)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:606)
        at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:629)
        at org.eclipse.equinox.launcher.Main.basicRun(Main.java:584)
        at org.eclipse.equinox.launcher.Main.run(Main.java:1438)
        at org.eclipse.equinox.launcher.Main.main(Main.java:1414)

Alguém sabe o que aconteceu de errado? Ou o que devo fazer para corrigir esse problema? Obrigado..

Atualizar:-

Detalhes da versão abaixo -

ubuntu@username-dyn-vm1-48493:~$ dpkg -l libgtk[0-9]* | grep ^i
ii  libgtk2.0-0:amd64                   2.24.17-0ubuntu2                    amd64        GTK+ graphical user interface library
ii  libgtk2.0-bin                       2.24.17-0ubuntu2                    amd64        programs for the GTK+ graphical user interface library
ii  libgtk2.0-common                    2.24.17-0ubuntu2                    all          common files for the GTK+ graphical user interface library
SSH
fonte
estranhamente, tive um problema semelhante ao tentar executar o dbeaver. Eu tive que sair do tmux primeiro para que ele funcionasse corretamente. Odd
matchew 19/11

Respostas:

4

Eu acho que isso é um problema com o gtk. Verifique qual versão está instalada.

dpkg -l libgtk[0-9]* | grep ^i

Se não estiver instalado ou a versão estiver incorreta, execute um sudo apt-get install gtkou execute um sudo apt-get update.

EDITAR

O problema era que o SSH estava usando o SSH para se conectar remotamente a uma VM Linux e não tinha um X-Server configurado no Windows e não tinha o encaminhamento do X11 ativado. Depois de corrigir isso, o OP não deve ter nenhum problema ao executar o Eclipse.

Jeight
fonte
Atualizei minha pergunta com as informações reais da versão. Deixe-me saber se ainda preciso fazer a atualização?
SSH
Bem, existe uma versão 3.8 para o gtk por aí, então não poderia machucar atualizar para a versão mais recente.
Jeight 10/10
3
Entendo .. Mas quando eu atualizei, é isso que eu tenho - sudo apt-get install gtk Reading package lists... Done Building dependency tree Reading state information... Done E: Unable to locate package gtk . Não é capaz de localizar o pacote gtk de alguma forma .. Alguma idéia?
SSH
O que você ganha quando faz um sudo apt-cache search gtk?
Jeight 10/10
Ele fez muitas coisas .. E um monte de coisas foi impresso na minha tela. Não sabe ao certo o que você pode estar interessado?
SSH
10

Este também é o erro que você obtém se tentar iniciar o Eclipse pelo ssh sem encaminhar o acesso ao X. ssh -X user@hostOu seja, você esqueceu de executar ou esqueceu de incluir ForwardX11 yesna sua ~/.ssh/configentrada para o servidor.

Estou adicionando esta resposta a qualquer pessoa que possa encontrar essa pergunta em uma pesquisa no Google, embora tecnicamente a OP esteja perguntando sobre um caso de VM.

user837451
fonte
@isakbob Obrigado, isso resolveu o meu problema. Não foi possível encontrar a resposta em nenhum outro lugar. Pode querer publicá-lo como resposta.
Mateus
@ Matthew, não acho que meu comentário justifique outra resposta. Acabei de editar esta resposta para incluir meu comentário.
isakbob 20/11
6

Além disso, isso também pode ser causado pelo fato de o aplicativo não ter a autorização correta para exibir no controle remoto X server. Isso normalmente acontece quando você efetua login na sessão ssh como um usuário e executa um comando como outro usuário para lançar um aplicativo GUI. Por exemplo, quando você efetua login no servidor remoto e executa um sudocomando. Para resolver esse problema, você precisará obter o cookie mágico do usuário que está efetuando login e importar o cookie para o usuário que está executando o comando.

Como o usuário que está efetuando login no servidor ao qual tem autoridade para exibir X, execute:

xauth extract cookie_file $DISPLAY

Então, como o usuário tentando executar o gui: xauthmesclarcookie_file

Depois que o cookie é importado para o usuário. Xauthorityarquivo, você poderá executar a GUI.

user100341
fonte
Também é possível que o host simplesmente não tenha exibição. Nesse caso, você pode instalar o Xvfb e criar um buffer de quadro virtual com os comandos: Xvfb :1 -ac -screen 0 1024x768x8 & export DISPLAY=:1 source
Staszek
3

Encontrei um problema semelhante ao instalar o IBM Installation Manager (IBMIM) no CentOS 6.x e resolvi o problema instalando vários pacotes que foram a causa desse erro idêntico:

$ sudo /opt/IBM/InstallationManager/eclipse/IBMIM \
       -record /root/was8nd_v85_install.xml \
       -skipInstall /tmp/was8nd

00:00.46 ERROR [main] org.eclipse.equinox.log.internal.ExtendedLogReaderServiceFactory safeLogged
  Application error
  org.eclipse.swt.SWTError: No more handles [gtk_init_check() failed]
  org.eclipse.swt.SWTError: No more handles [gtk_init_check() failed]
    at org.eclipse.swt.SWT.error(SWT.java:4387)
    at org.eclipse.swt.widgets.Display.createDisplay(Display.java:913)
    at org.eclipse.swt.widgets.Display.create(Display.java:899)
    at org.eclipse.swt.graphics.Device.<init>(Device.java:156)
    ...
IBMIM:
An error has occurred. See the log file
/opt/IBM/InstallationManager/eclipse/configuration/1457978953529.log.

Solução parte 1 - pacotes ausentes

$ sudo yum install \
   gtk2            \
   libXtst         \
   gnome-desktop   \
   xorg-x11-xauth  \
   dejavu-lgc-sans-fonts 

Algo semelhante a isso também poderia ter sido feito no Ubuntu.

Solução parte 2 - xauth

O outro problema que surgirá é que você está tentando executar o instalador do IBMIM (baseado em Eclipse) como o usuário raiz via sudo. Ao fazer isso, você obtém o erro acima do aplicativo do instalador:

00:00.46 ERROR [main] org.eclipse.equinox.log.internal.ExtendedLogReaderServiceFactory safeLogged
  Application error
  org.eclipse.swt.SWTError: No more handles [gtk_init_check() failed]
  org.eclipse.swt.SWTError: No more handles [gtk_init_check() failed]

Para contornar isso, você precisará xauth addadicionar o usuário inicial que efetuou login no $HOME/.Xauthorityarquivo raiz .

Como usuário1:

$ xauth list
ip-10-10-10-10.us-west-1.compute.internal/unix:10  MIT-MAGIC-COOKIE-1  6902e8c245a01ca50XXXXXXXXXXXXXXXX

Então como root:

$ xauth add ip-10-10-10-10.us-west-1.compute.internal/unix:10  MIT-MAGIC-COOKIE-1  6902e8c245a01ca50XXXXXXXXXXXXXXXX
xauth:  creating new authority file /root/.Xauthority

$ xauth list
ip-10-10-10-10.us-west-1.compute.internal/unix:10  MIT-MAGIC-COOKIE-1  6902e8c245a01ca50XXXXXXXXXXXXXXXX

Referências

slm
fonte
0

Se você estiver executando um Linux com o Gnome:

Inicie um Gnome com uma sessão do Xorg:

Depois de clicar em seu nome de usuário no GDM (o gerenciador de boas-vindas / login), clique em seu nome de usuário e, antes de digitar a senha, clique na pequena engrenagem e selecione Gnome with Xorg e digite sua senha.

Warhansen
fonte
-1

Depois de desativar o IPV6 na máquina remota, recebi a mensagem org.eclipse.swt.SWTError: No more handles [gtk_init_check() failed]ao usar o comando ssh -X ub-dev /opt/eclipse/eclipse. Para corrigir no Ubuntu 14.04, adicionei line AddressFamily inetao arquivo /etc/ssh/sshd_confige reiniciei o ssh sudo service ssh restart.

PLA
fonte