Estás en un sistema de 64 bits y no tienes instalado un soporte de biblioteca de 32 bits.
Para instalar (línea base) soporte para ejecutables de 32 bits
(si no usa sudo en su configuración, lea la nota a continuación)
La mayoría de los sistemas Linux de escritorio en la familia Fedora / Red Hat:
pkcon install glibc.i686
¿Posiblemente algunos sistemas Debian / Ubuntu de escritorio ?:
pkcon install ia32-libs
Fedora o Red Hat más reciente, CentOS:
sudo dnf install glibc.i686
RHEL más viejo, CentOS:
sudo yum install glibc.i686
Incluso más viejo RHEL, CentOS:
sudo yum install glibc.i386
Debian o Ubuntu:
sudo apt-get install ia32-libs
debería tomar la biblioteca (primera, principal) que necesita.
Una vez que tenga eso, probablemente necesitará bibliotecas de soporte
Cualquiera que necesite instalar glibc.i686
o glibc.i386
probablemente también se encontrará con otras dependencias de la biblioteca. Para identificar un paquete que proporciona una biblioteca arbitraria, puede usar
ldd /usr/bin/YOURAPPHERE
si no está seguro de que está dentro /usr/bin
, también puede recurrir
ldd $(which YOURAPPNAME)
La salida se verá así:
linux-gate.so.1 => (0xf7760000)
libpthread.so.0 => /lib/libpthread.so.0 (0xf773e000)
libSM.so.6 => not found
Compruebe si hay bibliotecas faltantes (por ejemplo, libSM.so.6
en el resultado anterior), y para cada una necesita encontrar el paquete que lo proporciona.
Comandos para encontrar el paquete por familia de distribución
Fedora / Red Hat Enterprise / CentOS:
dnf provides /usr/lib/libSM.so.6
o, en RHEL / CentOS anteriores:
yum provides /usr/lib/libSM.so.6
o, en Debian / Ubuntu:
primero, instale y descargue la base de datos para apt-file
sudo apt-get install apt-file && apt-file update
luego busca con
apt-file find libSM.so.6
Tenga en cuenta la ruta del prefijo /usr/lib
en el caso (habitual); raramente, algunas bibliotecas aún viven /lib
por razones históricas ... En los sistemas típicos de 64 bits, las bibliotecas de 32 bits viven /usr/lib
y las bibliotecas de 64 bits viven /usr/lib64
.
(Debian / Ubuntu organiza las bibliotecas de arquitectura múltiple de manera diferente).
Instalar paquetes para bibliotecas faltantes
Lo anterior debería darle un nombre de paquete, por ejemplo:
libSM-1.2.0-2.fc15.i686 : X.Org X11 SM runtime library
Repo : fedora
Matched from:
Filename : /usr/lib/libSM.so.6
En este ejemplo, el nombre del paquete es libSM
y el nombre de la versión de 32 bits del paquete eslibSM.i686
.
Luego puede instalar el paquete para obtener la biblioteca requerida utilizando pkcon
una GUI, o sudo dnf/yum/apt-get
según corresponda ... Por ej pkcon install libSM.i686
. Si es necesario, puede especificar la versión completamente. Por ej sudo dnf install ibSM-1.2.0-2.fc15.i686
.
Algunas bibliotecas tendrán un designador de "época" antes de su nombre; esto se puede omitir (los curiosos pueden leer las notas a continuación).
Notas
Advertencia
Incidentalmente, el problema que enfrenta implica que su base de datos RPM (resp. DPkg / DSelect) está dañada o que la aplicación que está intentando ejecutar no se instaló a través del administrador de paquetes. Si es nuevo en Linux, probablemente desee evitar el uso de software de fuentes distintas de su administrador de paquetes, siempre que sea posible ...
Si no usa "sudo" en su configuración
Tipo
su -c
cada vez que ves sudo
, por ejemplo,
su -c dnf install glibc.i686
Sobre el designador de época en los nombres de las bibliotecas
El designador "época" antes del nombre es un artefacto de la forma en que las bibliotecas RPM subyacentes manejan los números de versión; p.ej
2:libpng-1.2.46-1.fc16.i686 : A library of functions for manipulating PNG image format files
Repo : fedora
Matched from:
Filename : /usr/lib/libpng.so.3
Aquí, 2:
se puede omitir; solo pkcon install libpng.i686
o sudo dnf install libpng-1.2.46-1.fc16.i686
. (Esto implica vagamente algo como: en algún momento, el número de versión del libpng
paquete se revirtió y la "época" tuvo que incrementarse para asegurarse de que la versión más nueva se consideraría "más nueva" durante las actualizaciones. O sucedió algo similar. .)
Actualizado para aclarar y cubrir las diversas opciones del administrador de paquetes de forma más completa (marzo de 2016)
Acabo de encontrar el mismo problema en una máquina CentOS 6.4 de 64 bits recién instalada. Un solo comando yum arreglará esto más el 99% de problemas similares:
yum groupinstall "Bibliotecas de compatibilidad"
Prefije esto con 'sudo' o ejecútelo como root, lo que sea mejor para usted.
fuente
En general, cuando recibe un error como este, simplemente haga
entonces verás algo como:
y luego simplemente ejecuta lo siguiente como escribió BRPocock (en caso de que se preguntara cuál era la lógica ...):
fuente
Tratar
Espero que esto se aclare.
fuente
Solo quería agregar un comentario en BRPocock, pero no tengo suficientes privilegios.
Así que mi contribución fue para todos los que intentan instalar IBM Integration Toolkit desde el paquete de Integration Bus de IBM.
Cuando intenta ejecutar el comando "Installation Manager" desde la carpeta / Integration_Toolkit / IM_Linux (el archivo a ejecutar es "install"), se muestra el error en esta publicación.
Encontrará más instrucciones para solucionar este problema en la página web de esta IBM: https://www-304.ibm.com/support/docview.wss?uid=swg21459143
Espero que esto ayude a cualquiera que intente instalarlo.
fuente
sudo yum install fontconfig freetype libfreetype.so.6 libfontconfig.so.1 libstdc ++. so.6
fuente
Agregaría que para Debian necesita al menos un compilador en el sistema (de acuerdo con las bibliotecas Debian Stretch y Jessie de 32 bits ).
Lo instalé
apt-get install -y gcc-multilib
para ejecutar un archivo ejecutable de 32 bits en mi contenedor docker basado en debian: jessie.fuente
También puede instalar OpenJDK 32-bit (
.i686
) en su lugar. Según mi prueba, se instalará y funciona sin problemas.Nota:
Ver aquí para más detalles.
fuente