¡¡¡Como usar Gentookit!!!

gtop-www
Hoy voy a tocar una de las herramientas más usadas por los gentoosiastas: Gentookit. Pero primeramente ¿Qué es Gentookit?

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.

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.

Lo primero es lo primero: La Instalación

Con un simple:
emerge gentoolkit

Luego iremos conociendo una a una las diferentes aplicaciones o valiosos scripts que contiene gentoolkit.

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.

Por ejemplo:
Averiguar el paquete del que proviene un fichero:
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.

# equery check gentoolkit
[ Checking app-portage/gentoolkit-0.2.0 ]
* 54 out of 54 files 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:

# 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

Nos da una lista de todos los paquetes que tienen dependencia directa de pygtk

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.

# 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.

# 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

[...]

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

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:

# 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:

# 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.

# 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!

# 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.

# 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.

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

euse

euse es una herramienta para ver, activar y desactivar los parámetros USE en varios lugares. 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 el make.conf, activado en make.Defaults y activado en make.Globals. La salida se asemeja a [+ECDG].

# 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.

# 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).


NOTA: 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.

(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.

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.


# 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:
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:

$ 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.

Tomado de la documentación en español de Gentoo.

Ayúdenos en la traducción.

No comments yet

Responder

Introduce tus datos o haz clic en un icono para iniciar sesión:

Logo de WordPress.com

Estás comentando usando tu cuenta de WordPress.com. Cerrar sesión / Cambiar )

Imagen de Twitter

Estás comentando usando tu cuenta de Twitter. Cerrar sesión / Cambiar )

Foto de Facebook

Estás comentando usando tu cuenta de Facebook. Cerrar sesión / Cambiar )

Google+ photo

Estás comentando usando tu cuenta de Google+. Cerrar sesión / Cambiar )

Conectando a %s

A %d blogueros les gusta esto: