Me gustaría saber qué bibliotecas utilizan los ejecutables en mi sistema. Más específicamente, me gustaría clasificar qué bibliotecas se usan más, junto con los binarios que las usan. ¿Cómo puedo hacer esto?
linux
shared-libraries
Alan Szlosek
fuente
fuente
dlopen
.Respuestas:
ldd
para enumerar bibliotecas compartidas para cada ejecutable.Para encontrar la respuesta para todos los ejecutables en el directorio "/ bin":
Cambie "/ bin" arriba a "/" para buscar en todos los directorios.
La salida (solo para el directorio / bin) se verá así:
Editar - Se eliminó "grep -P"
fuente
ldd -v
ldd
realidad ejecuta el ejecutable con una variable de entorno especial, y el vinculador dinámico de Linux reconoce este indicador y simplemente genera las bibliotecas en lugar de ejecutar el ejecutable. Mira la fuente paraldd
; en mi sistema, es un script bash. Si el ejecutable está vinculado estáticamente y usa syscalls, y especifica un cargador diferente, puede hacer cosas malignas arbitrarias. Así que no lo useldd
en un ejecutable en el que no confía.No tenía ldd en mi cadena de herramientas ARM, así que usé objdump:
$ (CROSS_COMPILE) objdump -p
Por ejemplo:
fuente
ldd
lo que no debería usarse en ejecutables no confiables.obbjdump -p
muestra información adicional como laRPATH
, que puede ser útil al investigar problemas de vinculación dinámica con su ejecutable.musl-gcc
regularmente produce binarios de manera que invocarldd
el binario simplemente ejecuta el binario , por lo que hoy en día me recuerdan cuán inseguroldd
es).En Linux uso:
Esto funciona mejor que
ldd
cuando el ejecutable usa un cargador no predeterminadofuente
para saber qué bibliotecas usa un binario, use ldd
Tendría que escribir un pequeño script de shell para llegar a su desglose de todo el sistema.
fuente
Verificar las dependencias de la biblioteca compartida de un programa ejecutable
Para averiguar de qué bibliotecas depende un ejecutable en particular, puede usar el comando ldd. Este comando invoca el vinculador dinámico para descubrir las dependencias de la biblioteca de un ejecutable.
> $ ldd / ruta / a / programa
Tenga en cuenta que NO se recomienda ejecutar ldd con ningún ejecutable de terceros que no sea de confianza porque algunas versiones de ldd pueden invocar directamente el ejecutable para identificar sus dependencias de biblioteca, lo que puede ser un riesgo de seguridad.
En cambio, una forma más segura de mostrar las dependencias de la biblioteca de una aplicación binaria desconocida es utilizar el siguiente comando.
para más información
fuente
readelf -d
recursividadredelf -d
produce una salida similar a laobjdump -p
que se mencionó en: https://stackoverflow.com/a/15520982/895245Pero tenga en cuenta que las bibliotecas dinámicas pueden depender de otras bibliotecas dinámicas, para que tenga que recurrir.
Ejemplo:
Muestra de salida:
Luego:
Elija uno y repita:
Salida de muestra:
Y así.
/proc/<pid>/maps
para ejecutar procesosEsto es útil para encontrar todas las bibliotecas que se utilizan actualmente al ejecutar ejecutables. P.ej:
muestra todas las dependencias dinámicas cargadas actualmente de
init
(PID1
):Este método también muestra bibliotecas abiertas con
dlopen
, probadas con esta configuración mínima pirateada con unsleep(1000)
en Ubuntu 18.04.Ver también: /superuser/310199/see-currently-loaded-shared-objects-in-linux/1243089
fuente
En OS X por defecto no hay
ldd
,objdump
olsof
. Como alternativa, intenteotool -L
:En este ejemplo, el uso de
which openssl
rellenos en la ruta totalmente calificada para el entorno de usuario ejecutable y actual dado.fuente
En el sistema UNIX, suponga que el nombre binario (ejecutable) es test. Luego usamos el siguiente comando para enumerar las bibliotecas utilizadas en la prueba.
fuente
Con
ldd
usted puede obtener las bibliotecas que usan las herramientas. Para clasificar el uso de bibliotecas para un conjunto de herramientas, puede usar algo como el siguiente comando.(Aquí se
sed
eliminan todas las líneas que no comienzan con una pestaña y se filtran solo las bibliotecas reales. Consort | uniq -c
cada biblioteca se obtiene un recuento que indica la cantidad de veces que ocurrió).Es posible que desee agregar
sort -g
al final para obtener las bibliotecas en orden de uso.Tenga en cuenta que probablemente obtenga líneas dos líneas que no sean de biblioteca con el comando anterior. Uno de los ejecutables estáticos ("no un ejecutable dinámico") y uno sin ninguna biblioteca. Este último es el resultado de
linux-gate.so.1
que no es una biblioteca en su sistema de archivos sino una "suministrada" por el núcleo.fuente
Una opción más puede ser simplemente leer el archivo ubicado en
Por ejemplo, si el ID del proceso es 2601, el comando es
Y la salida es como
fuente
en paquetes de impresión ubuntu relacionados con un ejecutable
fuente
Encontré esta publicación muy útil ya que necesitaba investigar las dependencias de una biblioteca suministrada por terceros (rutas de ejecución de 32 contra 64 bits).
Creé un script de bash recurrente de preguntas y respuestas basado en la sugerencia 'readelf -d' en una distribución RHEL 6.
Es muy básico y probará cada dependencia cada vez, incluso si es posible que se haya probado antes (es decir, muy detallado). La salida es muy básica también.
redirigir la salida a un archivo y grep para 'encontrado' o 'fallido'
Use y modifique, bajo su propio riesgo, por supuesto, como lo desee.
fuente