Gentoolkit

Matt Butcher  Author
John P. Davis  Editor
Erwin  Editor
Shyam Mani  Editor
Xavier Neys  Editor
Karl Trygve  Editor
José Luis Rivero  Editor
Joshua Saddler  Editor
Enrique Barbeito García  Traductor

Actualizado 25 de junio, 2007

1.  Introducción

¿Qué es Gentoolkit?

Gentoo es una distribución única y presenta algunas complejidades que simplemente no existen en otras distribuciones. A medida que desarrolladores y colaboradores de Gentoo descubrían algunas de estas complejidades, escribieron herramientas para ayudar a usuarios y administradores a trabajar entre ellas. Muchas de estas herramientas han sido escritas para el proyecto Gentoo y se incluyen en el paquete app-portage/gentoolkit.

Nota: En la actualidad existen dos versiones de gentoolkit: app-portage/gentoolkit y app-portage/gentoolkit-dev. Mientras que el primero contiene scripts de administración, el último contiene scripts específicos para reforzar el desarrollo en Gentoo. Si es desarrollador, puede incluir sus scripts en gentoolkit-dev poniéndose en contacto con el responsable del mantenimiento de Gentoolkit. Este documento únicamente habla de gentoolkit.

Gentoolkit contiene un gran grupo de herramientas útiles para ayudar a administrar los paquetes y seguirle la pista a lo que ocurre en su sistema. La mayoría de usuarios --particularmente aquellos que a menudo actualizan sus sistemas-- se beneficiarán de tener gentoolkit instalado.

Instalación

Como en cualquier paquete de Gentoo, la instalación es sólo un simple emerge.

Listado de Código 1.1: Obtener gentoolkit

# emerge gentoolkit

Nota: Muchas de las herramientas en gentoolkit revelan información importante sobre el sistema o requieren permisos de usuario root. Por esa razón, algunos de los programas sólo pueden ser ejecutados (o sólo funcionan correctamente) si se ejecutan con un usuario con permisos de root.

Encontrar documentación

Cualquier documentación que un programa pudiera tener (exceptuando las páginas man) se encuentra en /usr/share/doc/gentoolkit-[versión]/[nombre-del-programa]/.

2.  equery

Introducción

equery es una herramienta que proporciona muchísima información acerca de los paquetes de su sistema y más. equery --help le da el listado completo de opciones.

Nota: No todas las características listadas por equery --help han sido implementadas todavía. Las que no, están claramente marcadas. También verá que cada comando tiene una opción reducida; p.e. b en vez de belongs.

Nota: Sea consciente de que equery actualmente cambia el formato de la salida si ésta es enviada a través de una tubería. Este tipo de formato está pensado para facilitar a las herramientas el análisis de la salida, aunque también puede deshabilitarlo añadiendo la opción --no-pipe. Si escribe scripts que emplean equery, debería ser cuidadoso con esto.

Averiguar el paquete del que proviene un fichero

equery también proporciona la funcionalidad de encontrar el paquete del cual proviene un fichero empleando para ello el comando belongs (o solamente b).

Listado de Código 2.1: Averiguar el ebuild que instaló un fichero dado

# equery belongs /usr/bin/audacious
[ Searching for file(s) /usr/bin/audacious in *... ]
media-sound/audacious-1.1.2 (/usr/bin/audacious)

Utilizando la opción -f, puede buscar paquetes con los ficheros que coincidan con cualquier expresión regular. La opción -e es útil para detener su búsqueda inmediatamente cuando se encuentre una coincidencia.

Comprobar la integridad de los paquetes

A veces es útil comprobar la integridad de un paquete. equery puede verificar sumas md5 así como marcas de tiempo para indicar cuándo un paquete pudo haber sido corrompido, reemplazado o borrado.

Listado de Código 2.2: Comprobar la integridad de un paquete

# equery check gentoolkit
[ Checking app-portage/gentoolkit-0.2.0 ]
 * 54 out of 54 files good

Por favor, dese cuenta de que si cambia ficheros de configuración después de una instalación, éstos serán reportados como "not good"

Lista de todos los paquetes que dependen de ...

equery es capaz de listar todas las dependencias directas relacionadas con un paquete. La función que debemos utilizar para ello es depends y es tan fácil cómo:

Listado de Código 2.3: Buscar paquetes que dependan de pygtk

# equery depends pygtk
[ Searching for packages depending on pygtk... ]
app-office/dia-0.93
dev-python/gnome-python-2.0.0-r1
gnome-extra/gdesklets-core-0.26.2
media-gfx/gimp-2.0.4
x11-libs/vte-0.11.11-r1

Gráficos de dependencias

equery es capaz de darnos un gráfico de dependencias para un determinado paquete. Este gráfico ofrece un listado de todos los paquetes que tienen dependencias directas e indirectas con el paquete en cuestión.

Listado de Código 2.4: El gráfico de dependencias para cdrtools

# equery depgraph cdrtools
Displaying dependencies for app-cdr/cdrtools-2.01_alpha37
`-- app-cdr/cdrtools-2.01_alpha37
 `-- sys-libs/glibc-2.3.4.20040808 (virtual/libc)
  `-- sys-kernel/linux-headers-2.4.22 (virtual/os-headers)
   `-- sys-apps/baselayout-1.10.4
    `-- sys-apps/sysvinit-2.85-r1
     `-- sys-apps/gawk-3.1.3-r1
      `-- sys-apps/util-linux-2.12-r4
          `-- sys-apps/sed-4.0.9
        `-- sys-libs/ncurses-5.4-r4
            `-- sys-apps/pam-login-3.14
            `-- sys-libs/pam-0.77-r1
                 `-- sys-libs/cracklib-2.7-r10
               `-- sys-apps/miscfiles-1.3-r1
              `-- app-arch/gzip-1.3.5-r1
              `-- sys-apps/portage-2.0.50-r10

Por ejemplo, mientras que glibc es una dependencia directa para cdrtools, los linux-headers le son una dependencia indirecta. Observe que la salida también incluye información sobre paquetes virtuales. En el ejemplo de arriba, cdrtools está realmente escrito para requerir virtual/libc y no sys-libs/glibc pero en el sistema dado en el ejemplo sys-libs/glibc proporciona virtual/libc.

Listar los ficheros que pertenezcan a un ebuild

equery puede listar los ficheros que pertenecen a un ebuild instalado. Si no conozco los ficheros que Gentoolkit ha instalado en el sistema, usaré equery para mostrarlos.

Listado de Código 2.5: Listar los ficheros

# equery files gentoolkit
[ Searching for packages matching gentoolkit... ]
app-portage/gentoolkit-0.2.0
* Contents of app-portage/gentoolkit-0.2.0:
/usr
/usr/bin
/usr/bin/equery
/usr/bin/etcat
/usr/bin/euse
/usr/bin/glsa-check
/usr/bin/qpkg
/usr/bin/revdep-rebuild
/usr/lib
/usr/lib/gentoolkit
/usr/lib/gentoolkit/pym
/usr/lib/gentoolkit/pym/gentoolkit
/usr/lib/gentoolkit/pym/gentoolkit/__init__.py
/usr/lib/gentoolkit/pym/gentoolkit/gentoolkit.py
/usr/lib/gentoolkit/pym/gentoolkit/pprinter.py
/usr/lib/gentoolkit/pym/glsa.py
/usr/sbin
/usr/share
/usr/share/doc
/usr/share/doc/gentoolkit-0.2.0_pre10

[...]

El comando files de equery proporciona algunas opciones para modificar la salida. Puede encontrarlas todas en la página man deequery.

Buscar paquetes que usan un parámetro USE específico

Si quiere encontrar los paquetes de su sistema que hacen uso de un parámetro USE en concreto, equery tiene para ello la función hasuse:

Listado de Código 2.6: Buscar paquetes que usan el parámetro USE firefox

# equery hasuse firefox
[ Searching for USE flag firefox in all categories among: ]
 * installed packages
[I--] [  ] dev-python/gnome-python-extras-2.14.0-r1 (0)
[I--] [  ] media-video/totem-2.16.4 (0)

Listar paquetes

equery tiene una potente característica para listar paquetes que pertenecen a nuestro sistema, a portage o incluso en el overlay (directorio extensión de portage). Probemos ésto:

Listado de Código 2.7: Listar paquetes con equery

# equery list gentoolkit
[ Searching for package 'gentoolkit' in all categories among: ]
 * installed packages
[I--] [  ] app-portage/gentoolkit-0.2.0 (0)

La consulta estándar buscará nuestros paquetes instalados para el nombre dado. Si encuentra algo, la siguiente información será mostrada: la localización del paquete entre el primer par de corchetes (I para paquetes instalados, P para Portage, O para Overlay), las posibles máscaras entre el segundo par (~ para keyword, - para arquitectura o M para hard masked), luego la categoría, el nombre completo y, por último, el slot en el que el paquete está almacenado.

Otro ejemplo, esta vez vamos a usar las opciones locales en orden para buscar paquetes en nuestro árbol portage y overlay.

Listado de Código 2.8: Empleando opciones locales con equery

# equery list -p -o vim
[ Searching for package 'vim' in all categories among: ]
 * installed packages
[I--] [  ] app-editors/vim-6.3-r4 (0)
 * Portage tree (/usr/portage)
[-P-] [M~] app-editors/vim-7.0_alpha20050126 (0)
[-P-] [M~] app-editors/vim-7.0_alpha20050201 (0)
[-P-] [  ] app-editors/vim-6.3-r2 (0)
[-P-] [M~] app-editors/vim-7.0_alpha20050122 (0)
[-P-] [M~] app-editors/vim-core-7.0_alpha20050126 (0)
[-P-] [  ] app-editors/vim-core-6.3-r3 (0)
[-P-] [M~] app-editors/vim-core-7.0_alpha20050122 (0)
[-P-] [M~] app-editors/vim-core-7.0_alpha20050201 (0)
[-P-] [  ] app-editors/vim-core-6.3-r4 (0)
 * overlay tree (/opt/ebuilds)

Averiguar el tamaño de los paquetes

¿Alguna vez ha tenido la curiosidad de averiguar cuánto espacio ocupa un paquete concreto? Desde que un paquete puede tener sus archivos repartidos en más de un directorio, puede que el habitual du -hc no le proporcione una cifra correcta. No se preocupe, ¡equery viene al rescate!

Listado de Código 2.9: Tamaño del paquete

# equery size openoffice-bin
* app-office/openoffice-bin-1.1.2
     Total Files : 2908
     Total Size  : 223353.31 KiB

Como puede ver, equery escribe el espacio total ocupado en kilobytes y además lista la cantidad de archivos que tiene el paquete.

Listado de parámetros USE por paquete

equery puede usarse para darnos información acerca de qué parámetros USE están siendo usados por un paquete en concreto. También nos dice cuáles son nuestros parámetros USE actuales para un paquete y, además, cuáles están disponibles para ese paquete.

Listado de Código 2.10: Activar y desactivar parámetros USE

# equery uses wireshark
[ Colour Code : set unset ]
[ Legend    : (U) Col 1 - Current USE flags        ]
[           : (I) Col 2 - Installed With USE flags ]

 U I [ Found these USE variables in : net-analyzer/wireshark-0.99.4 ]
 - - adns      : Adds support for the adns DNS client library
 + + gtk       : Adds support for x11-libs/gtk+ (The GIMP Toolkit)
 - - ipv6      : Adds support for IP version 6
 - - kerberos  : Adds kerberos support
 - - portaudio : Adds support for the crossplatform portaudio audio API
 - - selinux   : !!internal use only!! Security Enhanced Linux support, this must be set by the selinux profile or breakage will occur
 - - snmp      : Adds support for the Simple Network Management Protocol if available
 + + ssl       : Adds support for Secure Socket Layer connections
 - - threads   : Adds threads support for various packages. Usually pthreads

He instalado wireshark con sólo los parámetros gtk y ssl activados, aunque hay varios otros disponibles para wireshark. Para más información sobre los parámetros USE, por favor consulte el capítulo Parámetros USE del Manual Gentoo.

¿Dónde está el ebuild?

Podemos averiguar qué ebuild está siendo utilizado por un paquete en concreto con equery. Esto se hace con el comando equery which, que muestra la ruta completa del ebuild.

Listado de Código 2.11: Mostrar la ruta del ebuild

# equery which cdrtools
/usr/portage/app-cdr/cdrtools/cdrtools-2.01_alpha37.ebuild

3.  euse

Introducción

euse es una herramienta para ver, activar y desactivar los parámetros USE en varios lugares. Para más información acerca de los parámetros USE, por favor consulte el documento Parámetros USE. Por favor, use euse -h para ver la ayuda completa y todas las opciones.

Ver, activar y desactivar los parámetros USE

El comando euse -a lee y muestra los actuales parámetros USE activos.

Nota: Hay 5 "columnas" que euse utiliza para mostrar si un parámetro está activo/inactivo y donde se ha activado cada uno de ellos. Las columnas están como sigue: +/-, activado en el Entorno, activado en make.Conf, activado en make.Defaults y activado en make.Globals. La salida se asemeja a [+ECDG].

Listado de Código 3.1: Mostrar todos los parámetros USE activos

# euse -a
X                   [+ CD ]
aalib               [+    ]
acpi                [+ C  ]
alsa                [+ C  ]
apache2             [+ C  ]
apm                 [+  D ]
avi                 [+  D ]
berkdb              [+  D ]
bitmap-fonts        [+  D ]
bonobo              [+    ]
cdr                 [+ C  ]
crypt               [+ CD ]
cscope              [+ C  ]
cups                [+ CD ]
curl                [+    ]
emboss              [+  D ]
encode              [+  D ]
esd                 [+    ]
fam                 [+    ]
fbcon               [+ C  ]
firefox             [+ C  ]
font-server         [+  D ]
foomaticdb          [+  D ]
fortran             [+  D ]
gd                  [+ C  ]
gdbm                [+  D ]
gif                 [+ CD ]
gimpprint           [+ C  ]
gnome               [+ CD ]
gphoto2             [+    ]
gpm                 [+ CD ]
gstreamer           [+ C  ]
gtk                 [+  D ]
gtkhtml             [+ C  ]
guile               [+    ]
imagemagick         [+    ]
imlib               [+ CD ]
innodb              [+    ]
ipv6                [+  D ]
javascript          [+ C  ]
jpeg                [+ CD ]
kde                 [+  D ]
ldap                [+    ]
libg++              [+ CD ]
libwww              [+ CD ]
mad                 [+ CD ]
mbox                [+ C  ]
md5sum              [+ C  ]
mikmod              [+ CD ]
mmx                 [+ C  ]
motif               [+ CD ]
mp3                 [+    ]
mpeg                [+ CD ]
mpeg4               [+ C  ]
mysql               [+ C  ]
ncurses             [+ CD ]
nls                 [+  D ]
nvidia              [+ C  ]
odbc                [+    ]
offensive           [+    ]
ogg                 [+ CD ]
opengl              [+ CD ]
oss                 [+  D ]
pam                 [+ CD ]
pdflib              [+ CD ]
perl                [+ CD ]
png                 [+ CD ]
python              [+ CD ]
qt                  [+  D ]
quicktime           [+ CD ]
readline            [+ CD ]
ruby                [+    ]
sdl                 [+ CD ]
slang               [+  D ]
spell               [+ CD ]
sse                 [+ C  ]
ssl                 [+ CD ]
svga                [+ CD ]
tcltk               [+ C  ]
tcpd                [+  D ]
tiff                [+ C  ]
truetype            [+ CD ]
usb                 [+ C  ]
vanilla             [+ C  ]
x86                 [+ C  ]
xml                 [+    ]
xosd                [+ C  ]
xv                  [+ CD ]
xvid                [+ C  ]
zlib                [+ CD ]

Del mismo modo, puede usar el comando euse -a -g para ver sólo los parámetros USE globales activados. El comando euse -a -l hace lo mismo para los parámetros USE locales activados. -g & -l son subopciones de euse y requieren de una opción anterior a ellos (como -a) para funcionar correctamente.

Listado de Código 3.2: Mostrar los parámetros USE locales activados

# euse -a -l
bitmap-fonts        [+  D ]
font-server         [+  D ]
fortran             [+  D ]
gimpprint           [+ C  ]
md5sum              [+ C  ]
mpeg4               [+ C  ]
nvidia              [+ C  ]
offensive           [+    ]
truetype            [+ CD ]

También podemos usar euse para activar o desactivar parámetros use. Los comandos empleados para ello son euse -E flagname (habilita un parámetro) y euse -D flagname (inhabilita un parámetro).

Aviso: No utilice los comandos euse -E y euse -D por ellos mismos (sin un parámetro). Sino activará/desactivará TODOS los parámetros USE en /etc/make.conf. Aunque se mantenga una copia de seguridad en /etc/make.conf.euse_backup, por favor tenga cuidado a la hora de usar euse -E o euse -D.

Listado de Código 3.3: Activar y desactivar parámetros USE

(Habilitar un parámetro USE)
#  euse -E 3dfx
/etc/make.conf was modified, a backup copy has been placed at /etc/make.conf.euse_backup

(/etc/make.conf después de ejecutar el comando)
USE="alsa acpi apache2 -arts cups cdr crypt cscope -doc fbcon \
     firefox gd gif gimpprint gnome gpm gstreamer gtkhtml imlib \
     innodb -java javascript jpeg libg++ libwww mad mbox md5sum \
     mikmod mmx motif mpeg mpeg4 mysql ncurses nvidia \
     ogg odbc offensive opengl pam pdflib perl png python \
     quicktime readline sdl spell sse ssl svga tcltk tiff truetype usb \
     vanilla X xosd xv xvid x86 zlib 3dfx"

(Inhabilitar un parámetro USE)
#  euse -D 3dfx
/etc/make.conf was modified, a backup copy has been placed at /etc/make.conf.euse_backup

(/etc/make.conf después de ejecutar el comando)
USE="alsa acpi apache2 -arts cups cdr crypt cscope -doc fbcon \
     firefox gd gif gimpprint gnome gpm gstreamer gtkhtml imlib \
     innodb -java javascript jpeg libg++ libwww mad mbox md5sum \
     mikmod mmx motif mpeg mpeg4 mysql ncurses nvidia \
     ogg odbc offensive opengl pam pdflib perl png python \
     quicktime readline sdl spell sse ssl svga tcltk tiff truetype usb \
     vanilla X xosd xv xvid x86 zlib -3dfx"

Nota: euse no borra físicamente el parámetro de make.conf. Solo le antepone el signo - (menos) para desactivarlo. Puede que tenga que limpiar manualmente su make.conf para deshacerse de parámetros que no quiera.

4.  Otras herramientas

revdep-rebuild

Esta herramienta es el reconstructor de dependencias inversas de Gentoo. Realizará una búsqueda de todos los ebuilds instalados que no funcionen a causa de alguna actualización de un paquete del cual dependan. Puede hacer un emerge de esos paquetes por usted pero puede ocurrir que un paquete determinado ya no funcione con las actuales dependencias instaladas, en cuyo caso, debe actualizar el paquete que no funciona a una versión más reciente. revdep-rebuild le pasará parámetros a emerge que te permiten hacer uso de --pretend para ver qué paquetes se van a emerger de nuevo antes de proceder.

Listado de Código 4.1: Ejecutar revdep-rebuild en modo pretend

# revdep-rebuild -p

Checking reverse dependencies...
Packages containing binaries and libraries broken by any package update,
will be recompiled.

Collecting system binaries and libraries... done.
  (/root/.revdep-rebuild.1_files)

Collecting complete LD_LIBRARY_PATH... done.
  (/root/.revdep-rebuild.2_ldpath)

Checking dynamic linking consistency...
  broken /usr/lib/ao/plugins-2/libarts.so (requires libartsc.so.0)
  broken /usr/lib/kde3/libkpresenterpart.so (requires libartskde.so.1 libqtmcop.so.1
         libsoundserver_idl.so.1 libkmedia2_idl.so.1 libartsflow.so.1 libartsflow_idl.so.1 libmcop.so.1)
  broken /usr/lib/ruby/site_ruby/1.8/i686-linux/fox.so (requires libFOX-1.0.so.0)
  broken /usr/lib/xine/plugins/1.0.0/xineplug_ao_out_arts.so (requires libartsc.so.0)
  broken /usr/lib/perl5/vendor_perl/5.8.0/i686-linux/auto/SDL_perl/SDL_perl.so (requires libSDL_gfx.so.0)
  broken /usr/lib/libloudmouth-1.so.0.0.0 (requires libgnutls.so.10)
  broken /usr/bin/k3b (requires libartskde.so.1 libqtmcop.so.1 libsoundserver_idl.so.1 libkmedia2_idl.so.1
         libartsflow.so.1 libartsflow_idl.so.1 libmcop.so.1)
  broken /usr/bin/lua (requires libhistory.so.4)
  broken /usr/bin/lyx (requires libAiksaurus-1.0.so.0)
  broken /usr/bin/luac (requires libhistory.so.4)
  broken /usr/bin/avidemux2 (requires libartsc.so.0)
  broken /usr/bin/pptout (requires libxml++-0.1.so.11)
  broken /usr/bin/xml2ps (requires libxml++-0.1.so.11)
 done.
  (/root/.revdep-rebuild.3_rebuild)

Assigning files to ebuilds... done.
  (/root/.revdep-rebuild.4_ebuilds)

Evaluating package order... done.
  (/root/.revdep-rebuild.5_order)

All prepared. Starting rebuild...
emerge --oneshot --nodeps -p =app-cdr/k3b-0.11.14 =app-office/koffice-1.3.2 =app-office/lyx-1.3.4 \
       =app-office/passepartout-0.2 =dev-lang/lua-5.0.2 =dev-ruby/fxruby-1.0.29 =media-libs/libao-0.8.5 \
       =media-libs/xine-lib-1_rc5-r3 =media-video/avidemux-2.0.26 =net-libs/loudmouth-0.16 

These are the packages that I would merge, in order:

Calculating dependencies ...done!
[ebuild   R   ] app-cdr/k3b-0.11.14  
[ebuild   R   ] app-office/koffice-1.3.2  
[ebuild   R   ] app-office/lyx-1.3.4  
[ebuild   R   ] app-office/passepartout-0.2  
[ebuild   R   ] dev-lang/lua-5.0.2  
[ebuild   R   ] dev-ruby/fxruby-1.0.29  
[ebuild   R   ] media-libs/libao-0.8.5  
[ebuild   R   ] media-libs/xine-lib-1_rc5-r3  
[ebuild   R   ] media-video/avidemux-2.0.26  
[ebuild   R   ] net-libs/loudmouth-0.16  

Ahora ya puede eliminar -p (o --pretend) de los argumentos y volver a ejecutar
revdep-rebuild.

Si necesita reconstruir algunos paquetes, puede ejecutar revdep-rebuild sin el parámetro -p y los paquetes listados serán emergidos de nuevo.

glsa-check

glsa-check es principalmente una herramienta de verificación que le sigue la pista a los diversos GLSA's (Advertencia de Seguridad de Gentoo Linux, Gentoo Linux Security Advisory en inglés) y que acabará por integrarse en emerge y equery. Para más información, por favor visite la Página de integración Portage GLSA.

eread

eread es una sencilla herramienta para visualizar ficheros elog creados por Portage a partir de la versión >=portage-2.1. Puede habilitar la grabación de ficheros elog definiendo un par de variables en /etc/make.conf:

Listado de Código 4.2: Habilitar elog en /etc/make.conf

PORTAGE_ELOG_CLASSES="log"
PORTAGE_ELOG_SYSTEM="save"

Nota: Éste es sólo uno de los modos de grabar mensajes elog. Para obtener más información de cómo funciona el sistema elog de Portage, por favor consulte su correspondiente página en el Manual Gentoo.

Una vez haya configurado elog del modo deseado, simplemente ejecute eread para ver sus ficheros de registro.

Listado de Código 4.3: Utilizar eread

$ eread

This is a list of portage log items. Choose a number to view that file or type q to quit.

1) app-portage:gentoolkit-0.2.4_pre2:20070320-000256.log
2) app-portage:gentoolkit-0.2.4_pre2:20070320-000258.log
3) app-portage:gentoolkit-0.2.4_pre2:20070320-000319.log
4) app-portage:gentoolkit-0.2.3:20070320-000408.log
Choice?

Seleccione un número y el fichero se mostrará mediante el programa de paginación especificado en la variable de entorno PAGER. Si ésta no está definida, se utilizará less.

Una vez mostrado el elemento elog, se le preguntará si desea eliminar el fichero.