Manual de Gentoo: IA64/Trabajando/Características
Características de Portage
Portage tiene varias características adicionales que hacen de su experiencia con Gentoo algo mucho mejor. Muchas de estas características residen en ciertas herramientas software que mejoran el rendimiento, la estabilidad, la seguridad, ...
Para activar o desactivar ciertas características de Portage necesita editar la variable FEATURES del archivo /etc/portage/make.conf. Esta variable contiene una lista con las palabras clave de cada característica separadas por un espacio en blanco. En algunos casos necesita además instalar la herramienta que implementa la característica.
No todas las características que soporta Portage están aquí reflejadas. Para una consulta completa por favor revise la página de la ayuda referente a make.conf
user $
man make.conf
Para conocer qué características están siendo utilizadas por defecto, ejecute emerge --info y busque la variable FEATURES o utilice grep:
user $
emerge --info | grep ^FEATURES=
Compilación Distribuida
Usar distcc
distcc es un programa para distribuir un trabajo de compilación a través de muchas, no necesariamente idénticas, máquinas en una red. Los clientes de distcc envían toda la información necesaria a los servidores DistCC disponibles (corriendo distccd) así pueden compilar trozos de código fuente para el cliente. El resultado final, es un tiempo de compilación más rápido.
Puede encontrar información más detallada sobre distcc (e información de como tenerlo funcionando sobre Gentoo) en el artículo sobre Distcc.
Instalar distcc
Distcc se distribuye con un monitor gráfico para monitorizar las tareas que su computador está enviando para compilar. Esta herramienta es instalada automáticamente si activa USE="gtk"
.
root #
emerge --ask sys-devel/distcc
Activar el soporte en Portage
Añada distcc
a la variable FEATURES dentro de /etc/portage/make.conf. Hecho esto, edite la variable MAKEOPTS e incremente a la cantidad de trabajos de compilación en paralelo que su sistema permite. Una pauta conocida para configurarla es poner -jN
donde N es el número de CPUs que ejecutan distccd (incluyendo la máquina local) más uno, pero quizá obtenga mejores resultados con otros números.
Ahora ejecute distcc-config y cree una lista de los servidores distcc disponibles. Para un ejemplo simple, supondremos que los servidores DistCC son 192.168.1.102 (el host local), 192.168.1.103 y 192.168.1.104 (los dos hosts "remotos"):
root #
distcc-config --set-hosts "192.168.1.102 192.168.1.103 192.168.1.104"
Por supuesto, no se olvide ejecutar también el demonio distccd:
root #
rc-update add distccd default
root #
/etc/init.d/distccd start
Compilación utilizando caché
Acerca de ccache
ccache es un caché de compilación rápida. Cuando compila un programa, puede guardar resultados intermedios, de forma que, si recompila el mismo programa y versión, el tiempo de compilación se reducirá ampliamente. La primera vez que se ejecuta ccache, ésta será más lenta que una compilación normal. Recompilaciones posteriores deberían ser más rápidas. La herramienta ccache solo es útil si va a recompilar la misma versión de la aplicación muchas veces; por lo tanto en la mayoría de los casos es útil únicamente para los desarrolladores de software.
Para mas información sobre ccache, visite su página principal.
ccache puede causar numerosos fallos de compilación. Algunas veces ccache mantendrá objetos con código obsoleto o ficheros corruptos que pueden llevar a que no se pueda hacer emerge de ciertos paquetes. Si esto ocurre (Si obtiene errores como "File not recognized: File truncated"), intente recompilar la aplicación con ccache deshabilitado (
FEATURES="-ccache"
en /etc/portage/make.conf o de un golpe desde la linea de comandos con lo que sigue) antes de informar del error:
root #
FEATURES="-ccache" emerge <category/package>
Instalar ccache
Para instalar ccache, ejecute la siguiente orden:
root #
emerge --ask dev-util/ccache
Activar el soporte ccache en Portage
Primero, edite el fichero /etc/portage/make.conf y añada ccache
a los valores definidos en la variable FEATURES. Si no existe FEATURES, entonces deberá crearla. A continuación, añada una nueva variable llamada CCACHE_SIZE y dele el valor 2G
:
FEATURES="ccache"
CCACHE_SIZE="2G"
Para comprobar si ccache funciona, pídale a ccache que te muestre las estadísticas. Ya que Portage utiliza un directorio diferente para guardar los datos, se necesita fijar la variable CCACHE_DIR para reflejar ésto:
root #
CCACHE_DIR="/var/tmp/ccache" ccache -s
La ruta /var/tmp/ccache/ es el directorio por defecto que emplea Portage para ccache; si quiere cambiar esta variable, configure CCACHE_DIR en /etc/portage/make.conf.
Sin embargo, si ejecuta simplemente ccache, empleará como directorio por defecto ${HOME}/.ccache/, que es la razón por la cual necesita configurar la variable CCACHE_DIR cuando se le pide a Portage que muestre las estadísticas de ccache.
Utilizar ccache para compilaciones de C sin relación con Portage
Si quiere utilizar ccache para compilaciones que no tengan que ver con Portage, añada /usr/lib/ccache/bin/ al principio de su variable PATH (antes de /usr/bin). Esto puede llevarse a cabo editando el fichero ~/.bash_profile de su directorio home de usuario. ~/.bash_profile es una de las maneras de definir variables PATH.
PATH="/usr/lib/bin:${PATH}"
Soporte para Paquetes Binarios
Crear paquetes binarios
Portage soporta la instalación de paquetes precompilados. A pesar de que Gentoo no proporciona paquetes precompilados por sí mismo, Portage puede funcionar perfectamente con paquetes precompilados.
Para crear un paquete precompilado puede utilizar la orden quickpkg si el paquete está instalado en su sistema, o hacer emerge con las opciones --buildpkg
o --buildpkgonly
.
Si quiere que Portage cree paquetes precompilados de cada paquete individual que instale, añada buildpkg
a la variable FEATURES.
Puede encontrar mayor soporte para la creación de conjuntos de paquetes precompilados con catalyst. Para más información sobre catalyst, por favor lea las Preguntas frecuentes sobre Catalyst (en inglés).
Instalar Paquetes Precompilados
A pesar de que Gentoo no proporciona uno, puede crear un repositorio central donde almacene paquetes precompilados. Si quiere utilizar este repositorio, necesita que Portage lo conozca a través de la variable PORTAGE_BINHOST que debe apuntar al repositorio. Por ejemplo, si los paquetes precompilados están en ftp://buildhost/gentoo:
PORTAGE_BINHOST="ftp://buildhost/gentoo"
Cuando quiera instalar un paquete precompilado, añada la opción --getbinpkg
a la orden emerge junto a la opción --usepkg
. La primera le indica a emerge que descargue el paquete precompilado del servidor definido previamente, mientras que el segundo indica a emerge que intente instalar el paquete precompilado antes de buscar el código fuente y compilarlo.
Por ejemplo, para instalar gnumeric a través de paquetes precompilados:
root #
emerge --usepkg --getbinpkg gnumeric
Más información sobre las opciones para utilizar paquetes precompilados con emerge puede consultarse en la página man de ayuda:
user $
man emerge
Distribuir paquetes precompilados a otros
Si distribuye paquetes precompilados a otros, asegúrese que eso está permitido. Compruebe los términos para la distribución del desarrollador del paquete. Por ejemplo, para un paquete publicado bajo GNU GPL, las fuentes deben estar disponibles junto con los binarios.
Los ebuilds pueden definir una restricción bindist
en su variable RESTRICT si los binarios construidos no son distribuibles. En algunos casos esta restricción está condicionada a uno o mas ajustes USE.
Por defecto, Portage no enmascara ningún paquete debido a esta restricción. Esto puede cambiarse globalmente configurando la variable ACCEPT_RESTRICT en /etc/portage/make.conf. Por ejemplo, para enmascarar paquetes que tengan una restricción bindist
añada la siguiente línea a make.conf:
ACCEPT_RESTRICT="* -bindist"
También es posible modificar el valor de la variable ACCEPT_RESTRICT añadiendo la opción --accept-restrict
al comando emerge. Por ejemplo, --accept-restrict=-bindist
temporalmente enmascarará paquetes con restricción bindist
.
Considere también ajustar la variable ACCEPT_LICENSE cuando distribuya paquetes. Vea la sección Licencias para ello.
Es exclusiva responsabilidad de cada usuario cumplir con los términos de licencia de los paquetes y con las leyes del pais de cada usuario. Las variables de metadatos definidas por los ebuilds (RESTRICT o LICENSE) pueden proporcionar indicaciones cuando la distribución de binarios no esté permitida, de manera que la obtención desde Portage o cuestiones respondidas por los desarrolladores de Gentoo no son declaraciones legales, y como tales, no debe confiarse en ellas. Sea cuidadoso de respetar las leyes de su ubicación física.
Descargar los Ficheros
Verificar los ficheros de distribución
Para verificar de nuevo la integridad y (potencialmente) descargar de nuevo los ficheros de distribución previamente eliminados o corruptos para todos los paquetes actualmente instalados, ejecutar:
root #
emerge --ask --fetchonly --emptytree @world