Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Esta es la continuación del libro Linux From Scratch. Introduce y guia al lector a través de la ampliación del sistema, incluyendo el entorno de red,
soporte de las X, soporte para sonido y soporte para impresoras y escáneres.
El presente texto se distribuye bajo la Licencia GNU de documentación libre (GFDL). Para todo aquello no especificado en dicha licencia son de
aplicación las condiciones de uso del documento original en el que se basa esta traducción, citadas a continuación.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
• Redistributions in any form must retain the above copyright notice, this list of conditions and the following disclaimer.
• Neither the name of "Linux From Scratch" nor the names of its contributors may be used to endorse or promote products derived from this
material without specific prior written permission.
• Any material derived from Linux From Scratch must contain a reference to the "Linux From Scratch" project.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED
WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.
Índice
Prólogo
Prefacio
Quién querría leer este libro
Organización
Parte I − Introducción
Parte II − Configuración Posterior a LFS y Software Adicional
Parte III − Librerías y Utilidades Generales
Parte IV − Conectarse a una Red
Parte V − Entorno de Red Básico
Parte VI − Servidores de Red
Parte VII − Servidores de Contenido
Parte VIII − X + Administradores de Ventanas
Parte IX − KDE
Parte X − Gnome
Parte XI − Programas para las X
Parte XII − Multimedia
Parte XIII − Impresoras, Escáneres y Tipografía
Apéndices
I. Introducción
1. Bienvenido a BLFS
Agradecimientos
Créditos
¿Qué secciones del libro quiero?
Convenciones usadas en este libro
Versión del libro
Servidores alternativos
Historial de modificaciones
Listas de correo y archivos
Servidor de noticias
Buscando ayuda y las FAQ
Información de contacto
2. Información importante
Conseguir y desempaquetar el software
El debate /usr frente a /usr/local
Parches opcionales
Usar los guiones de arranque de BLFS
Ir Más Allá del BLFS
II. Configuración posterior a LFS y Software Adicional
3. Configuración posterior al LFS
Creación de un disquete de arranque personalizado
Comfiguración para añadir usuarios
/etc/inputrc
Los ficheros de inicio de Bash
/etc/vimrc, ~/.vimrc
/etc/issue (Personalizar tu entrada al sistema)
Generación de números aleatorios
Compresión de las páginas de manual e info
4. Seguridad
Linux−PAM−0.77
Shadow−4.0.3
iptables−1.2.8
Configuración de un cortafuegos
GnuPG−1.2.3
Tripwire−2.3.1−2
5. Sistemas de ficheros
Ext3
ReiserFS−3.6.11
XFS−2.5.6
6. Editores
Vim−6.2
Emacs−21.3
nano−1.2.2
JOE−2.9.8
7. Intérpretes de comandos
Dedicatoria 2
Más Allá de Linux From Scratch
ASH−0.4.0
Tcsh−6.12.00
ZSH−4.1.1
III. Librerías y Utilidades Generales
8. Librerías Generales
OpenSSL−0.9.7c
pcre−4.3
popt−1.7
slang−1.4.9
FAM−2.6.10
libxml−1.8.17
libxml2−2.5.11
libxslt−1.0.33
readline−4.3
GMP−4.1.2
GDBM−1.8.3
GLib−1.2.10
GLib−2.2.3
expat−1.95.6
libesmtp−1.0
aspell−0.50.3
ispell−3.2.06.epa6
Guile−1.6.4
slib−2d6
G−Wrap−1.3.4
LZO−1.08
9. Librerías Gráficas
lcms−1.11
libjpeg−6b
libpng−1.2.5
libtiff−3.6.0
libungif−4.1.0b1
libmng−1.0.5
Imlib−1.9.14
AAlib−1.4rc5
SVGAlib−1.4.3
DirectFB−0.9.19
Imlib2−1.1.0
10. Utilidades Generales
bc−1.06
rep−gtk−0.18
Compface−1.4
11. Utilidades del Sistema
GPM−1.20.1
Fcron−2.9.3
hdparm−5.4
which−2.14 y alternativas
UnZip−5.50
Zip−2.3
PCI Utilities−2.1.11
pkgconfig−0.15.0
cpio−2.5
MC−4.6.0
12. Programación
Python−2.3.2
Módulos de Perl
librep−0.16.2
J2SDK−1.4.1
Ruby−1.8.0
GCC−3.3.1
Tcl−8.4.4
Tk−8.4.4
GCC−2.95.3
NASM−0.98.38
IV. Conectarse a una Red
13. Entorno de Red por Marcado Telefónico (Dial−Up)
PPP−2.4.1
WvDial−1.53
14. Clientes DHCP
Configuración de los guiones de arranque de LFS para soportar clientes DHCP
Dedicatoria 3
Más Allá de Linux From Scratch
DHCP−3.0pl2
dhcpcd−1.3.22−pl4
15. Otras formas de conexión
RP−PPPoE−3.5
V. Entorno de Red básico
16. Librerías para trabajo en Red
cURL−7.10.7
WvStreams−3.70
GNet−2.0.4
libsoup−1.99.23
17. Navegadores Web en modo texto
Links−2.1pre11
Lynx−2.8.4
w3m−0.4.1
18. Programas Básicos para Trabajo en Red
NcFTP−3.1.6
Cliente OpenSSH−3.7.1p2
Cliente rsync−2.5.6
CVS−1.11.6
Wget−1.8.2
tcpwrappers−7.6
portmap−5beta
Inetutils−1.4.2
NCPFS−2.2.3
NTP−4.1.2
19. Utilidades Básicas para el Trabajo en Red
Traceroute−1.4a12
Nmap−3.30
Whois−4.6.7
BIND Utilities−9.2.2
20. Clientes de Correo y Noticias
Nail−10.5
Procmail−3.22
Fetchmail−6.2.3
Mutt−1.4.1i
Pine−4.58
slrn−0.9.7.4
Otros programas de correo y noticias
21. Utilidades de D.J. Bernstein
daemontools−0.76
ucspi−tcp−0.88
VI. Servidores de Red
22. Servidores de Correo
Postfix−2.0.16
qmail−1.03
Sendmail−8.12.10
Exim−4.24
Qpopper−4.0.5
Courier−0.43.2
23. Otros servidores
BIND−9.2.2
Ejecutar un servidor CVS
DHCP−3.0pl2
Leafnode−1.9.43
OpenSSH−3.7.1p2
rsync−2.5.6
OpenLDAP−2.1.22
Samba−2.2.8a
xinetd−2.3.12
VII. Servidores de Contenidos
24. Bases de Datos
Berkeley DB−4.1.25
Berkeley DB−3.3.11
MySQL−4.0.15a
PostgreSQL−7.3.4
25. Servir la Web
Apache−2.0.47
PHP−4.3.3
ProFTPD−1.2.8p
VIII. X + Administradores de Ventanas
Dedicatoria 4
Más Allá de Linux From Scratch
Dedicatoria 5
Más Allá de Linux From Scratch
GAL−1.99.9
libgnomeprint−2.2.1.3
libgnomeprintui−2.2.1.3
GtkHTML−3.0.8
32. GNOME base
GNOME Desktop−2.2.2
GNOME Panel−2.2.2.2
GNOME Session−2.2.2
Control Center−2.2.2
33. Paquetes adicionales de GNOME
GNOME Terminal−2.2.2
GNOME System Monitor−2.0.5
GNOME Applets−2.2.2
GNOME Utilities−2.2.3
GNOME Games−2.2.1
Nautilus−2.2.4
Yelp−2.2.3
bug−buddy−2.2.106
gedit−2.2.2
EOG−2.2.2
GStreamer−0.6.2
gst−plugins−0.6.2
GNOME Media−2.2.2
Nautilus Media−0.2.2
GNOME2 User Docs−2.0.6
34. Otros Paquetes de GNOME
GConf Editor−0.4.1
GDM−2.4.1.4
35. Configuración de GNOME
Configuración de los paquetes básicos de GNOME
36. Librerías de GNOME 1.4
Configuración previa a la instalación
ORBit−0.5.17
OAF−0.6.10
GNOME Libraries−1.4.2
GDK Pixel Buffer−0.22.0
GNOME Print−0.37
Bonobo−1.0.22
GConf−1.0.9
GNOME Virtual File System−1.0.5
libglade−0.17
GAL−0.24
Guppi−0.40.3
libcapplet−1.5.11
Soup−0.7.11
GtkHTML−1.1.7
libghttp−1.0.9
XI. Programas para las X
37. Programas de Oficina Individuales
AbiWord−2.0.0
Gnumeric−1.2.0
GnuCash−1.8.7
GIMP−1.2.5
Evolution−1.4.4
38. Paquetes de oficina
KOffice−1.2.93
OpenOffice−1.1.0
39. Navegadores Gráficos
Mozilla−1.5
Galeon−1.3.10
Konqueror−3.1.4
Dillo−0.7.3
40. Otros programas de Internet basados en las X
Pan−0.14.2
Balsa−2.0.14
XII. Multimedia
41. Controladores y Librerías Multimedia
ALSA−0.9.6
ALSA Driver−0.9.6
ALSA Library−0.9.6
Dedicatoria 6
Más Allá de Linux From Scratch
ALSA Utilities−0.9.6
ALSA Tools−0.9.6
ALSA OSS−0.9.6
aRts−1.1.4
Audio File−0.2.3
EsounD−0.2.30
SDL−1.2.6
libao−0.8.3
libogg−1.0
libvorbis−1.0
NAS−1.6
libmpeg3−1.5.2
libmad−0.15.0b
OpenQuicktime−1.0
libFAME−0.9.0
Speex−1.0.1
id3lib−3.8.3
FLAC−1.1.0
libdvdread−0.9.4
libdvdcss−1.2.8
libdv−0.99
liba52−0.7.4
XviD−0.9.2
xine Libraries−1−rc0a
42. Utilidades de sonido
mpg123−0.59r
Vorbis Tools−1.0
XMMS−1.2.7
LAME−3.93.1
CDParanoia−III−9.8
43. Utilidades de Vídeo
FFmpeg−0.4.7
Avifile−0.7.38
MPlayer−1.0pre1
xine User Interface−0.9.22
transcode−0.6.10
44. Utilidades para grabar CDs
Configuración del núcleo para grabar CDs
Cdrtools−2.00.3
Cdrdao−1.1.7
UDFtools−1.0.0b2
XIII. Impresoras, Escáneres y Tipografía
45. Impresoras
CUPS−1.1.19
LPRng−3.8.22
AFPL Ghostscript−8.11
ESP Ghostscript−7.07.1rc2
46. Escáneres
SANE−1.0.12
XSane−0.91
GOCR−0.37
47. Lenguaje de Marcas Estándar Generalizado (SGML)
SGML Common−0.6.3
DocBook SGML DTD−3.1
DocBook SGML DTD−4.2
OpenSP−1.5
OpenJade−1.3.2
DocBook DSSSL Stylesheets−1.78
48. Lenguaje de Marcas Extensible (XML)
DocBook XML DTD−4.2
DocBook XSL Stylesheets−1.62.4
49. PostScript
a2ps−4.13b
enscript−1.6.1
PSUtils−p17
GSview−4.4
Xpdf−2.02pl1
Otros programas PostScript
50. Tipografía
TeX−2.0.2
Dedicatoria 7
Más Allá de Linux From Scratch
XIV. Apéndices
A. Listado de los enlaces en rc?.d usados en LFS/BLFS
rc0.d
rc1.d
rc2.d
rc3.d
rc4.d
rc5.d
rc6.d
B. Instalar en una localización no estándar
Glosario
Lista de tablas
A−1. Enlaces simbólicos en rc0.d
A−2. Enlaces simbólicos en rc1.d
A−3. Enlaces simbólicos en rc2.d
A−4. Enlaces simbólicos en rc3.d
A−5. Enlaces simbólicos en rc4.d
A−6. Enlaces simbólicos en rc5.d
A−7. Enlaces simbólicos en rc6.d
Dedicatoria 8
Prólogo
Prefacio
Mientras ayudaba con Linux From Scratch por algún tiempo, noté que estábamos recibiendo muchas preguntas sobre cómo hacer cosas más allá del
sistema LFS base. Por aquellas fechas, la única ayuda expresamente ofrecida relacionada con LFS eran las recetas LFS
(http://www.linuxfromscratch.org/hints, en inglés. Hay un buen número de ellas traducidas al castellano en
http://www.escomposlinux.org/lfs−es/recetas). La mayoría de las recetas LFS son sumamente buenas y están bien escritas, pero yo (y otros) pudimos
ver todavía una necesidad de una ayuda más amplia para ir Más Allá de LFS − de aquí el nombre de BLFS (Beyond LFS).
BLFS pretende ser más que las recetas LFS convertidas a XML, aunque mucho de nuestro trabajo está basado en las recetas y, en efecto, algunos
autores escriben tanto las recetas como las secciones de BLFS pertinentes. Esperamos poder proporcionarte suficiente información, no sólo para lograr
construir tu sistema hasta donde quieras, ya sea un servidor web o un ordenador multimedia, sino también para que aprendas mucho sobre la
configuración del sistema mientras lo haces.
Las gracias, como siempre, van dirigidas a todos los miembros de la comunidad LFS/BLFS, especialmente a aquellos que han aportado instrucciones,
escrito el texto, contestado preguntas y, en general, ¡gritado cuando las cosas han ido mal!
Finalmente, te animamos a implicarte en la comunidad; pregunta en la lista de correo o en la pasarela de noticias y únete a la diversión en #lfs en
irc.linuxfromscratch.org. Encontrarás más detalles sobre todo esto en la sección Introducción del libro.
Mark Hymers
markh@linuxfromscratch.org
Editor del BLFS (Julio de 2001 − Marzo de 2003)
Todavía recuerdo cómo encontré el proyecto BLFS y comencé a utilizar las instrucciones que tenía completadas en alquel momento. No podía creerme
lo maravilloso que era tener una aplicación en marcha rápidamente, con explicaciones de por qué se hacian las cosas de un cierto modo.
Desafortunadamente para mí, esto se acabó conforme abría aplicaciones en cuya página solo habia un "Por hacer". Hice lo que haría la mayoria, esperar
a que alguien lo hiciera. No pasó mucho tiempo hasta que busqué en Bugzilla algo facil para hacer. Y como con cualquier aprendizaje por experiencia,
la definición de qué es facil va cambiando.
Te animamos a que te involucres, pues BLFS nunca estará realmente terminado. Contribuyendo o simplemente usandolo, esperamos que te diviertas
con tu experiencia con BLFS.
Larry Lawrence
larry@linuxfromscratch.org
Editor del BLFS (Marzo 2003 − presente)
Organización
Este libro se divide en las siguientes partes.
Parte I − Introducción
Esta parte contiene información que es esencial para el resto del libro.
Aquí introducimos aspectos básicos de configuración y de seguridad. Tambien se describen varios editores, sistemas de ficheros e intérpretes de
comandos que no se tratan en el libro LFS.
En esta sección se tratan librerías que se necesitan en el resto del libro, así como utilidades del sistema. Esta parte concluye con información sobre
programación (incluyendo la recompilación de GCC para soportar varios lenguajes).
Prólogo 9
Más Allá de Linux From Scratch
Aquí se describe cómo conectarse a una red cuando no estás usando la sencilla configuración de IP estática que se ofrece en el libro LFS.
Aquí se describe la configuración de servidores de correo y otros servidores (tales como SSH, CVS, etc).
Esta parte explica cómo configurar una instalación básica de XFree86, junto con algunas librerías genéricas para las X y administradores de ventanas.
Parte IX − KDE
Para aquellos que quieren usar el Entorno de Escritorio K o algunas partes del mismo, aquí se explica cómo.
Parte X − Gnome
GNOME es la principal alternativa a KDE en los entornos de escritorio, y aquí tratamos tanto Gnome−1.4 como GNOME−2.2
Los programas de oficina y los navegadores web gráficos son importantes para la mayoría de la gente. Estos, junto con algunos programas genéricos
para las X, se describen en esta parte del libro.
Aquí se describe la configuración de librerías y controladores multimedia junto con algunos programas de audio, vídeo y grabación de CDs.
La parte PST del libro trata cosas que van desde Ghostscript, CUPS y DocBook hasta la instalación de TeX.
Apéndices
Los Apendices cubren información que no pertence al libro principal. Están aquí básicamente como referencia.
I. Introducción 11
Capítulo 1. Bienvenido a BLFS
El libro Más Allá de Linux From Scratch está pensado para conducirte a partir del punto en el que el libro LFS te deja. A diferencia del libro LFS, no
está diseñado para seguirse de forma correlativa. La lectura de ¿Qué secciones del libro quiero?, que es parte de este capítulo, debería servirte de guía a
través del libro.
Por favor, lee esta parte del libro cuidadosamente, pues explica muchas de las convenciones usadas a lo largo del mismo.
Agradecimientos
Queremos agradecer a las siguientes personas y organizaciones su contribución al Proyecto LFS−ES:
Queremos dar las gracias a las siguientes personas y organizaciones por su contribución a los proyectos BLFS y LFS:
• Todas aquellas personas listadas en la página Créditos, por proporcionar parches, instrucciones y correciones al libro. El editor anterior
quiere agradecer especialmente a Bruce, Larry y Billy su enorme impulso al proyecto.
• Mark Stone <mstone@linux.com> por donar los servidores para linuxfromscratch.org.
• Gerard Beekmans <gerard@linuxfromscratch.org> por iniciar y escribir gran parte del proyecto LFS.
• Jesse Tie−Ten−Quee <highos@linuxfromscratch.org> por responder muchas cuestiones en el IRC, demostrando mucha paciencia, y ¡por no
matar al editor actual por el chiste en el anuncio original del BLFS!
• DREAMWVR.COM por su anterior patrocinio mediante la donación de varios recursos al LFS y subproyectos relacionados.
• Robert Briggs por donar los nombres de dominio linuxfromscratch.org y linuxfromscratch.com.
• Frank Skettino <bkenoah@oswd.org> en OSWD por hacer los diseños iniciales de los sitios web de LFS y BLFS.
• Garrett LeSage <garrett@linux.com> por crear el logotipo de LFS.
• Jeff Bauman (anterior coeditor del libro) por su ayuda para conseguir que el BLFS saliera a la luz.
• Muchas otras personas en las listas de correo de LFS y BLFS que han hecho posible este libro mediante sus sugerencias, probándolo y
enviando informes de errores.
Créditos
Mucha gente ha contribuido directa o indirectamente al BLFS. Esta página enumera todos los que recordamos. Puede que hayamos olvidado a alguien
y si te encuentras en esta situación, mándanos una línea. Muchas gracias a toda la comunidad LFS por su apoyo a este proyecto. Si estás en la lista y
deseas que se incluya tu dirección de correo, por favor, manda igualmente una línea a larry@linuxfromscratch.org y estaremos felices de incluirla. No
incluimos direcciones de correo por defecto, así que si quieres que se incluya indícalo, por favor, cuando contactes con nosotros.
Editores
• Capítulo 01. Basado en el texto de introducción del LFS por Gerard Beekmans, modificado por Mark Hymers para BLFS.
• Capítulo 02: El debate /usr contra /usr/local: Andrew McMurry.
• Capítulo 02: Ir más allá del BLFS: Tushar Teredesai.
• Capítulo 03: /etc/inputrc: Chris Lynn.
• Capítulo 03: Personalizar tu entrada al sistema & vimrc: Mark Hymers.
• Capítulo 03: Guión de generación de números aleatorios: Larry Lawrence.
• Capítulo 03: Crear un disquete de arranque personalizado Mike Bedwell y ampliado por Bill Maltby.
• Capítulo 03: Los ficheros de inicio de Bash James Robertson.
• Chapter 03: Documentos comprimidos Olivier Peres.
• Capítulo 04: Cortafuegos: Henning Rohde con agradecimientos a Jeff Bauman.
• Capítulo 11: Which Mark Hymers con agradecimientos a Seth Klein y Jesse Tie−Ten−Quee.
• Capítulo 26: XFree86 Bruce Dubbs.
• Capítulo 28: Introducción a los Administradores de Ventanas Bruce Dubbs.
• Capítulo 29: KDE: Bruce Dubbs.
• Capítulo 32: GNOME: Larry Lawrence.
• aalib, Alsa, ffmpeg, MPlayer, opendivx, sane, transcode, xvid y xsane: Alex Kloss
• AbiWord, at−spi, ATK, audiofile, avifile, bc, bonobo−activation, bug−buddy, cdrdao, cdrtools, cpio, curl, dhcp, enlightenment, eog, esound,
fcron, fluxbox, FNLIB, gail, galeon, gconf−editor, gdbm, gedit, gimp, GLib2, gmp, gnet, gnome−applets, gnome−desktop, gnome−games,
gnome−icon−theme, gnome−libs, gnome−media, gnome−mime−data, gnome−panel, gnome−session, gnome−system−monitor,
gnome−terminal, gnome−themes, gnome−utils, gnome−vfs, gnome2−user−docs, gnumeric, GTK+2, gtk−doc, gtk−engines,
gtk−thinice−engine, eel, imlib, intltool, lame, libao, libart_lgpl, libbonobo, libbonoboui, libgail−gnome, libglade2, libgnome,
libgnomecanvas, libgnomeprint, libgnomeprintui, libgnomeui, libgsf, libgtkhtml, libgtop, libIDL, libogg, librep, librsvg, libvorbis, libwnck,
libxml2, libxslt, linc, LPRng, Linux_PAM, metacity, MPlayer, mutt, nautilus, nautilus−media, oaf, OpenJade, OpenSP, OpenSSH, ORBit,
ORBit2, pan, Pango, pccts, pcre, pkgconfig, postfix, procmail, Python, QT, rep−gtk, ruby, sawfish, scrollkeeper, sgml−common, sgml−dtd,
shadow, startup−notification, unzip, vorbis−tools, vte, wget, XFce, xine, xml−dtd, yelp y zip: Larry Lawrence
• CDParanoia, mpg123, SDL y XMMS: Jeroen Coumans
• alsa, cvs, dhcpcd, gpm, hdparm, libjpeg, libmng, libpng, libtiff, libungif, links, lynx, openssl, tcsh, which, zcsh y zlib: Mark Hymers
• daemontools, traceroute y ucspi−tcp: Jeff Bauman
• db y lcms: Jeremy Jones y Mark Hymers
• aspell, balsa, bind, bonobo, bonobo−conf, cvs server, db−3.3.11, db−3.1.17, emacs, evolution, exim, expat, gal, gnome−print, GnuCash,
gtkhtml, guppi, guile, guppi, g−wrap, leafnode, lesstif, libcapplet, libesmtp, libfam, libghttp, libglade, pine, portmap, PostgreSQL, pspell,
qmail, qpopper, readline, reiserfs, Samba, sendmail, slib, slrn, soup, tex, tcp−wrappers, y xinetd: Billy O'Connor
• ProFTPD y rsync: Daniel Baumann
• ESP Ghostscript: Matt Rogers
• PHP: Jeremy Utley
• fetchmail y wvdial: Paul Campbell
• udftools: Richard Downing
• compface, DirectFB, FLAC, id3lib, Imlib2, liba52, libdv, libdvdcss, libdvdread, libFAME, libmad, libmpeg3, LZO, MC, NASM,
OpenQuicktime, Speex y SVGAlib: Igor Zivkovic
• tripwire : Manfred Glombowski
• alsa−oss, inetutils, gdk, GLib, GTK+, libxml y vim: James Iwanek
• iptables: Henning Rohde
• joe, nano, nmap, slang, w3m y whois: Timothy Bauscher
• MySQL: Jesse Tie−Ten−Quee
• fontconfig, gcc, gcc2, j2sdk, mozilla, nas, openoffice, ispell, nail, STLport, tcl, tk y bind−utils: Tushar Teredesai
• ncpfs y RP−PPPoE: DJ Lucas
• ntp: Eric Konopka
Reconocimientos Generales
• Gerard Beekmans por tolerarnos habitualmente y por poner en marcha el proyecto LFS.
• Bruce Dubbs por escribir la receta kde.txt a partir de la que hemos obtenido mucha información útil.
• Lee Harris por escribir la receta gpm.txt en la que se basan nuestras instrucciones del gpm.
• Marc Heerdink por escribir la receta gpm2.txt en la que se basan nuestras instrucciones del gpm.
• Jeremy Jones (conocido también como mca) por retocar los Makefiles y ayuda general.
• J_Man por suministrar un fichero gpm−1.19.3.diff en la que se basan nuestras instrucciones del gpm.
• Scot Mc Pherson por escribir la receta gnome−1.4.txt de la que hemos obtenido información útil y por avisarnos de que posiblemente la
versión 2.0 de GNOME no estaría preparada para el libro.
• Tushar Teredesai por escribir la receta Compilación de Java 2 SDK desde Cero en la que se basa j2sdk y por escribir la receta de docbook
usada durante todo el capítulo de tipografía.
• Oliver Brakmann por desarrollar el parche de dhcpcd para cumplir con el FHS.
• DJ Lucas por contribuir al parche de dhcpcd y por muchas otras contribuciones mientras se desarrollaba la sección DHCP.
• Billy O'Connor por construir GNOME 2.0 muchas veces y ser de mucha ayuda con sus comentarios sobre esta sección.
• Ted Riley por escribir la receta Linux−PAM + CrackLib + Shadow en la que se basa la reinstalación de shadow para usar PAM.
• Fernando Arbeiza por hacer un gran control de calidad de Shadow usando PAM. El acceso a la máquina que salvó pudo haber sido la tuya.
• Jim Harris por escribir la receta dig−nslookup−host.txt en la que se basan las instrucciones de bind−utils.
• Eric Konopka por escribir la receta ntp.txt en la que se basa la sección ntp.
• Marc Heerdink por crear los parches para tcp_wrappers y portmap.
Todo el que lea el libro querrá leer ciertas secciones. La parte de Introducción, que estás leyendo en este momento, contiene información genérica.
Toma especial nota de lo que se dice en Información importante (Capítulo 2), pues contiene comentarios sobre cómo desempaquetar el software y otros
aspectos varios que se aplican a lo largo del libro.
La parte sobre Configuración posterior al LFS y Software adicional es por la que muchos querreis continuar. No trata sólo de configuración, también de
Seguridad (Capítulo 4), Sistemas de Ficheros (Capítulo 5), Editores (Capítulo 6) e Intérpretes de Comandos (Capítulo 7). De hecho, puede que desees
consultar ciertas partes de este capítulo (sobre todo las secciones de Editores y Sistemas de Ficheros) mientras construyes tu sistema LFS .
Siguiendo los temas básicos, muchos querreis navegar al menos por la parte Librerías y Utilidades Generales del libro. Esta parte contiene información
sobre muchos elementos que son prerrequisitos para otras secciones del libro, al igual que cuestiones (como Programación, Capítulo 12) que son útiles
por derecho propio. Advierte que no tienes que instalar necesariamente todas las librerías y paquetes que encuentres en esta parte. Cada proceso de
instalación del BLFS te indica de qué paquetes depende para que puedas elegir el programa que quieres instalar y ver lo que necesita.
Igualmente, muchos posiblemente querreis mirar las partes Conectarse a una Red y Entorno de Red básico. La primera trata sobre la conexión a
Internet o a tu LAN local utilizando una variedad de métodos como DHCP (Capítulo 14) y Conexión por Marcado (Capítulo 13). La segunda trata de
temas como Librerías para el Entorno de Red (Capítulo 16) y varios programas y utilidades básicas para el trabajo en red.
Una vez que hayas terminado con estas cuestiones básicas, puede que quieras configurar servicios de red más avanzados. Esto se cubre en las partes
Servidores de Red y Servidores de Contenido del libro. Quien quiera construir servidores encontrará aquí suficiente información como punto de
partida. Ten en cuenta que Servidores de Contenido también contiene información sobre varios paquetes de bases de datos.
Las siguientes partes del libro tratan, principalmente, de los sistemas de escritorio. Comenzamos con una parte que habla sobre X y Administradores de
Ventanas. Esta parte también trata algunas librerías genéricas basadas en las X (Capítulo 27). A continuación, KDE y Gnome tienen sus propias partes,
a las que sigue Programas para las X.
Entonces nos movemos para tratar sobre los paquetes Multimedia. Advertimos que muchos querreis utilizar las instrucciones de ALSA−0.9.6 de este
capítulo al principio de vuestro viaje por el BLFS. Están aquí simplemente porque es el sitio más lógico.
La parte final del libro BLFS trata sobre Impresoras, Escáneres y Tipografía. Eso es útil para aquellos con sistemas de escritorio, y también los que
esteis creando sistemas servidores lo encontrareis útil.
Finalmente, los Apéndices contienen varias piezas de información útil que puedes necesitar como referencia.
./configure −−prefix=/usr
Un texto así debe teclearse exactamente como aparece, a menos que se indique lo contrario. También se utiliza en las secciones
explicativas para identificar el comando al que se hace referencia.
Un texto así (de ancho fijo) representa salida por pantalla, probablemente como resultado de comandos, y también se usa para
especificar nombres de archivo, como por ejemplo /etc/lilo.conf.
Énfasis
Este tipo de texto se utiliza con varios fines en el libro, principalmente para poner de relieve puntos importantes y para dar
ejemplos de qué se debe teclear.
http://www.linuxfromscratch.org/
Este tipo de texto se usa para hipervínculos, tanto al propio libro como a páginas externas, como How−To's, direcciones de
descarga, sitios web, etc.
Este tipo de secciones se usa principalmente al crear archivos de configuración. El primer comando (en negrita) solicita al
sistema que cree el archivo $LFS/etc/group a partir de lo que se teclee en las líneas siguientes, hasta encontrar la secuencia
EOF. Por tanto, generalmente la sección entera debe teclearse tal cual.
de los servidores alternativos listados a continuación para obtener las versiones actualizadas.
Servidores alternativos
El proyecto BLFS tiene por todo el mundo varios servidores alternativos para facilitar el acceso a las páginas web. Por favor, visita el sitio web
http://www.linuxfromscratch.org/blfs para consultar la lista de los servidores alternativos actuales.
El proyecto LFS−ES, que se ocupa de la traducción al castellano de los textos del LFS/BLFS, dispone de los siguientes servidores:
Historial de modificaciones
Por favor, ten en cuenta que el historial de modificaciones sólo refleja qué editor fue el responsable de poner los cambios en el CVS. Lee en la página
de Créditos en el Capítulo 1 los detalles de quién escribió qué.
• 6 de Noviembre de 2003 [billyoc]: cambio de la ubicación de los perfiles de acceso de los usarios de Samba.
• 4 de Noviembre de 2003 [tushar]: actualizado a galeon−1.3.10.
• 4 de Noviembre de 2003 [igor]: actualizados enlances desactualizados donde fué posible, eliminados los demás.
• 2 de Noviembre de 2003 [igor]: añadido un parche para FreeType suministrado por Alexander E. Patrakov.
• 1 de Noviembre de 2003 [igor]: añadida una nota sobre la incompatibilidad de DirectFB con la última versión de FreeType, sugerido por
Alexander E. Patrakov.
• 31 de Octubre de 2003 [tushar]: NAS: añadiada dependencia a XFree86 y modificadas las instrucciones para la instalación en /usr/X11R6
en lugar de /usr.
• 31 de Octubre de 2003 [tushar]: OpenOffice: añadida descripción sobre la Administración de la Impresión.
• 31 de Octubre de 2003 [tushar]: Portmap: corregida la ubicación del binario de portmap.
• 31 de Octubre de 2003 [igor]: medidos los SBU donde faltaban (partes VI a XIII).
• 30 de Octubre de 2003 [bdubbs]: otro retoque en XFree86, gracias a Bill Maltby.
• 30 de Octubre de 2003 [igor]: integrado el paquete daemontools−man con la principal página de daemontools.
• 29 de Octubre de 2003 [bdubbs]: actualizadas las instrucciones de XFree86 para mayor consistencia y pequeños retoques en el aspecto.
• 29 de Octubre de 2003 [igor]: aplicado el parche a compressdoc suministrado por Yann E. Morin.
• 29 de Octubre de 2003 [tushar]: añadida la advertencia de que el parche del kernel para escritura de packet puede ocasionar daños en el
hardware.
• 28 de Octubre de 2003 [bdubbs]: añadida una nota sobre los parches de KDE como sugerencia de Alexander E. Patrakov.
• 28 de Octubre de 2003 [igor]: medidos los SBU donde faltaban (partes II a V).
• 26 de Octubre de 2003 [igor]: añadido un comando a las instrucciónes en OpenSSL para instalar certificación CA como lo sugiere Bill
Maltby.
• 26 de Octubre de 2003 [igor]: actualizado a Pine−4.58.
• 24 de Octubre de 2003 [igor]: Apache: establecidos los correctos permisos para los ficheros instalados.
• 23 de Octubre de 2003 [igor]: actualizado el enlace de descarga de libungif.
• 22 de Octubre de 2003 [tushar]: actualizado a Mozilla−1.5, Firebird−0.7 y Thunderbird−0.3. Añadida la extensión Enigmail para Mozilla.
• 22 de Octubre de 2003 [igor]: modificado httpd.conf para ejecutar Apache como un ususario sin privilegios.
• 21 de Octubre de 2003 [larry]: OpenLDAP: expandida la sección de configuración apuntando a la personalización.
• 21 de Octubre de 2003 [igor]: corregida la configuración de la fuente para subtítulos en MPlayer, añadida una nota sobre el archivo de
configuración.
• 20 de Octubre de 2003 [larry]: openldap: expandida la sección de configuración con recomandaciones.
• 19 de Octubre de 2003 [larry]: mplayer: ajustado −dvd 1 a dvd://1.
• 19 de Octubre de 2003 [igor]: limpieza en la sección de GNOME (paso final).
• 18 de Octubre de 2003 [tushar]: añadido el no establecimiento de los caracteres en dillo, envíado por Alexander E. Patrakov.
• 18 de Octubre de 2003 [igor]: limpieza en la sección de GNOME (segundo paso).
• 16 de Octubre de 2003 [markh]: añadido −−sysconfdir=/etc a las instrucciones de instalación de SANE.
• 15 de Octubre de 2003 [larry]: cambio de localstatedir a /var/lib en las instrucciones de openldap.
• 14 de Octubre de 2003 [larry]: regreso al estable fluxbox−0.1.14 y añadido un parche.
• 14 de Octubre de 2003 [larry]: actualizada la introducción de cdparanoia, paquetes opcionales para lame y sus SBU.
• 14 de Octubre de 2003 [igor]: actualizado a MySQL−4.0.15a.
• 13 de Octubre de 2003 [tushar]: actualizado a mozilla−1.4.1.
• 13 de Octubre de 2003 [larry]: modificada la instrucción de instalación para libIDL a /usr.
• 13 de Octubre de 2003 [larry]: editado el parche para Python para utilizar correctamente GDBM.
• 13 de Octubre de 2003 [larry]: doble revisión de los SBU y tamaños durante la reconstrucción.
• 13 de Octubre de 2003 [igor]: limpieza en la sección de GNOME (primer paso).
• 12 de Octubre de 2003 [larry]: editado gimp y librsvg sugerido por nathan. Cambios de SBU, corregida la instalación de xfce.
• 10 de Octubre de 2003 [bdubbs]: actualizadas las instrucciónes de instalación de Qt.
• 10 de Octubre de 2003 [tushar]: corrección en mozilla, añadido −−disable−pedantic.
• 10 de Octubre de 2003 [bdubbs]: actualizado koffice a la versión 1.2.93
• 10 de Octubre de 2003 [igor]: sustraídos archivos de configuración muertos , limpieza de entidades en el capítulo 31.
Servidores alternativos 15
Más Allá de Linux From Scratch
• 9 de Octubre de 2003 [tushar]: Actualizado tcp_wrappers y portmap con nuevos parches. Cambiada la ubicación al URI primario.
• 9 de Octubre de 2003 [tushar]: actualizado el parche del kernel para udftools, añadido enlace para otros parches.
• 9 de Octubre de 2003 [larry]: sorpresa al actualizar a tiff−v3.6.0(.1).
• 9 de Octubre de 2003 [larry]: aplicado un parche nuevo a compressdoc, actualizadas las introducciones en GDBM y CVS y estandarizado lo
reemplazable en docbook−dsssl.
• 9 de Octubre de 2003 [tushar]: añadido un parche de errno para compface. Cambiada la URL para sane.
• 8 de Octubre de 2003 [igor]: añadidos los enlaces web http/ftp faltantes (parte VIII).
• 7 de Octubre de 2003 [igor]: añadidos los enlaces web http/ftp faltantes (parte VI and VII).
• 7 de Octubre de 2003 [tushar]: añadido un parche y modificadas las instrucciones de tripwire para la compilación con gcc3.
• 7 de Octubre de 2003 [larry]: añadido un parche para courier suministrado por Jim Gifford
• 7 de Octubre de 2003 [igor]: añadidos los enlaces web http/ftp faltantes (parte V).
• 6 de Octubre de 2003 [larry]: actualizado a openssh−3.7.1p2.
• 6 de Octubre de 2003 [igor]: añadidos los enlaces web http/ftp faltantes (parte IV).
• 5 de Octubre de 2003 [tushar]: añadido de parche a libungif. Coordinadas las instrucciones de vim con las del LFS.
• 5 de Octubre de 2003 [tushar]: añadido ash−0.4.0.
• 5 de Octubre de 2003 [tushar]: añadido de parches a tiff y nas.
• 5 de Octubre de 2003 [bdubbs]: actualizadas las instrucciones de kde−multimedia. Extraídas las secciones kdoc y kde−other.
• 5 de Octubre de 2003 [larry]: actualizado a Docbook XSL Stylesheets−1.62.4.
• 5 de Octubre de 2003 [igor]: actualizado a NASM−0.98.38 y Python−2.3.2.
• 5 de Octubre de 2003 [igor]: añadidos los enlaces web http/ftp faltantes (parte III).
• 4 de Octubre de 2003 [larry]: General: actualizado a OpenSSL−0.9.7c y FAM−2.6.10.
• 4 de Octubre de 2003 [tushar]: añadida una página en Parches Opcionales que hace referencia al Proyecto de Parches.
• 4 de Octubre de 2003 [igor]: añadidos los enlaces web http/ftp faltantes (parte XIII).
• 4 de Octubre de 2003 [tushar]: reorganización de los parches, Sección IV.
• 3 de Octubre de 2003 [tushar]: actualizado OpenOffice a 1.1.0.
• 3 de Octubre de 2003 [tushar]: añadidos dos parches a unzip.
• 3 de Octubre de 2003 [tushar]: reorganización de los parches (Parte II).
• 3 de Octubre de 2003 [igor]: añadidos los enlaces web http/ftp faltantes (parte XII).
• 3 de Octubre de 2003 [tushar]: reorganización de los parches.
• 2 de Octubre de 2003 [larry]: varias ediciones en las Parte X para colocar el correcto nombre de las aplicaciónes y las etiquetas de clases de
nombres de ficheros.
• 2 de Octubre de 2003 [igor]: modificadas las instrucciones de Evolution.
• 2 de Octubre de 2003 [bdubbs]: eliminado libpng de la lista de requerimientos de Qt. Este es requerido en XFree86.
• 2 de Octubre de 2003 [bdubbs]: actualizado Qt a la versión 3.2.1.
• 2 de Octubre de 2003 [igor]: añadidos los enlaces web http/ftp faltantes (parte XI).
• 2 de Octubre de 2003 [bdubbs]: actualizadas las instrucciones de XFree86 para aclarar la implementación de DRI y las modificaciones de
XF86Config.
• 29 de Septiembre de 2003 [igor]: añadidos los enlances web http/ftp faltantes (parte II).
• 29 de Septiembre de 2003 [larry]: añadido gocr a la sección Escaneado.
• 28 de Septiembre de 2003 [tushar]: añadido ntp a los Programas de Red.
• 27 de Septiembre de 2003 [larry]: actualizado a xfce−4.0.0.
• 27 de Septiembre de 2003 [tushar]: actualizadas las instrucciones de Mozilla para gcc−3.3.1. Añadido de notas para la construcción de
Firebird y Thunderbird.
• 27 de Septiembre de 2003 [larry]: actualizado el parche de xfs para el kernel 2.4.22.
• 26 de Septiembre de 2003 [igor]: añadido MC−4.6.0 y actualizado a ProFTPD−1.2.8p.
• 26 de Septiembre de 2003 [larry]: aplicado parche para compressdocs suministrado por Yann Morin.
• 25 de Septiembre de 2003 [igor]: actualizado a sendmail−8.12.10 y python−2.3.1.
• 25 de Septiembre de 2003 [igor]: añadido PHP−4.3.3 suministrado por Jeremy Utley.
• 24 de Septiembre de 2003 [larry]: actualizado a xine−ui−0.9.22.
• 24 de Septiembre de 2003 [larry]: etiquetado de Acrónimos, construído el Glossario, etiquetado de las extenciones de los nombres de
ficheros (sin usar identificador el cuál no es compatible con la versión 4.1.2). Comprobando la Capitalización contra sitios web o la base de
datos o sourceforge.
• 23 de Septiembre de 2003 [igor]: actualizado a OpenLDAP−2.1.22 y gsview−4.4.
• 22 de Septiembre de 2003 [igor]: actualizado a exim−4.24.
• 22 de Septiembre de 2003 [larry]: añadido un Glosario.
• 22 de Septiembre de 2003 [igor]: actualizado a leafnode−1.9.43.
• 21 de Septiembre de 2003 [tushar]: reubicado STLport al Apéndice C.
• 21 de Septiembre de 2003 [tushar]: actualizado a OpenOffice 1.1rc4.
• 21 de Septiembre de 2003 [igor]: añadido libdvdread−0.9.4, libdvdcss−1.2.8, libdv−0.99 y liba52−0.7.4.
• 21 de Septiembre de 2003 [larry]: actualizado a lcms−1.11.
• 21 de Septiembre de 2003 [igor]: actualizado a transcode−0.6.10.
• 21 de Septiembre de 2003 [tushar]: añadido tcl−8.4.4 y tk−8.4.4.
• 20 de Septiembre de 2003 [tushar]: añadido nail−10.5.
• 20 de Septiembre de 2003 [tushar]: Sincronizado gcc−2.95.3 con las instrucciónes del LFS.
• 20 de Septiembre de 2003 [larry]: actualizado bootdisk para uso de non−devfs y la opción de dos discos.
• 20 de Septiembre de 2003 [tushar]: actualizado a j2sdk−1.4.2_01 (precompilado).
• 20 de Septiembre de 2003 [tushar]: añadido ispell−3.2.06.epa6 a Librerías Generales.
Servidores alternativos 16
Más Allá de Linux From Scratch
Servidores alternativos 17
Más Allá de Linux From Scratch
• 29 de Agosto de 2003 [larry]: Gnome: actualizada la introducción para orbit2 y actualizado a bonobo−activation−2.2.3.
• 28 de Agosto de 2003 [larry]: actualizado a GLib−2.2.3, Pango−1.2.5, ATK−1.2.4 y GTK+−2.2.3.
• 28 de Agosto de 2003 [larry]: actualizada la introducción de gtk−doc and openjade. Errores tipográficos.
• 28 de Agosto de 2003 [larry]: actualizado a ruby−1.8.0
• 26 de Agosto de 2003 [larry]: añadido un parche para OpenSP.
• 26 de Agosto de 2003 [larry]: añadido SVGAlib y actualizado Links para agregarle opciones gráficas.
• 26 de Agosto de 2003 [larry]: actualizada la introducción para PAM, añadido un enlace a cracklib, modificada la descarga de cvs.
• 26 de Agosto de 2003 [tushar]: Añadidas dependencias para fontconfig.
• 25 de Agosto de 2003 [larry]: Actualizada la aplicación de parches suminstradas por Igor Zivkovic para cvs−1.11.6 y hdparm−5.4.
• 24 de Agosto de 2003 [larry]: Actualizada la introducción a vim, docbook y docbook−dsssl. Eliminado el lugar de alojamiento para
alsa−oss.
• 24 de Agosto de 2003 [larry]: Actualizado el SBU para glib−1, gtk−1,
• 24 de Agosto de 2003 [larry]: Edición de etiquetas en el envío de Bill.
• 22 de Agosto de 2003 [tushar]: Actualizado libfam para corregir una falla relacionada con libtool−1.5.
• 21 de Agosto de 2003 [larry]: Cambiado el SBU para aspell, pan, zip, libidl, which, mozilla y vim.
• 19 de Agosto de 2003 [larry]: Basicnet: actualizado a gnet−1.1.9. Cambiado el SBU para pkgconfig, GLib−2, Pango, ATK, GTK−2,
intltool, gnet.
• 18 de Agosto 2003 [larry]: PST: eliminado el mensaje −enable xml de las instruccinones de instalación de Opensp. Cambiado el SBU para
OpenSP, openjade, sgml−common, libxml2, libxslt, libmng, qt, lesstif y fluxbox para reflejar la nueva escala.
• 17 de Agosto de 2003 [bdubbs]: XFree86: cambio de bunzip2 a gunzip.
• 16 de Agosto de 2003 [bdubbs]: Actualizadas las instrucciones de configuración de fontconfig.
• 16 de Agosto de 2003 [tushar]: Sincronizadas las instrucciones de shadow para hacerlas iguales a las del LFS−CVS.
• 15 de Agosto de 2003 [bdubbs]: Actualizadas las instrucciones de XFree86 y añadido de un parche.
• 15 de Agosto de 2003 [bdubbs]: Actulizadas las instrucciónes de configuración de fontconfig y desplazado al capítulo de las librerías de X.
• 13 de Agosto de 2003 [tushar]: Corregido un error tipográfico de nas.
• 8 de Agosto de 2003 [tushar]: Añadido fontconfig y agregado como dependencia para X.
• 4 de Agosto de 2003 [larry]: modificada la introducción de GLib.
• 4 de Agosto de 2003 [larry]: multimedia: actualizado a esound−0.2.30.
• 3 de Agosto de 2003 [larry]: basicnet: actualizado a nmap−3.30.
• 3 de Agosto de 2003 [larry]: modificada la introducción de qt, gtk+, startup−notification, slrn, popt y slang.
• 3 de Agosto de 2003 [larry]: basicnet: actualizado a pine−4.56.
• 3 de Agosto de 2003 [larry]: basicnet: actualizado a fetchmail−6.2.3.
• 2 de Agosto de 2003 [larry]: pst: actualizado a docbook−xsl−1.61.3.
• 2 de Agosto de 2003 [larry]: X: actualizado a lesstif−0.93.46.
• 31 de Julio de 2003 [larry]: general: añadidos parches para gpm−1.20.1.
• 30 de Julio de 2003 [larry]: contenido: añadido proftpd−1.2.8.
• 30 de Julio de 2003 [larry]: general: actualizado a Python−2.3.
• 24 de Julio de 2003 [tushar]: Actualizado a mozilla−1.4
• 17 de Julio de 2003 [larry]: gnome: Actualizado a linc−1.0.3, libIDL−0.8.2, intltool−0.26 y bonobo−activation−2.2.2.
• 7 de julio de 2003 [larry]: servidores: actualizado a postfix−2.0.13.
• 7 de julio de 2003 [larry]: general: actualizado a libxml2−2.5.8 y libxslt−1.0.31.
• 2 de juilo de 2003 [larry]: servidores: eliminada la creación de mount.smbs pues la versión actual crea este fichero en el directorio /sbin.
Notificado por Eagle.
• 1 de julio de 2003 [larry]: general: actualizado a Python−2.2.3.
• 1 de julio de 2003 [larry]: general: actualizado a pcre−4.3.
• 1 de julio de 2003 [larry]: server: actualizado a openssh−3.6.1p2.
• 29 de junio de 2003 [larry]: multimedia: añadido udftools a la sección cdwriting, contribuido por Richard Downing.
• 27 de junio de 2003 [larry]: servidores: actualizado a postfix−2.0.12.
• 27 de junio de 2003 [larry]: basicnet: actualizado a whois−4.6.6.
• 27 de junio de 2003 [larry]: basicnet: eliminado inetutils− ahora en LFS.
• 17 de junio de 2003 [larry]: general: actualizada la introducción de expat.
• 17 de junio de 2003 [larry]: servidores: Añadido un modificador al configure de BIND. mdc buscaba su fichero de configuración en /usr/etc.
• 17 de junio de 2003 [larry]: general: mencionadas las cuestiones de licencias de openssl.
• 13 de junio de 2003 [larry]: general: actualizada la introducción de libjpeg y libtiff.
• 12 de junio de 2003 [larry]: general: actualizada la introducción de pkgconfig y atk.
• 12 de junio de 2003 [larry]: x: actualizado a Pango−1.2.3 y GTK+−2.2.2.
• 12 de junio de 2003 [larry]: general: actualizado a glib−2.2.2.
• 10 de junio de 2003 [larry]: pst: modificado xpdfrc según lo indicado por Andre Kalus.
• 3 de junio de 2003 [tushar]: alsa: actualizado a 0.9.4 (suminitrado por James Iwanek).
• 14 de mayo de 2003 [larry]: x: actualizado a freetype−2.1.4.
• 14 de mayo de 2003 [larry]: cambio del marcado y de la introducción en docbook−xsl, freetype2, libpng.
• 13 de mayo de 2003 [larry]: cambio del marcado y de la introducción de db, procmail, fetchmail, mutt, GLib−2.0, libxslt.
• 12 de mayo de 2003 [larry]: xsoft: actualizado a pan−0.14.0.
• 12 de mayo de 2003 [larry]: cambio del marcado y de la introducción de sgml−common y opensp.
• 5 de mayo de 2003 [larry]: postlfs: actualizado a iptables−1.2.8.
• 5 de mayo de 2003 [larry]: multimedia: actualizado a transcode−0.6.3.
• 4 de mayo de 2003 [larry]: multimedia: actualizado a xine−ui−0.9.20.
• 3 de mayo de 2003 [larry]: red básica: actualizado a pine−4.55.
• 1 de mayo de 2003 [larry]: multimedia: actualizado a xine−lib−1−beta11.
• 1 de mayo de 2003 [larry]: servidores: actualizado a postfix−2.0.9.
Servidores alternativos 18
Más Allá de Linux From Scratch
• 1 de mayo de 2003 [larry]: general: despues de revisar lcms, parece ser un buen candidato para el nuevo formato de instalación de LFS. A
ver qué os parece.
• 30 de abril de 2003 [larry]: general: actualizado a lcms−1.10.
• 30 de abril de 2003 [larry]: xsoft: actualizado a dillo−0.7.2.
• 29 de abril de 2003 [larry]: general: actualizado a libxml2−2.5.7.
• 28 de abril de 2003 [larry]: aplicado el parche de dillo.
• 28 de abril de 2003 [larry]: plantillas: modificadas las plantillas al nuevo formato de introducción.
• 28 de abril de 2003 [larry]: general: actualizado a openssl−0.9.7b y pcre−4.2.
• 27 de abril de 2003 [larry]: introducción: corregida la url del artículo de ESR. general: corregido el tamaño del paquete aalib.
Para obtener mas información sobre qué listas hay disponibles, cómo suscribirse a ellas, localización de los archivos, etc..., visita
http://www.linuxfromscratch.org/mail.html.
Servidor de noticias
Todas las listas de correo hospedadas en linuxfromscratch.org también son accesibles a través del servidor NNTP. Todos los mensajes publicados en
una lista de correo se copian en el grupo de noticias correspondiente y viceversa.
• Que el soporte para el hardware esté compilado dentro del núcleo o como módulo. Si es un módulo, que esté correctamente configurado en
modules.conf y que se haya cargado. Debes usar lsmod para ver si está cargado. Comprueba sys.log o ejecuta modprobe <módulo>
para ver cualquier mensaje de error. Si se carga correctamente, puede que necesites añadir el modprobe en tus guiones de arranque.
• Que tus permisos están ajustados adecuadamente, especialmente para los dispositivos. LFS utiliza grupos para facilitar estos ajustes, pero
esto también añade el paso de incluir los usuarios en los grupos para permitir el acceso. Un simple moduser −G audio <usuario> puede ser
todo lo que haga falta para que el usuario tenga acceso al sistema de sonido. Ante cualquier cuestión que comience con "Funciona como
root, pero no como..." deberian comprobarse detenidamente los permisos antes de preguntar.
• BLFS usa en ocasiones /opt/<package>.La principal objeción a esto se centra en la necesidad de ampliar tus variables de entorno para
cada paquete ubicado aquí (por ejemplo, PATH=$PATH:/opt/kde/bin). En algunos casos, el paquete te guiará a través de los cambios, pero
en otros no. El Apéndice B está disponible para ayudarte a comprobarlo.
Además de una breve explicación del problema que tienes, las cosas escenciales a incluir en tu petición son:
(Advierte que el hecho de haberte desviado del libro no significa que no te ayudemos. Simplemente nos sirve para ver otras posibles causas para tu
problema.)
Espera recibir orientaciones en lugar de instrucciones específicas. Si se te indica que leas algo, por favor hazlo. Generalmente implica que la respuesta
era demasiado obvia y que la pregunta no debería haberse realizado si se hubiese hecho una búsqueda antes de preguntar. Los voluntarios en la lista de
correo prefieren no ser usados como una alternativa a hacer una búsqueda razonable por tu parte. Por otro lado, la calidad de tu experiencia con BLFS
también aumenta con estas búsquedas, y la calidad de los voluntarios mejora debido a que no sienten que se abusa de su tiempo, por lo que están más
dispuestos a participar.
Eric S. Raymond ha escrito un artículo excelente sobre cómo pedir ayuda en general en Internet. Está disponible en línea en
http://www.catb.org/~esr/faqs/smart−questions.html. Léelo y sigue las pistas que se mencionan en el documento, de esa forma tendrás más
posibilidades de obtener una respuesta y conseguir la ayuda que necesites.
Información de contacto
Por favor, dirige tus mensajes a una de las listas de correo de BLFS. Mira Listas de correo y archivos para más información sobre las listas de correo
disponibles.
El actual coordinador de BLFS es Larry Lawrence. Si necesitas contactar con Larry, envía un mensaje a larry@linuxfromscratch.org.
Si necesitas o deseas contactar con el equipo de LFS−ES, traductores del presente libro, envía tu mensaje a lfs−es@listas.escomposlinux.org
Información de contacto 20
Capítulo 2. Información importante
Conseguir y desempaquetar el software
Aquellas personas que hayan construido un sistema LFS estarán familiarizados con los principios generales de la descarga y desempaquetado del
software. Sin embargo, repetiremos aquí parte de esa información para aquellos que sean nuevos construyendo su propio software.
Cada conjunto de instrucciones de instalación contiene una URL desde la que puedes descargar el paquete. Sin embargo, guardamos una selección de
parches disponible por http. Estos se mencionan en las instrucciones de instalación cuando son necesarios.
Aunque puedes guardar los paquetes con las fuentes donde quieras, asumimos que los desempaquetas y descomprimes los parches necesarios en
/usr/src.
Nunca podremos hacer suficiente hincapié en que debes comenzar con un árbol de fuentes limpio cada vez. Esto significa que, si tienes un error,
usualmente es mejor borrar el árbol de las fuentes y volver a desempaquetarlo antes de probar de nuevo. Obviamente, esto no es aplicable si eres un
usuario avanzado retocando los Makefiles y el código C, pero en caso de duda, comienza con un árbol limpio.
Desempaquetar el software
Si un archivo está empaquetado con tar y comprimido con gzip, se desempaqueta ejecutando uno de los comandos siguientes, dependiendo del nombre
del archivo:
Si un archivo está empaquetado con tar y comprimido con bzip2, normalmente se desempaqueta ejecutando:
Finalmente, necesitas ser capaz de descomprimir los parches, que generalmente no están empaquetados con tar. La mejor forma de hacerlo es copiar el
fichero del parche en /usr/src y entonces ejecutar uno de los siguientes comandos, dependiendo de si el fichero es .gz o .bz2:
gunzip ficheroparche.gz
bunzip2 ficheroparche.bz2
Esta es una cuestión sin respuesta obvia para un sistema basado en LFS
En los sistemas Unix tradicionales, /usr normalmente contiene los ficheros que vienen con la distribución, y el árbol /usr/local queda libre para
que el administrador local añada cosas. En realidad, la única regla dura y rápida es que las distribuciones Unix no deberían tocar /usr/local,
excepto, por supuesto, para crear los directorios básicos que contiene.
Con las distribuciones Linux, como RedHat, Debian, etc. una posible regla es que /usr está administrado por el sistema de paquetes de la distribución,
y /usr/local no. De este modo, la base datos del administrador de paquetes conoce cada fichero que se encuentra en /usr.
Los usuarios de LFS construyen su propio sistema, y por eso decidir dónde termina el sistema y comienzan los ficheros locales no es sencillo. Por tanto
debe hacerse la elección para que las cosas sean más fáciles de administrar. Hay varias razones para dividir los ficheros entre /usr y /usr/local.
• En una red con varias máquinas corriendo todas LFS, o una mezcla de LFS y otras distribuciones Linux, /usr/local podría usarse para
almacenar paquetes que son comunes entre todos los ordenadores de la red. Pueden estar montadas mediante NFS o replicarse a partir de un
servidor. Aquí local indica local para el sitio.
• En una red con varios ordenadores en los que en todos se ejecuta un sistema LFS idéntico, /usr/local podría almacenar paquetes que
son diferentes entre máquinas. En este caso, local se refiere a cada ordenador individual.
• Incluso en un ordenador único, /usr/local puede ser útil si tienes instaladas varias distribuciones simultáneamente, y quieres un lugar
donde poner los paquetes que serán iguales en todas ellas.
• O puede que reconstruyas habitualmente tu LFS, pero quieras un lugar en el que poner los ficheros que no quieras reconstruir cada vez. De
este modo puedes vaciar el sistema de ficheros del LFS y empezar con una partición limpia sin perder nada.
Algunas personas preguntan: ¿por qué no usar su propio árbol de directorios, por ejemplo /usr/site, en lugar de /usr/local?
Nada te lo impide, muchos sitios crean sus propios árboles, sin embargo esto complica la instalación de nuevo software. Los instaladores automáticos
con frecuencia buscan las dependencias en /usr y /usr/local, y si el fichero que buscan se encuentra en /usr/site el instalador seguramente
falle hasta que le especifiques en dónde debe mirar.
Todas las instrucciones del BLFS instalan los programas en /usr a menos que se especifique otra cosa. Hay ejemplos en los que ciertos ficheros son
colocados en la jerarquía /usr/local, pero están documentados y, generalmente, es por una buena razón. Estas excepciones deberían estar bien
documentadas en el libro. Si encuentras alguna que no lo esté, por favor ¡dínoslo!
Parches opcionales
A medida que sigas las diversas secciones del libro, observarás se incluyen varios parches requeridos para una correcta y segura instalación de los
paquetes. La filosofía general del libro es incluir parches que cumplan uno de los siguientes criterios:
En resumen, el libro solo incluye parches que son Requeridos o Recomendados. Hay un Subproyecto Parches que hospeda varios parches (incluidos los
parches que aparecen en el libro) para permitir que configures tu LFS del modo que prefieras.
Si estás instalado un paquete en una ruta que no sea estándar, la lista de comprobaciones que hay en el Apéndice B te será de ayuda si el paquete no
funciona como se espera.
Si estás buscando un paquete que no se incluye en el libro, lo siguiente son diferentes caminos por los que puedes buscar dicho paquete.
• Si sabes el nombre del paquete, entonces búscalo en FreshMeat , http://freshmeat.net/. Busca también en Google, http://google.com/. A
veces una búsqueda del rpm en http://rpmfind.net/ o del deb en http://www.debian.org/distrib/packages#search_packages también puede
llevar a la página oficial del paquete.
• Si sabes el nombre del ejecutable, pero no del paquete al que pertenece, prueba primero a buscar en Google el nombre del ejecutable. Si los
resultados son infructuosos, prueba a buscar dicho ejecutable en el repositorio de Debian,
http://www.debian.org/distrib/packages#search_contents.
• Muchos de los más nuevos paquetes siguen el baile de la rutina ./configure && make && make install. La ayuda sobre las opciones
soportadas por configure se puede obtener mediante el comando ./configure −−help.
• Muchos de los paquetes contienen documentación sobre cómo compilarlo e instalarlo. Algunos de los documentos son excelentes, otros no
tanto. Comprueba en la página oficial del paquete si hay consejos adicionales y actualizados para compilar y configurar el paquete.
• Si tienes problemas para compilar un paquete, consulta si aparece el error en los archivos de lfs en http://search.linuxfromscratch.org/ y si
esto falla prueba a buscarlo en Google. Si todo esto falla, inténtalo en la lista de correo/grupo de noticias de soporte del blfs.
Sugerencia: Si encuentras un paquete que sólo está disponible en formato .deb o .rpm, hay dos pequeños guiones rpm2targz y
deb2targz, disponibles en http://www.linuxfromscratch.org/~tushar/downloads/, para convertir los archivos a formato tar.gz.
Parches opcionales 22
II. Configuración posterior a LFS y Software Adicional
Índice
3. Configuración posterior al LFS
4. Seguridad
5. Sistemas de ficheros
6. Editores
7. Intérpretes de comandos
La mayoría de la gente que llega a Linux desde una formación en Windows, encuentra algo extraño el concepto de ficheros de configuración sólo de
texto. En Linux, casi toda la configuración se hace utilizando ficheros de texto. La mayoría de estos ficheros se pueden encontrar en la jerarquía /etc.
A menudo, hay disponibles programas gráficos de configuración para distintos subsistemas, pero casi siempre son simples y agradables frontales
(frontends) del proceso de editar el fichero. La ventaja de la configuración utilizando sólo texto es que puedes editar los parámetros usando tu editor de
texto favorito, ya sea vim, emacs o cualquier otro.
La primera tarea es crear un disquete de rescate, pues es la necesidad mas crítica. Entonces se configura el sistema para facilitar la adición de usuarios,
en "Configuración para añadir usuarios", pues esto puede afectar a las elecciones que hagas en los tres siguientes tópicos: "/etc/inputrc", "Los ficheros
de inicio de Bash" y "/etc/vimrc, ~/.vimrc".
Los siguiente tópicos, "/etc/issue (Personalizar tu entrada al sistema)", "Generación de números aleatorios", "Cuestiones de las páginas de manual" y
"Cuestiones de las páginas info" son resueltos entonces, en dicho orden. Estos no tienen mucha iteración con los otros tópicos de este capítulo.
En realidad, esta sección es sobre la creación de un disquete de rescate. Como el nombre rescate implica, el sistema anfitrión tiene un problema, con
frecuencia la pérdida de información de la partición o corrupción del sistema de ficheros, que impide que arranque y/o funcione normalmente. Por esta
razón, no debes depender de recursos procedentes del anfitrión a "rescatar". Asumir que cualquier partición o disco duro estará disponible es una
presunción arriesgada.
Atendiendo a los peligros, el disco de rescate creado aquí no tiene dependencia de los recursos del sistema anfitrión, aparte de la arrancabilidad básica y
la validez del hardware. Como mínimo, los tipos de fallos mas comunes que requieren de un disco de rescate deben ser resueltos con el contenido del
disquete de arranque. Esto debería incluir la común pérdida de particiones (el registro maestro de arranque se ha perddido o está corrupto), corrupción
del sistema de ficheros, y poder crear y editar ficheros que puedan haberse perdido o corrompido, posiblemente por efecto de uno de los otros dos
problemas.
Debería haber disponibles utilidades adicionales para buscar texto o ficheros, mover y eliminar ficheros y muchas otras operaciones normales que es de
esperar que se necesiten durante la reconstrucción.
Aquí la intención es crear un "disquete de rescate" que soportará las operaciónes comunes listadas arriba. Estas funciones se suministran mediante la
inclusión de ejecutables seleccionados procedentes de busybox y e2fsprogs. Opcionalmente pueden incluirse también un editor básico y una utilidad
rudimentaria de particionado de discos.
Esto, sin embargo, no es el límite. Aquí se describe un disco mínimo, pero puedes añadir todo lo que puedas meter en el disquete. Mas aún, si un
disquete no es suficiente para cubrir tus necesidades, puedes hacer un conjunto de rescate multidisquete que lo haga. En esencia, el cielo es el límite.
Esto se expone mas adelante. El número de otras variaciones posibles es demasiado grande para mencionarlas aquí.
Prerrequisitos
Deberias disponer de varios disquetes de confianza. Hay quien prefiere usar el comando fdformat para prepararlos debido a que también los verifica.
Mira los detalles en su página de manual. Otra buena idea es tener siempre preaparado un duplicado del disquete de rescate, pues se deterioran con el
tiempo.
Estas instrucciones asumen que hay instalado un sistema base LFS utilizando el sistema de ficheros ext2/ext3.
Las versiones del núcleo 2.4.22 y 2.6 anteriores a test6 tienen una deficiencia que impiden que busybox y aplicaciones similares arranquen
correctamente. Necesitas descargar y aplicar el parche init−1 para corregir esto, permitir que busybox sea usado por nuestra aplicación, y reconstruir tu
núcleo. Ten en cuenta las siguientes cuestiones sobre el núcleo mientras lo haces.
Para usar este procedimiento, necesitas tener activado el soporte para el dispositivo de bucle (loopback) en el núcleo de tu anfitrión.
Deberías hacer un núcleo personalizado que incluya solo aquellas características necesarias para rescatar tu sistema, así tendrá un menor tamaño. No
tiene sentido construirle soporte para cosas como XFree86, DRI, etc, pues muchos rescates se realizan desde la línea de comandos. En esta línea, si
tienes GCC−2.95.3, se sabe que este genera núcleos mas pequeños. Si lo haces no olvides cualquier módulo cargable (que no se mencione aquí) que
puedas necesitar. Deben compilarse con el mismo compilador usado para hacer el núcleo.
La imagen de rescate debe incluir soporte para el sistema de ficheros de tu elección (aquí asimimos ext2/ext3), disco de memoria (ramdisk) y disco de
memoria inicial (initrd). Desactiva todo lo que puedas de la configuración del núcleo. Deberías mantener el soporte para los sistemas de ficheros proc y
tmpfs, pues son de utilidad general. El sistema de ficheros proc se necesita para que mount informe correctamente.
Si instalas solo el conjunto mínimo de componentes mostrado en este documento, necesitarás un núcleo que ocupe 643 bloques o menos. Si quieres los
programas opcionales (un editor muy básico como ed, un particionador de discos rudimentario como sfdisk) es necesario que el núcleo sea de 595
bloques o menos. Esto no debería ser un problema a menos que tus necesidades sean esotéricas. En el sistema usado para desarrollar esta versión del
procedimiento, usando solo sistemas de ficheros ext2 y sin utilizar para la recuperación la red o CDs, la imagen del núcleo es de solo 481 bloques. Y
puede haber mas por ganar, no se examinó detenidamente para encontrar ahorros adicionales.
De aquí en adelante, esta imagen del núcleo se llamará "rescueimage". En realidad, puedes ponerle el nombre que quieras y usar ese nombre en los
comandos que lo contengan, en sustitución de "recueimage".
Si no consigues que tu imagen de rescate baje hasta el tamaño necesario para permitir todo lo que necesitas en la imagen de disco de memoria, no te
procupes. Siempre puedes construir un conjunto de dos diquetes, uno de arranque y otro como raíz. El núcleo te pedirá que insertes el disquete con el
sistema de ficheros raíz. Esto permitirá tener espacio para una imagen comprimida de disco de memoria de 1440 bloques y una imagen de rescate del
mismo tamaño.
Los anteriores límites en el tamaño de la imagen de rescate pueden variar al cambiar las configuraciones específicas locales del sistema. Úsalas solo
como una guía, y no como la bíblia. El tamaño de la imagen de rescate mostrado por ls −sk es solo una aproximación debido a cierto "aumento". En el
sistema usado para desarrollar este versión del procedimiento dicho comando muestra 488 bloques, pero el número real de bloques escritos es de solo
480 y un poco, lo que indica que en realidad ha usado 481 bloques.
mkdir −p /mnt/loop1
dd if=/dev/zero of=/tmp/rfloppy bs=1k count=4096
dd: Esta es una utilidad generalizada de copia de entrada a salida que también tiene muchas capacidades de transformación.
if=/dev/zero: Este parámetro asigna el fichero de entrada de dd a un dispositivo que devuelve un flujo infinito de ceros.
bs=1k count=4096: Estos parámetros le indican a dd que lea y escriba en "trozos" de 1024 bytes y procese 4096 "trozos".
La razón para usar estos comandos es que funcionan sea cual sea la versión de mount (las mas antiguas no tienen la opción −o loop) o si
/etc/mtab es un enlace simbólico a /proc (lo que hace que mount no pueda "desvincular" un dispositivo de bucle debido a la información
"perdida"). Tras estos tres comandos se facilita un conjunto alternativo de comandos que puedes usar si no tienes ninguna de estas situaciones.
losetup /dev/loop1 /tmp/rfloppy: Este comando "vincula" un dispositivo de bucle al fichero vacio.
mke2fs −m 0 −N 504 /dev/loop1: Este comando crea un sistema de ficheros ext2 en el dispositivo de bucle (lo que significa que en realidad es creado
en el fichero al que está vinculado el dispositivo de bucle) y no reserva bloques. El parámetro −N 504 causa que solo se asignen 504 inodos, dejando
espacio en el sistema de ficheros para otras cosas necesarias.
mount −t ext2 /dev/loop1 /mnt/loop1: Esto monta el sistema de ficheros recién creado igual que si fuese un dispositivo real, como un disco duro o un
disquete. Esto le permite operar a todos los comandos normales de I/O como si hubiese presente un dispositivo real.
Si tu mount soporta la opción −o loop y tu /etc/mtab es un fichero real en vez de un enlace simbólico a /proc, los tres comandos anteriores
pueden reemplazarse por los dos comandos siguientes:
mke2fs −F −m 0 −N 504 /tmp/rfloppy: Como antes, se crea un sistema de ficheros ext2 de solo 504 inodos y sin bloques reservados, que será
vinculado a un dispositivo de bucle. El parámetro −F elimina una pregunta irritante que aparece cuando mke2fs advierte que no estás accediendo a un
dispositivo.
mount −o loop /tmp/rfloppy /mnt/loop1: Este comando le indica a mount que vincule el mencionado fichero a un dispositivo de bucle seleccionado
automáticamente (el primero disponible) y monte el dispositivo en /mnt/loop1.
Una nota de advertencia. Si no estás trabajando dentro de un entorno chroot, asegurate de que no omites accidentalmente la referencia en los
comandos a /mnt/loop1. Si lo haces podrías reemplazar los componentes equivalentes de tu anfitrión con los componentes instalados por estos
procedimientos. Incluso si estás en un entorno chroot, deberías ser muy cuidadoso si tu entorno es el sistema LFS recién construido que piensas usar
como anfitrión en el futuro.
Primero, para tener tanto espacio libre como sea posible, elimina el directorio lost+found, que no es necesario pues solo lo utiliza fsck. Puesto que
fsck nunca se ejecutará sobre este sistema de ficheros, es innecesario.
rmdir /mnt/loop1/lost+found/
mkdir /mnt/loop1/{dev,proc,etc,sbin,bin,lib,mnt,usr,var}
Añade los ficheros de dispositivos necesarios a la imagen initrd. Si utilizas devfs, el siguiente comando funcionará bien, pues solo tendrás los
dispositivos que utilizas.
Si utilizaste MAKEDEV para crear los dispositivos de tu anfitrión, querrás utilizar algo parecido a este comando largo para minimizar el gasto de
espacio con inodos innecesarios.
Debes modificar esto para ajustarlo a la configuración de tu imagen de rescate y otras necesidades. Por ejemplo, puede que necesites dispositivos
SCSI y puede que no necesites dispositivos "frame buffer" o el directorio de pseudoterminales. Igualmente, el número de discos duros y particiones que
incluyas debe ser el mínimo que necesites. No se ha hecho un estudio exaustivo de la siguiente lista, así que se puede ahorrar mas espacio e inodos
mediante un "ajuste fino" de este conjunto.
mkdir /mnt/loop1/dev/pts
cp −a \
/dev/null /dev/console \
/dev/fb[0−7] /dev/fd /dev/fd0 /dev/fd0h1440 /dev/full \
/dev/hda* /dev/hdb* /dev/hdc* /dev/hdd* /dev/initctl /dev/kmem \
/dev/loop[0−3] /dev/lp0 /dev/mem /dev/port \
/dev/psaux /dev/ram \
/dev/ram0 /dev/ram1 /dev/ram2 /dev/ram3 /dev/random /dev/rtc \
/dev/shm /dev/stderr /dev/stdin /dev/stdout /dev/tty \
/dev/tty[0−9] /dev/ttyS0 /dev/ttyS1 /dev/urandom /dev/zero \
/mnt/loop1/dev
Si lo eliges, puedes copiar todo o parte de tus ficheros /etc/passwd y /etc/group. Pero aunque cada uno tenga menos de 1024 bytes perderás
dos bloques y dos inodos en tu disco de memoria inicial. Esto en realidad solo importa porque intentamos apretarlo todo en un disquete de 1,44MB.
Cada pequeño bit ayuda. La estrategia aquí tomada es crear estos dos ficheros como parte de los procesos de arranque e inicialización del rescate. Los
comandos que crean estos dos ficheros serán integrados dentro del guión rcS que linuxrc (en realidad busybox ) invoca tras la carga del initrd. De
esta forma no se usan mas inodos o bloques para estos ficheros.
Alguien puede que quisiera copiar su directorio /etc/rc* dentro de la imagen de disco de memoria, pero esto puede no tener valor, aparte de usarlo
como archivo en un grave caso de recuperación. Si quieres que el sistema se inicialice automáticamente tras repararlo, puede tener algún sentido. Pero
poca gente necesita o quiere que esto suceda. Si el sistema de ficheros del disco duro está corrupto, ¿qué de bueno harán los guiones de montaje?
Algunos guiones pueden ser útiles, como el acceso a una red para copiar datos de respaldo cuando el sistema de ficheros sea de nuevo utilizable. El
punto es que deberías copiar solo las partes que puedas usar, pues el espacio es un premio en el disquete.
Aquí solo se incluirá fstab. Esto es práctico porque facilita el montaje de las particiones que puedan usarse y también puede ser examinado y usado
como guia de lo que está disponible y de lo que puede necesitar reconstrucción. Debido a que puede ser mas largo que necesario, deberías editarlo,
eliminar cualquier entrada innecesaria y minimizar los comentarios. No es necesario mas cambios, pues los guiones de arranque no se incluyen y no se
hará un montaje automático usando fstab. Si decides incluir algunos guiones de arranque que intenten montar cosas, cambia las entradas de fstab a
noauto en el campo de opciones, para que no provoque un intento de montar una partición potencialmente corrupta. Copialo a /tmp, editalo como
desees y entonces:
cp −a /tmp/fstab /mnt/loop1/etc
Ahora se añadirá el guión de inicialización. Como se mencionó antes, linuxrc es un enlace simbólico a busybox . Tras la carga del núcleo y del disco
de memoria inicial, el núcleo le pasa el control a linuxrc (busybox ). Este quiere ejecutar un guión /etc/init.d/rcS para hacer la configuración
inicial.
Si usas devfsd necesitarás ajustar el guión rcS para manejar el inicio de devfsd. Pon los siguientes comandos en /mnt/loop1/etc/init.d/rcS.
Puede que también quieras añadir alguno de los procesos mostrados en la versión sin devfs que le sigue.
#!/bin/sh
mount −t devfs devfs /dev
/sbin/devfsd /dev
Si no utilizas devfsd, si no que creaste un directorio /dev estático usando MAKEDEV o un proceso similar, el guión rcS hará cosas algo diferentes.
Al mismo tiempo, no olvides que está creando los ficheros /etc/passwd y /etc/group para salvar espacio en el disquete.
El siguiente guión montará /proc, activará la partición de intercambio (no hay peligro si al hacerlo falla) creará los ficheros /etc/passwd y
/etc/group, y creará un directorio de registro. Crea el guión con:
mkdir −p /mnt/loop1/etc/init.d
cat >/mnt/loop1/etc/init.d/rcS << EOD
#!/bin/sh
mount −t proc proc /proc
swapon −a
mkdir /var/log
EOD
chmod u+x /mnt/loop1/etc/init.d/rcS
A menos que le añadas muchas cosas a este guión, lo que es aconsejable, lo anterior debería estar razonablemente cerca de lo que necesitas.
Instalar paquetes
Hay dos paquetes que deben instalarse. El paquete busybox incorpora las funciones centrales que suministran un intérprete de comandos y muchas
utilidades básicas. Un paquete de sistemas de ficheros, como e2fsprogs o un paquete para el sistema de ficheros que estés usando, proporcionará un
conjunto mínimo de utilidades para la comprobación y reconstrucción del sistema de ficheros. No se instalará el paquete completo, solo ciertos
componentes necesarios.
Instala busybox dentro de la imagen del disco de memoria inicial. Busybox incorpora muchas de las funciones de los programas Unix dentro de un
ejecutable pequeño.
make &&
make PREFIX=/mnt/loop1 install &&
> /mnt/loop1/var/utmp
Creamos var/utmp porque busybox lo necesita para que el comando reboot funcione correctamente. Si este fichero no existe cuando se inicia
busybox, el comando reboot no funcionará. Esto puede ser malo para las personas que no disponen del botón reset.
Si utilizas devfs para crear dispositivos al vuelo y liberar preciosos inodos en el disquete, debes instalar también devfsd para facilitar los dispositivos
que busybox espera encontrar. Usa los siguientes comandos para instalarlo.
Si utilizas el sistema de ficheros ext2 o ext3 (con transaciones), puedes usar los siguientes comandos para instalar la funcionalidad mínima que debería
permitirte hacer usables de nuevo tus discos duros. Si utilizas ext3, recuerda que es parte del paquete e2fsprogs y puedes conseguir los componentes,
que mayormente son enlaces duros, de los mismos lugares mostrados a continuación. Si utilizas algún otro sistema de ficheros, como reiserfs, debes
aplicar los principios que ves aquí para instalar parte del paquete en su lugar.
LDFLAGS='−s'
mkdir build &&
cd build &&
../configure −−prefix=/mnt/loop1/usr −−with−root−prefix="" \
−−disable−swapfs −−disable−debugfs \
−−enable−dynamic−e2fsck −−disable−nls −−disable−evms \
−−disable−rpath &&
make LDFLAGS="$LDFLAGS" &&
strip −p −−strip−unneeded −−remove−section=.comment \
−o /mnt/loop1/sbin/mke2fs misc/mke2fs &&
strip −p −−strip−unneeded −−remove−section=.comment \
−o /mnt/loop1/sbin/e2fsck e2fsck/e2fsck &&
chmod 555 /mnt/loop1/sbin/{mke2fs,e2fsck}
Hay dos utilidades muy útiles que cualquier disco de rescate debería tener para ayudar a una recuperación mas rápida y exacta. La primera es una
utilidad de particionado. El programa sfdisk se usa aquí por su reducido tamaño y gran poder. Si embargo te aviso, no es lo que se considera
"amigable". Pero los programas fdisk y cfdisk son sustancialmente mas grandes o requieren mas objetos compartidos, como ncurses.
La segunda utilidad es un editor. Muechos editores gráficos son demasiado grandes por naturaleza y también requieren objetos compartidos
adicionales. Por esta razón, aquí se usa ed. Es pequeño, no necesita objetos compartidos adicionales y es un editor basado en expresiones regulares que
es el antecesor de casi todos los editores posteriores que soportan edición basada en expresiones regulares, sean gráficos o no. Es un "editor de
contexto" y ofrece características de edición poderosas, pero no gráficas. Hay otros muchos editores que pueden ser apropiados, eres libre de usar uno
de ellos en su lugar.
Lee los ficheros INSTALL y README de busybox para ver cómo incluir un editor vi. Todavía no ha sido investigado aquí, por lo que puede que sea
facil o no meterlo dentro de una única imagen de disquete, como hacemos aquí.
Sfdisk y ed se instalan, esencialmente, copiandolos desde tu anfitrión. Se usa strip solo para asegurar que no tienen "exceso de peso", aunque, en
realidad, en la instalación del LFS base ya se debería haber depurado. Usa los siguientes comandos:
Igualmente, recordando tu limitaciones de espacio, copia cualquier otro binario y librería que necesites a la imagen. Usa el comando ldd para ver qué
librería necesitarás copiar para cualquier ejecutable. No olvides depurarlos también antes de copiarlos a la imagen o usar strip como antes para
"copiarlos".
Una vez que tengas instaladas todas las utilidades anteriores y las adicionales que desees, utiliza el comando ldd, como se mencionó antes, sobre
aquellos que no se han listado en este documento. Si se necesita alguna librería adicional, añadela a los comandos mostrados abajo.
Si instalaste solo aquellas cosas mostradas arriba, los objetos compartidos necesarios serán muy pocos. Puedes añadirlos a la imagen del disco de
memoria con:
Advierte que los comandos anteriores cambian el nombre de las librerías, eliminando la necesidad de usar enlaces simbólicos. Si añades otros objetos
compartidos adicionales, estate atento ante oportunidades similares y también ante los errores que puedan presentarse.
Desmonta el fichero de bucle. Si usaste la opción −o loop de mount, el "vínculo" entre el dispositivo de bucle y el fichero será eliminado cuando se
haga el desmontaje. Simplemente omite losetup −d /dev/loop1 de la siguiente secuencia. El parámetro −9 se usa con gzip para crear la imagen
comprimida lo mas pequeña posible. Para asegurar que cabrá en el disquete, lista el tamaño del fichero.
Ahora la imagen de rescate y la imagen del disco de memoria inicial se escribirán al disquete de arranque. Antes de hacer esto, calcula el número de
bloques necesario para la imagen de rescate y para el initrd, individualmente, mediante la división de cada tamaño por 1024 y la adición de uno si
queda resto. Suma estos dos resultados. El total debe ser 1.440 bloques o menos. Si el total es mayor, no te preocupes demasiado. Mas adelante se
muestran los cambios para crear un grupo de dos disquetes. Por supuesto, puedes reexaminar tus elecciones y tratar de reducir la imagen de rescate o la
imagen del disco de memoria inicial.
Para crear un disquete único de rescate, usando devfs, utiliza los siguientes comandos. Si usas la configuración estática de /dev utiliza /dev/fd0 en
lugar de /dev/floppy/0.
rdev /dev/floppy/0 0,0: establece el sistema de ficheros raíz que el núcleo usará durante el arranque. Debido a que se carga como initrd,
automáticamente será establecido como el dispositivo raíz, inicialmente. Por tanto, 0,0 le indica "sin valor", dicienlo al núcleo que no monte ningún
otro dispositivo. Algunos le pasan /dev/fd0 o algo similar. Pero esto tiene efecto solo cuando linuxrc (en realidad busybox ) termina y se invoca al
proceso init. Puesto que esto no se hará aquí, y el disquete no es un sistema de ficheros válido, sería algo inutil. Un disco duro sería mejor elección si
estás buscando levantar el sistema automáticamente tras su reparación. Puesto que busybox suministra el comando reboot, la inicialización automática
no es necesaria.
rdev −R /dev/floppy/0 0 establecerá a cero las "opciones de la raíz". No tienen uso en esta aplicación.
480+1 records in
480+1 records out
En este ejemplo, la imagen de rescate (el núcleo) tenía un tamaño de 480+1 bloques. Asegurate de que este número, que puede ser diferente para ti,
coincide con el que calculaste antes. Ahora necesitas calcular un "número mágico" que será insertado dentro de la imagen de rescate. El valor consiste
en tres partes significativas. Dos se exponen aquí. La tercera se toca un poco mas tarde.
Los bits 0 − 10 contendrán el tamaño de la imagen de rescate, en bloques, que calculaste anteriormente y que debe coincidir con el resultado del
anterior dd. El bit 14 (el quinceavo bit, que es 2 a la catorceava potencia o 16.384) es una marca que, cuando se establece a 1, le indica al núcleo que
debe cargar una imagen del disco de memoria inicial. Para el disquete de rescate único, los dos números 16.384 y 481 (o el número adecuado para el
tamaño de tu imagen de rescate) se suman para generar un valor decimal, como 16865. Este valor se inserta en el lugar adecuado de la imagen de
rescate mediante el comando rdev ejecutado a continuación.
Inserta el "número mágico" dentro de la imagen de rescate y entonces escribe el sistema de ficheros raíz en el disquete tras la imagen de rescate,
ejecutando los siguientes comandos y poniendo el número adecuado. Advierte que el número del parámetro seek debe ser el tamaño, en bloques, de tu
imagen de rescate. Si usaste la configuración estática de /dev, utiliza /dev/fd0 en el comando siguiente en lugar de /dev/floppy/0.
En este comando, seek se utiliza para posicionarse en el bloque siguiente al final de la imagen de rescate (480+1) y comenzar a escribir el sistema de
ficheros raíz al disquete.
Si no puedes vivir con un sistema de rescate de un único disquete, aquí está lo que hay que hacer para crear un sistema simple de dos disquetes. Ten en
cuenta que las posibilidades finales presentes por la disponibilidad de linuxrc y otros componentes no se exponen aquí. Aquí solo usaremos la
capacidad del núcleo para pedir un segundo disquete que contenga la imagen initrd y la carge.
Modifica las instrucciones anteriores como sigue. Primero se necesita un número mágico diferente. El quinceavo bit (bit 14) todavía debe establecerse,
pero el tamaño de la imagen de rescate, en bloques, se sustituye con un cero. El tercer componente, que no se explicó arriba, es usado ahora. Este es el
dieciseisavo bit (bit 15) del "número mágico". Cuando se establece, le indica al núcleo que le solicite al usuario la inserción del disquete "raíz".
Entonces carga la imagen intrd de ese disquete. Debido a que el tamaño de la imagen de rescate se sustituyó por cero, el núcleo inicia la carga a partir
del bloque cero (el primero) del segundo disquete.
El dieciseisavo bit (bit 15) representa 2 elevado a la quinceava potencia, o 32.768. Por tanto el nuevo número mágico es 32.768 + 16.384, que es
49.152. Este valor le indica al núcleo que pida, y después carge, una imagen del disco de memoria inicial a partir del primer bloque del disquete
insertado. Así que tu primera modificación es en el comando para escribir el "numero mágico" en la imagen de rescate del disquete.
Ten en cuenta que la imagen initrd no se ha copiado todavía al disquete. Extrae el disquete de arranque e inserta otro disquete que almacenará tu
sistema de ficheros raíz. Ejecuta estos comandos modificados (no olvides usar /dev/fd0 si no utilizas devfs). Advierte que no se usa un parámetro
seek.
Esto es todo. A partir de aquí las posibilidades solo están limitadas por tu imaginación y tenacidad para añadir mejoras. Y tu voluntad para buscar la
documentación disponible. Un buen punto de partida es el directorio "Documentation" del arbol de las fuentes de tu núcleo. Se puede obtener mas
ayuda en LFS Hints (por favor, utiliza uno de los sitios réplica disponibles) y TLDP.
El directorio /etc/skel almacena copias de varios ficheros de inicialización y otros ficheros que deben copiarse a los directorios personales de los
nuevos usuarios cuando el programa /usr/sbin/useradd añade el nuevo usuario.
Useradd
El programa useradd utiliza una colección de valores por defecto guardados en /etc/default/useradd, si existe. Si el fichero no existe utiliza
algunos valores internos. Puedes ver los valores por defecto ejecutando /usr/sbin/useradd −D.
Para cambiar estos valores a algo nuevo, crea un fichero /etc/default/useradd con los mismos valores de la salida de /usr/sbin/useradd −D.
Este es un ejemplo.
# Inicio de /etc/default/useradd
GROUP=100
HOME=/home
INACTIVE=−1
EXPIRE=
SHELL=
SKEL=/etc/skel
# Fin de /etc/default/useradd
La única cosa que falta en el fichero es el intérprete de comandos por defecto. Añadela ejecutando:
/usr/sbin/useradd −D −s/bin/bash
/etc/skel
Para empezar crea un directorio /etc/skel y asegurate de que es escribible solo por el administrador del sistema, normalmente root. Crear el
directorio como root es la mejor forma.
El modo de todos los ficheros que pongas en /etc/skel a partir de esta parte del libro debe ser el de escribible solo por el propietario. También,
puesto que no estamos hablando de qué tipo de información sensible puede añadir eventualmente un usuario en sus copias de estos ficheros, deberías
hacerlas ilegibles para el "grupo" y para "otros".
También puedes poner otros ficheros en /etc/skel que pueden necesitar diferentes permisos.
Decide qué ficheros de inicialización deberían facilitarse en cada (o casi) directorio personal de un nuevo usuario. Las decisiones que tomes afectarán a
lo que hagas en las tres siguientes secciones, /etc/inputrc, la sección Los ficheros de inicio de Bash y /etc/vimrc, ~/.vimrc. Algunos o todos estos
ficheros serán útiles para root, cualquier usuario ya existente y los nuevos usuarios.
Los ficheros de estas secciones que puede que quieras colocar en /etc/skel incluyen .inputrc, .bash_profile, .bashrc,
.bash_logout, .dircolors, y .vimrc. Si no estás seguro de cuales de ellos deberías colocar, avanza a las siguientes secciones, lee cada
sección y cada referencia indicada, y entonces toma tu decisión.
Ejecutarás un grupo de comandos ligeramente modificado para los ficheros que se ubiquen en /etc/skel. Cada sección te recordará esto. En
resumen, los comandos del libro han sido escritos para ficheros que no se añaden a /etc/skel y envian el resultado al directorio personal del
usuario. Si el fichero va a estar en /etc/skel, cambia los comandos del libro para que en su lugar envien la salida aquí y entonces copia los ficheros
de /etc/skel a sus directorios apropiados, como /etc, ~ o el directorio personal de cualquier otro usuario que ya exista en el sistema.
Cuando añadas un nuevo usuario con useradd utiliza el parámetro −m, que le indica a useradd que cree el directorio personal del usuario y copie los
ficheros de /etc/skel (puede omitirse) al directorio personal del nuevo usuario. Por ejemplo:
/etc/inputrc
El fichero inputrc se ocupa del mapeado del teclado en ciertas situaciones. Este fichero es el fichero de inicio utilizado por readline, la librería
relacionada con la entrada usada por Bash y la mayoría de los demás intérpretes de comandos.
Para más información mira info bash −− Nodo: Readline Init, así como info readline. Son muchas las cosas que pueden hacerse con este único
fichero rc.
Los valores globales se establecen en /etc/inputrc. Los valores personales se establecen en ~/.inputrc. El fichero ~/.inputrc prevalecerá
sobre los valores del fichero de configuración global. En la siguiente página se configura Bash para usar /etc/inputrc si no hay un .inputrc
para un usuario cuando se lee /etc/profile (normalmente en la entrada al sistema). Si quieres que tu sistema utilice ambos, o no quieres un
manejo del teclado global, es buena idea colocar un .inputrc por defecto en el directorio /etc/skel para usarlo con los nuevos usuarios.
Lo que sigue es un /etc/inputrc básico junto con comentarios que explican lo que hacen las diversas opciones. Ten en cuenta que los comentarios
no pueden estar en la misma línea que los comandos.
Si vas a crear un .inputrc en /etc/skel usando el siguiente comando, cambia la salida del comando a /etc/skel/.inputrc y asegurate de
comprobar o establecer los permisos posteriormente. Entonces podrás simplemente copiar este fichero a /etc/inputrc y a los directorios
personales de los usuarios que ya existan en el sistema, incluido root, que necesita una versión privada de este fichero. Asegurate de usar el parámetro
−p de cp para mantener los permisos y asegurate de cambiar el propietario al apropiado.
"\eOd": backward−word
"\eOc": forward−word
/etc/inputrc 31
Más Allá de Linux From Scratch
# para xterm
"\eOH": beginning−of−line
"\eOF": end−of−line
# Fin de /etc/inputrc
EOF
Un intérprete interactivo de conexión se ejecuta después de una entrada al correcta sistema, mediante /bin/login, leyendo el fichero
/etc/passwd. Un intérprete interactivo de no conexión se ejecuta mediante la línea de comandos (por ejemplo, [prompt]$/bin/bash). Un
intérprete no interactivo está presente normalmente cuando se ejecuta un guión. Es no interactivo porque está procesando un guión y no está esperando
a que el usuario introduzca un comando.
Para más información, consulta info bash −− Nodos: Bash Startup Files e Interactive Shells (Ficheros de inicio de Bash e Intérpretes Interactivos)
Se necesitan los siguientes ficheros para asegurarse que se lee el entorno correcto para cada una de las formas en que el intérprete puede ser invocado:
/etc/profile y su equivalente privado ~/.bash_profile, y /etc/bashrc (no oficial) y su equivalente privado ~/.bashrc.
El fichero ~/.bash_logout no se usa para la invocación del intérprete. Es leído por este cuando un usuario sale del sistema.
Los ficheros /etc/profile y ~/.bash_profile son leídos cuando se ejecuta un intérprete interactivo de conexión. El fichero ~/.bashrc es
leído cuando se ejecuta un intérprete interactivo de no conexion y lee /etc/bashrc si existe.
También son útiles los ficheros /etc/dircolors y ~/.dircolors, llamados por /etc/profile. Controlan la salida coloreada de cosas como
ls −−color.
Aquí se muestra un fichero /etc/profile básico. Los comentarios en el fichero deberían explicar todo lo que necesitas. Para más información de
las secuencias de escape que puedes usar para el indicador del sistema (p.e la variable de entorno PS1) consulta info bash −− Nodo: Printing a
Prompt.
if [ −d "/usr/X11R6/bin" ] ; then
pathman /usr/X11R6/bin last
fi
HISTSIZE=1000
HISTIGNORE="&:[bf]g:exit"
PS1="[\u@\h \w]\\$ "
if [ −f "$HOME/.dircolors" ] ; then
eval $(dircolors −b $HOME/.dircolors)
fi
fi
# Fin de /etc/profile
EOF
Aquí se muestra un fichero /etc/bashrc básico. Los comentarios en el fichero deberían explicar todo lo que necesitas.
# Fin de /etc/bashrc
EOF
Aquí se muestra un fichero ~/.bash_profile básico. Los comentarios en el fichero deberían explicar todo lo que necesitas. Si quieres que cada
nuevo usuario tenga este fichero automáticamente, basta con que cambies la salida del siguiente comando a /etc/skel/.bash_profile y
compruebes los permisos tras la ejecución del comando. Entonces puedes copiar /etc/skel/.bash_profile a los directorios personales de los
usuarios que ya existan, incluido root, y estableces correctamente el grupo y propietario.
if [ −f "$HOME/.bashrc" ] ; then
source $HOME/.bashrc
fi
if [ −d "$HOME/bin" ] ; then
pathman $HOME/bin last
fi
export PATH
# Fin de ~/.bash_profile
EOF
Aquí se muestra un fichero ~/.bashrc básico. Los comentarios en el fichero deberían explicar todo lo que necesitas. Los comentarios e instrucciones
anteriores para usar /etc/skel para .bash_profile también son aplicables aquí. Solo los nombres de los ficheros de destino son diferentes.
if [ −f "/etc/bashrc" ] ; then
source /etc/bashrc
fi
# Fin de ~/.bashrc
EOF
Aquí se muestra un fichero ~/.bash_logout básico. Los comentarios en el fichero deberían explicar todo lo que necesitas. Comprobarás que el
fichero ~/.bash_logout no incluye un comando clear. Esto es porque el borrado de la pantalla se indica en el fichero /etc/issue.
# Fin de ~/.bash_logout
EOF
Si quieres utilizar las capacidades de dircolors ejecuta el siguiente comando. Los pasos anteriores para /etc/skel también pueden usarse para
facilitar un fichero .dircolors cuando se añade un nuevo usuario. Como antes, basta con cambiar el nombre del fichero de salida en el siguiente
comando y asegurar que los permisos, propietario y grupo son los correctos en los ficheros creados y/o copiados.
Ian Macdonald ha escrito una excelente colección de consejos y trucos para mejorar el entorno del intérprete de comandos. Puedes consultarla en
http://www.caliban.org/bash/index.shtml
/etc/vimrc, ~/.vimrc
El libro LFS instala vim como editor. En este punto, deberíamos aclarar que hay muchos otros editores, incluyendo a emacs, nano, joe y muchos más.
Cualquiera que haya indagado por Internet (especialmente por usenet), aunque sea por poco tiempo, seguramente haya observado, por lo menos, una
disputa, ¡normalmente entre usuarios de vim y emacs!
El libro LFS contiene un fichero vimrc básico. Aquí, intentaremos mejorar ese fichero. Al inicio, vim lee los ficheros /etc/vimrc y ~/.vimrc
(es decir, el vimrc global y el específico del usuario). Advierte que esto sólo es cierto si has compilado vim utilizando LFS−3.1 o posterior. Antes de
esto, el vimrc global era /usr/share/vim/vimrc.
Aquí tienes un vimrc ligeramente ampliado que puedes poner en /etc/vimrc para suministrar un efecto global. Por supuesto, si lo pones en
/etc/skel/.vimrc estará disponible para los usuarios que mas tarde añadas al sistema. También puedes copiar el fichero de
/etc/skel/.vimrc a /etc/vimrc y al directorio personal de los usuarios que ya existan, como root. Asegurate de establecer los permisos, el
propietario y el grupo si copias algo directamente de /etc/skel:
set bs=2
set columns=80
set background=dark
set wrapmargin=8
syntax on
set ruler
/etc/vimrc, ~/.vimrc 34
Más Allá de Linux From Scratch
Una de las FAQ de las listas lfs contempla las marcas de comentarios del fichero vimrc. Advierte que son " en lugar de las más usuales # o //. Esto es
correcto. La sintaxis de vimrc es ligeramente inusual.
Vamos a realizar una rápida explicación de lo que significa cada una de las opciones de este fichero de ejemplo:
• set bs=2 : Esto afecta al comportamiento de la opción de retroceso. Es bastante complejo, por lo que debes leer :help 'bs' para más
detalles.
• set columns=80 : Esto simplemente establece el número de columnas que se usan para la pantalla.
• set background=dark : Esto indica a vim que use colores que queden bien en un fondo oscuro.
• set wrapmargin=8 : Este es el número de caracteres a partir del borde derecho de la pantalla donde se hace el ajuste de línea.
• syntax on : Activa el resaltado de sintaxis de vim.
• set ruler : Esto hace que vim muestre la fila y la columna actual en la esquina inferior derecha de la pantalla.
Se puede encontrar más información sobre las muchas opciones de vim leyendo la ayuda que se encuentra dentro del mismo vim. Utilízala escribiendo
:help en vim para conseguir la ayuda general, o escribiendo :help usr_toc.txt para ver el Índice del Manual del Usuario.
El fichero /etc/issue es un fichero de texto plano que también aceptará algunas secuencias de Escape (ver más abajo) para insertar información
sobre el sistema. Además existe el fichero issue.net que puede usarse cuando se ingresa en el sistema remotamente. Sin embargo, ssh sólo lo usará
si estableces la opción en su fichero de configuración y, además, no interpretará las secuencias de escape que se describen más abajo.
Una de las cosas más comunes que la gente quiere hacer es borrar la pantalla en cada entrada al sistema. Lo más sencillo es poner una secuencia de
escape "clear" (borrar) en /etc/issue. Una forma simple de hacerlo es con clear > /etc/issue. Esto insertará el código de escape pertinente
al principio del fichero /etc/issue. Advierte que si haces esto, cuando edites el fichero deberías dejar el carácter ^[c de la primera línea.
agetty (el programa que normalmente analiza /etc/issue) reconoce las siguientes secuencias de escape. Esta información proviene de man agetty,
dónde puedes encontrar información adicional sobre el proceso de entrada al sistema.
El fichero issue puede contener ciertos códigos de escape para mostrar diferente información. Todos los códigos de escape consisten en una barra
invertida (\) seguida de una de las letras que se explican más abajo (por lo que \d en /etc/issue insertaría la fecha actual).
Cuando un sistema Linux comienza sin mucha interacción del operador, el fondo de entropía, los datos usados para calcular un número aleatorio, puede
estar en un estado fácilmente predecible. Esto crea la posibilidad real de que el número generado al inicio pueda ser siempre el mismo. Para
contrarrestar este efecto, deberías propagar la información del fondo de entropía a través de los apagados e inicios del sistema. El siguiente guión init.d
y sus enlaces efectuarán esta función automáticamente.
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Inicializando el generador de números aleatorios del núcleo..."
if [ −f /var/tmp/random−seed ]; then
cat /var/tmp/random−seed >/dev/urandom
fi
dd if=/dev/urandom of=/var/tmp/random−seed count=1 &>/dev/null
evaluate_retval
;;
stop)
echo "Salvando la semilla de números aleatorios..."
dd if=/dev/urandom of=/var/tmp/random−seed count=1 &>/dev/null
evaluate_retval
;;
*)
echo "Uso: $0 {start|stop}"
exit 1
;;
esac
# Fin de $rc_base/init.d/random
EOF
chmod 755 /etc/rc.d/init.d/random
Crea los enlaces simbólicos a este fichero en los directorios rc.d pertinentes con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/random ../rc0.d/K45random &&
ln −sf ../init.d/random ../rc2.d/S25random &&
ln −sf ../init.d/random ../rc3.d/S25random &&
ln −sf ../init.d/random ../rc4.d/S25random &&
ln −sf ../init.d/random ../rc5.d/S25random &&
ln −sf ../init.d/random ../rc6.d/K45random
#!/bin/bash
# VERSION: 20031029.0025
#
# Comprime (con bzip2 o gzip) todas las páginas de manual de una
# jerarquía y actualiza los enlaces simbólicos
# − Por Marc Heerdink <marc @ koelkast.net>
# Modificado por Mark Hymers <markh @ linuxfromscratch.org>
# para poder escojer entre ficheros gzip o bzip2 y tratar correctamente
# todos los enlaces simbólicos
#
# Modificado el 30/09/2003 por Yann E. Morin <yann.morin.1998 @ anciens.enib.fr>
# para aceptar compresión/descompresión, manejar correctamente enlaces
# duros, permitir el cambio de enlaces duros por blandos, especificar el nivel
# de compresión, procesar man.conf para todas las apariciones de MANPATH,
# permitir hacer copias de respaldo y permitir que se gu7arde la versión mas
# reciente de una página.
#
# TODO:
# − elegir el método de compresión por defecto basandose en la
# herramienta disponible : gzip o bzip2;
# − ofrecer una opción para elegir automáticamente el mejor método de
# compresión según la página (por ejemplo, comprobar página a página
# qué gzip/bzip2/lo que sea es mas efectivo);
# − cuando exista una variable de entorno MANPATH, utilizarla en vez de
# /etc/man.conf (útil para que los usuarios (des)compriman sus
# páginas de manual);
# − ofrecer una opción para recuperar una copia de respaldo anterior;
# − añadir otras herramientas de compresión (compress, zip, etc?).
# ¿Es necesario?
−−decompress, −d
Descomprime las páginas de manual.
−−soft, −S Cambia enlaces duros por enlaces blandos. Usar con cuidado,
pues el primer fichero encontrado se usará como referencia. No se
utiliza en modo de respaldo.
dirs Una lista de rutas absolutas a los directorios man separadas por
espacios.
Cuando está vacio, y solo entonces, procesa todas las apariciones
de MANPATH en ${MAN_CONF}/man.
;;
−−fake|−f)
FAKE=yes
shift
;;
−−help|−h)
help
exit 0
;;
/*)
MAN_DIR="${MAN_DIR} ${1}"
shift
;;
−*)
help $1
exit 1
;;
*)
echo "\"$1\" no es el nombre absoluto de una ruta"
exit 1
;;
esac
done
# Redirecciones
case $VERBOSE_LVL in
0)
# O, silencioso
DEST_FD0=/dev/null
DEST_FD1=/dev/null
VERBOSE_OPT=
;;
1)
# 1, algo detallado
DEST_FD0=/dev/stdout
DEST_FD1=/dev/null
VERBOSE_OPT=−v
;;
*)
# 2 y superiores, es mas detallado
DEST_FD0=/dev/stdout
DEST_FD1=/dev/stdout
VERBOSE_OPT="−v −v"
;;
esac
# ¿Falsa ejecución?
if [ "$FAKE" != "no" ]; then
echo "Parámetros actuales usados:"
echo −n "Compresión.......: "
case $COMP_METHOD in
−−bzip2|−−bz2|−b) echo −n "bzip2";;
−−gzip|__gz|−g) echo −n "gzip";;
−−decompress|−d) echo −n "descompresión";;
*) echo −n "desconocido";;
esac
echo " ($COMP_METHOD)"
echo "Nivel de compresión.: $COMP_LVL"
echo "Sufijo de compresión: $COMP_SUF"
echo −n "Compresión forzada.: "
[ "foo$FORCE_OPT" = "foo−F" ] && echo "si" || echo "no"
echo "man.conf is.......: ${MAN_CONF}/man.conf"
echo −n "Enlaces duros........: "
[ "foo$LN_OPT" = "foo−S" ] && echo "convertir en blandos" || echo "dejarlos así"
echo −n "Enlaces blandos........: "
[ "foo$LN_OPT" = "foo−H" ] && echo "convertir en duros" || echo "dejarlos así"
echo "Respaldo............: $BACKUP"
echo "Falsa ejecución (!si!).....: $FAKE"
if [ −d "$FILE" ]; then
cd "${MEM_DIR}" # Regresa a donde ejecutamos "$0", en caso de que "$0"=="./compressdoc" ...
# Vamos recursivamente a este directorio
echo "−> Entrando a ${DIR}/${FILE}..." > $DEST_FD0
# No necesito usar −−conf, pues especifico el directorio de trabajo.
# Pero necesito salir en caso de error.
"$0" ${COMP_METHOD} ${COMP_LVL} ${LN_OPT} ${VERBOSE_OPT} ${FORCE_OPT} "${DIR}/${FILE}" || exit 1
echo "<− Saliendo de ${DIR}/${FILE}." > $DEST_FD1
cd "$DIR" # Necesario para la siguiente iteración del bucle.
else # !dir
if ! check_unique "$DIR" "$FILE"; then continue; fi
if [ −n "$HLINKS" ]; then
# ¡Tenemos enlaces duros! Los elimina ahora.
for i in $HLINKS; do rm −f "$i"; done
fi
done
fi
else
# Hay un problema cuando no obtenemos un enlace o un fichero plano.
# Obviamente, nunca deberíamos llegar aquí... :−(
echo "Whaooo... \"${DIR}/${FILE}\" no es un enlace o un fichero plano. Compruebalo:"
ls −l "${DIR}/${FILE}"
exit 1
fi
fi
done # para FILE
done # para DIR
EOF
chmod 755 /usr/bin/compressdoc
Ahora, como root, puedes ejecutar /usr/bin/compressdoc −−bz2 para comprimir todas las páginas de manual de tu sistema. También puedes ejecutar
/usr/bin/compressdoc −−help para obtener una ayuda clara sobre lo que el guión puede hacer.
No olvide que algunos programas, como el sistema X Window o XEmacs, también instalan su documentación en lugares no estándares (como
/usr/X11R6/man, etc...). No olvides añadir estas localizaciones al fichero /etc/man.conf con una sección MANPATH=/ruta.
Ejemplo:
...
MANPATH=/usr/share/man
MANPATH=/usr/local/man
MANPATH=/usr/X11R6/man
MANPATH=/opt/qt/doc/man
...
Generalmente, los sistemas de instalación de paquetes no comprimen las páginas man/info, lo que significa que necesitarás ejecutar este guión otra vez
si quieres mantener el tamaño de tu documentación tan pequeño como sea posible. Igualmente, ten en cuenta que es seguro ejecutar el guión tras
actualizar un paquete: cuando tienes varias versiones de una página (por ejemplo, una comprimida y otra sin comprimir) la mas reciente es la que se
guarda y las otras borradas..
El acceso de usuarios es normalmente manejado por login o una aplicación diseñada para manejar las funciones de login. En este capítulo mostraremos
cómo mejorar login estableciendo policías con módulos PAM. El acceso por red también puede protegerse mediante policías establecidas por iptables,
conocidas comúnmente como cortafuegos.
La prevención de brechas, como un troyano, es asistida por aplicaciones como GnuPG, específicamente la capacidad para verificar paquetes firmados,
lo que previene la modificación del archivo TAR tras la creación del paquete.
Por último, tocamos la detección con un paquete que guarda "firmas" de ficheros críticos (definidos por el administrador), regenera estas "firmas" y las
compara para los ficheros que han sido cambiados.
Linux−PAM−0.77
Introducción a Linux−PAM
El paquete Linux−PAM contiene Módulos de Autenticación Conectables. Son útiles para permitir al administrador del sistema local la elección sobre
cómo autentican las aplicaciones a los usuarios.
Descarga adicional
Dependencias de Linux−PAM
Opcional
cracklib v2.7
Instalación de Linux−PAM
−−enable−static−libpam : Esta opción construye las librerías estáticas de PAM así como las librerías dinámicas.
−−with−mailspool=/var/mail : Esta opción hace que el directorio de la cola de correo cumpla el FHS.
−−enable−read−both−confs : Esta opción permite que sea el administrador local quien elija el tipo de fichero de configuración a usar.
mv /lib/libpam.a /lib/libpam_misc.a /lib/libpamc.a /usr/lib : Este comando mueve las librerías estáticas a /usr/lib para cumplir con el FHS.
Configuración de Linux−PAM
Capítulo 4. Seguridad 43
Más Allá de Linux From Scratch
Ficheros de configuración
/etc/pam.d o /etc/pam.conf
La información de la configuración se situa en /etc/pam.d o /etc/pam.conf dependiendo de la aplicación que está usando PAM. A
continuación hay ficheros de ejempo de cada tipo:
# Inicio de /etc/pam.d/other
# Fin de /etc/pam.d/other
# Inicio de /etc/pam.conf
# Fin de /etc/pam.conf
La página de manual de PAM (man pam) facilita un buen punto de partida para las descripciones de los campos y las entradas permitidas. Se
recomienda la Linux−PAM guide for system administrators (Guía de Linux−PAM para administradores de sistemas) para profundizar en el tema.
Contenido
Desripciones
unix−chkpwd
Librerías libpam
Las librerías libpam proporcionan una interfaz entre las aplicaciones y los módulos PAM.
Shadow−4.0.3
Introducción a Shadow
Shadow ya fué instalado en LFS y no hay razón para reinstalarlo a menos que instales Linux−PAM. Si lo haces, esto permitirá a programas como login
y su utilizar PAM.
Dependencias de Shadow
Requerida
Linux−PAM−0.77
Instalación de shadow
Ficheros de configuración 44
Más Allá de Linux From Scratch
cp debian/securetty /etc/securetty : Este comando establece las ttys que permiten conexiones a través de PAM.
Ficheros de configuración
Añade los siguientes ficheros de configuración de PAM a /etc/pam.d (o añádelos a /etc/pam.conf con el campo adicional para el programa).
# Fin de /etc/pam.d/login
EOF
cat > /etc/pam.d/passwd << "EOF"
# Inicio de /etc/pam.d/passwd
# Fin de /etc/pam.d/passwd
EOF
cat > /etc/pam.d/shadow << "EOF"
# Inicio de /etc/pam.d/shadow
# Fin de /etc/pam.d/shadow
EOF
cat > /etc/pam.d/su << "EOF"
# Inicio de /etc/pam.d/su
# Fin de /etc/pam.d/su
EOF
cat > /etc/pam.d/useradd << "EOF"
# Inicio de /etc/pam.d/useradd
# Fin de /etc/pam.d/useradd
EOF
cat > /etc/pam.d/chage << "EOF"
# Inicio de /etc/pam.d/chage
# Fin de /etc/pam.d/chage
EOF
Actualmente, /etc/pam.d/other está configurado para permitir a cualquiera con una cuenta en la máquina usar programas que no tienen un
fichero de configuración propio. Después de comprobar que PAM está correctamente configurado, puede cambiarse de la siguiente forma:
# Fin de /etc/pam.d/other
EOF
Por último, edita /etc/login.defs añadiendo '#' al comienzo de las siguientes líneas:
DIALUPS_CHECK_ENAB
LASTLOG_ENAB
MAIL_CHECK_ENAB
PORTTIME_CHECKS_ENAB
CONSOLE
MOTD_FILE
NOLOGINS_FILE
PASS_MIN_LEN
SU_WHEEL_ONLY
MD5_CRYPT_ENAB
CONSOLE_GROUPS
ENVIRON_FILE
Esto hace que loginn no realice estas funciones, ya que ahora lo harán los módulos PAM.
iptables−1.2.8
La siguiente parte de este capítulo trata sobre cortafuegos. La principal herramienta de cortafuegos para Linux, en las series del núcleo 2.4, es iptables.
Reemplaza a ipchains de las series 2.2 e ipfwadm de las series 2.0. Necesitarás instalar iptables si piensas usar algún tipo de cortafuegos.
Introducción a iptables
Para crear un cortafuegos, además de instalar iptables, necesitarás configurar las opciones correspondientes en tu núcleo. Esto se discute en la siguiente
parte de este capítulo − crear un Núcleo con el cortafuegos activado.
Si pretendes usar IPv6 podrías considerar ampliar la funcionalidad del núcleo ejecutando make patch−o−matic en el directorio de nivel superior de las
fuentes de iptables. Si vas a hacer esto en un núcleo recién descomprimido, debes ejecutar primero yes "" | make config && make dep, porque de
otra forma el comando patch−o−matic fallará mientras establece algunas dependencias.
Si vas a aplicarle algún parche al núcleo, necesitarás hacerlo antes de compilar iptables, porque durante la compilación se comprueban las fuentes del
núcleo (si se encuentran en /usr/src/linux−[versión]) para ver qué características están disponibles. Sólo se incluirá en iptables el soporte para
las características reconocidas en tiempo de compilación. Aplicar un parche al núcleo puede hacer que se produzcan errores, a menudo debido a que los
enganches (hooks) para los parches han cambiado o porque el guión de ejecución no se da cuenta de que ya se ha incluido un parche.
Ten en cuenta que, para la mayoría de la gente, aplicar un parche al núcleo es innecesario. Con los últimos núcleos 2.4.x, gran parte de la funcionalidad
ya está disponible y aquellos que necesitan aplicar un parche son los que necesitan una característica específica. Si no sabes por qué necesitas aplicar un
parche al núcleo, ¡probablemente no lo necesitas!.
Instalación de iptables
iptables−1.2.8 46
Más Allá de Linux From Scratch
Contenido
Descripciones
iptables
iptables se usa para establecer, mantener e inspeccionar las tablas de las reglas de filtrado de paquetes IP en el núcleo Linux.
iptables−save, ~−restore
Se usan para almacenar y restaurar el conjunto de cadenas y reglas. Hasta iptables−1.2.5 se consideraban experimentales.
ip6tables
Es lo mismo que iptables, pero para IPv6. Con respecto a la versión 1.2.5, no es tan completo como la versión estándar para IPv4, especialmente en lo
que se refiere a algunos módulos.
libip*.so
Estos son varios módulos (implementados como librerías dinámicas) que extienden la funcionalidad de iptables.
Configuración de un cortafuegos
Antes de que leas esta parte del capítulo, ten en cuenta que asumimos que ya has instalado iptables como se describe en la sección anterior.
El propósito principal de un cortafuegos es proteger una red contra accesos maliciosos, utilizando una única máquina como cortafuegos. Esto implica
que el cortafuegos pasará a considerarse un punto único de fallo, pero puede facilitar mucho la vida a los administradores.
En un mundo perfecto, donde sabes que cada demonio o servicio de cada máquina está perfectamente configurado y es inmune a, por ejemplo,
desbordamientos de memoria intermedia (buffer overflows) o cualquier otro problema imaginable respecto a su seguridad; y donde confías en que cada
usuario que accede a tus servicios no pretende dañarlo, ¡no necesitarías un cortafuegos! Sin embargo, en el mundo real, los demonios pueden estar mal
configurados, los agujeros de seguridad de servicios esenciales están disponibles libremente, etc... Por ello, puede que quieras escoger qué servicios son
accesibles para ciertas máquinas, puede que quieras limitar a qué máquinas o aplicaciones les permites tener acceso a Internet o, simplemente, puede
que no confíes en algunas aplicaciones o usuarios. En estas situaciones podrías beneficiarte utilizando un cortafuegos.
Sin embargo, no asumas que tener un cortafuegos hace redundante una configuración cuidadosa, ni que convierte en inofensiva una configuración
negligente, ni que previene de que cualquiera explote un agujero de seguridad en un servicio que ofreces pero que no has actualizado o parcheado
después de publicarse ese agujero de seguridad. A pesar de tener un cortafuegos, necesitas tener bien configuradas y actualizadas las aplicaciones y los
demonios de tu sistema; ¡un cortafuegos no es la panacea!
Cortafuegos Personal
Es una configuración o programa, para Windows vendido comercialmente por compañías como Symantec, que afirma o presume de que puede asegurar
un ordenador casero o de sobremesa con acceso a Internet. Este tópico es importante para aquellos usuarios que no saben las formas en que se puede
acceder a sus ordenadores a través de Internet y cómo desactivarlas, especialmente si están siempre conectados y además a través de enlaces de banda
ancha.
Router enmascarado
Es una máquina situada entre Internet y una intranet. Para minimizar el riesgo de comprometer al propio cortafuegos debería, generalmente, tener sólo
un papel: proteger la red interna. Aunque no está completamente exento de riesgos, las tareas de efectuar el encaminamiento y, ocasionalmente, el
enmascaramiento IP (reescribir las cabeceras IP de los paquetes que enruta desde clientes con direcciones IP privadas hacia Internet, para que parezcan
que provienen del mismo cortafuegos) se consideran, comúnmente, inocuas.
BusyBox
Con frecuencia es un viejo ordenador que puede que hayas retirado y casi olvidado, que realiza enmascaramiento y funciones de encaminamiento, pero
que, además, ofrece una serie de servicios, por ejemplo, almacenamiento de páginas web, correo, etc. Esto suele usarse para redes caseras, pero no
puede seguir considerándose tan seguro, porque la combinación de servidor y encaminador en una sola máquina aumenta la complejidad de la
configuración.
Esta máquina efectúa enmascaramiento o encaminamiento, pero garantiza acceso público a parte de tu red, la cual, por tener IPs públicas y una
estructura físicamente separada, no se considera parte ni de Internet ni de la red interna. Estos servidores serán aquellos que deben ser fácilmente
accesibles, tanto desde Internet como desde la red interna. El cortafuegos los protege a todos.
Filtrado de paquetes / red parcialmente accesible [se describe parcialmente aquí, ver BusyBox]
Efectúa encaminamiento o enmascaramiento, pero sólo permite el acceso a ciertos servicios, y a veces sólo a usuarios o máquinas específicas Se usa
mayormente en contextos empresariales que necesitan alta seguridad, a veces desconfiando de los empleados. Esta era la configuración más común de
un cortafuegos en la época del núcleo Linux 2.2. Todavía es posible configurar un cortafuegos de esta manera, pero hace las reglas bastante complejas
y largas.
Limitación de responsabilidad
Este documento está pensado como una introducción a cómo configurar un cortafuegos. No es una guía completa sobre protección de sistemas. Instalar
cortafuegos es un asunto complejo que requiere una configuración cuidadosa. Los guiones que se mencionan aquí simplemente intentan dar ejemplos
de cómo funcionan los cortafuegos, no intentan encajar en cualquier configuración imaginable y puede que no prevengan de cualquier ataque
imaginable.
El propósito de este texto es, simplemente, darte una pista sobre cómo comenzar con los cortafuegos.
Será necesario adaptar estos guiones a tu situación específica para una configuración óptima, pero deberías hacer un estudio serio de la documentación
de iptables y de los cortafuegos en general antes de enredar. Echa un vistazo a la lista de Enlaces para lecturas adicionales al final de esta sección para
más detalles. Ahí encontrarás una lista de URLs que contienen información bastante detallada sobre cómo construir tu propio cortafuegos.
Si quieres que tu sistema Linux haga la función de cortafuegos debes empezar asegurándote de que tu núcleo ha sido compilado con las opciones
pertinentes activadas .
Cómo configurar el núcleo, activando las opciones que se compilarán en el núcleo o como módulos, depende de tus preferencias y experiencia
personales. Ten en cuenta que, para los guiones mencionados, se supone que los módulos necesarios se cargan al principio .
BusyBox 48
Más Allá de Linux From Scratch
Cortafuegos Personal
Se supone que un Cortafuegos Personal debe permitirte acceder a todos los servicios ofrecidos en internet, pero protegiendo tu sistema y tus datos.
A continuación incluimos una versión ligeramente modificada de la recomendada por Rusty Russell en Linux 2.4 Packet Filtering HOWTO (Filtrado
de paquetes en Linux 2.4 Cómo):
# Inicio de $rc_base/init.d/firewall
# Fin de $rc_base/init.d/firewall
EOF
El guión es bastante simple, ignora todo el tráfico que llega a tu ordenador que no ha sido iniciado por él, pero si simplemente estás navegando por
Internet es improbable que excedas sus límites.
Si te encuentras frecuentemente con retrasos al acceder a servidores ftp, por favor, consulta BusyBox − ejemplo Nª 4.
Incluso si tienes demonios o servicios ejecutándose en tu sistema, deberían ser inaccesibles desde cualquier parte que no sea tu propio ordenador. Si
quieres permitir el acceso a ciertos servicios de tu máquina, como ssh o ping, echa un vistazo a BusyBox.
Un cortafuegos real tiene dos interfaces: uno conectado a una red interna, en este ejemplo eth0, y uno conectado a Internet, aquí ppp0. Para
proporcionar la máxima seguridad contra accesos al cortafuegos, asegúrate de que no existen servidores ejecutándose en él, especialmente X11 y otros.
Y, como regla general, el cortafuegos no debería acceder por si mismo a ningún servicio que no sea de confianza (Piensa en un servidor de nombres
dando respuestas que hacen que tu bind falle o, incluso peor, que implementan un gusano mediante un desbordamiento de memoria).
# Inicio de $rc_base/init.d/firewall
echo
echo "Estás utilizando la configuración de ejemplo para un cortafuegos"
echo "de la receta de cortafuegos escrita para LinuxFromScratch."
echo "Este ejemplo está lejos de ser completo, sólo está pensado"
echo "como referencia."
echo "La seguridad de un cortafuegos es una cuestión compleja, que"
echo "sobrepasa el alcance de las reglas de configuración citadas."
Cortafuegos Personal 49
Más Allá de Linux From Scratch
modprobe ip_tables
modprobe iptable_filter
modprobe ip_conntrack
modprobe ip_conntrack_ftp
modprobe ipt_state
modprobe iptable_nat
modprobe ip_nat_ftp
modprobe ipt_MASQUERADE
modprobe ipt_LOG
modprobe ipt_REJECT
# Permitir reenvío
iptables −A FORWARD −m state −−state ESTABLISHED,RELATED −j ACCEPT
iptables −A FORWARD −m state −−state NEW −i ! ppp+ −j ACCEPT
# Registra todo para el depurado (la última de todas las reglas, pero
# antes de DROP/REJECT)
iptables −A INPUT −j LOG −−log−prefix "FIREWALL:INPUT "
iptables −A FORWARD −j LOG −−log−prefix "FIREWALL:FORWARD"
iptables −A OUTPUT −j LOG −−log−prefix "FIREWALL:OUTPUT "
# Activa TCPsyncookies
echo 1 > /proc/sys/net/ipv4/tcp_syncookies
Con este guión, tu red interna debería ser suficientemente segura contra ataques externos: nadie debería poder establecer una conexión nueva con
ningún servicio interno y, si está enmascarado, incluso es invisible. Mas aún, tu cortafuegos debería ser casi inmune porque no hay servicios
ejecutándose que un cracker pueda atacar.
Nota: Si la interfaz con la que estás conectando a Internet no utiliza ppp, necesitarás cambiar ppp+ por el nombre de la interfaz que estés utilizando. Si
estás utilizando la misma interfaz para conectarte tanto a la red interna como a Internet, necesitas utilizar el nombre verdadero de la interfaz, como
eth0, en ambas interfaces.
Si necesitas una seguridad más fuerte (por ejemplo, contra DOS (Denegación de Servicio), robo de conexión, engaños, etc.) echa un vistazo a la lista de
Enlaces para lecturas adicionales al final de esta sección.
BusyBox
Este escenario no es muy diferente al Router enmascarado, pero en este caso quieres ofrecer algunos servicios a tu red interna. Un ejemplo de esto es
cuando quieres administrar tu máquina desde otro ordenador de tu red interna, o utilizarla como servidor intermedio (proxy) o servidor de nombres.
Advertencia: Describir cómo proteger un servidor que ofrece servicios en Internet va mucho más allá del alcance de este documento, mira la Limitación
de responsabilidad.
BusyBox 50
Más Allá de Linux From Scratch
Se cauteloso. Cada servicio que ofrezcas y tengas activado hace tu configuración más compleja y tu máquina menos segura. Calcula los riesgos de
servicios mal configurados o de ejecutar un servicio con un fallo explotable, riesgos ambos a los que, principalmente, un cortafuegos debería ser
inmune. Mira la introducción a Router enmascarado para más detalles.
Si los servicios que quieres ofrecer no necesitan acceder a Internet, como un servidor samba o un servidor de nombres de uso sólo interno, esto es
bastante simple y todavía podría ser aceptable desde el punto de vista de la seguridad. Basta añadir, dentro del guión, las siguientes líneas antes de las
reglas de registro.
Si tus demonios tienen que acceder a la web, como puede necesitar squid, podrías abrir OUTPUT en general y restringir INPUT.
Sin embargo, no es recomendable en general dejar OUTPUT sin restricciones: pierdes cualquier control sobre troyanos que quieran "llamar a casa", y
algo de redundancia en caso de que tengas (mal) configurado un servicio que mande avisos de su existencia al mundo.
Si prefieres tener esta protección, puedes restringir INPUT y OUTPUT en todos los puertos, excepto aquellos que sea absolutamente necesario tener
abiertos. Qué puertos tener abiertos depende de tus necesidades: mayormente los encontrarás buscando los accesos fallidos en tus ficheros de registro.
Para evitar estos retardos puedes rechazar las peticiones con un 'tcp−reset':
Obviamente, esto debe hacerse directamente después de registrarlos, justo antes de que los paquetes sean anulados:
Esto son sólo ejemplos para mostrarte las capacidades del nuevo código de cortafuegos en los núcleos Linux−2.4. Consulta la página de manual de
iptables. Allí encontrarás más. Los números de puerto que necesitarás para esto puedes encontrarlos en /etc/services, en caso de que no los hayas
encontrado mediante "prueba y error" en tus ficheros de registro.
Si añades tus servicos ofrecidos o accedidos como se muestra anteriormente, quizás incluso en FORWARD o para comunicación de la red interna, y
borras las cláusulas generales, obtienes un filtrado de paquetes al estilo antiguo.
BusyBox 51
Más Allá de Linux From Scratch
Conclusión
Finalmente, quiero recordarte uno de los factores que no debemos olvidar: El esfuerzo gastado atacando un sistema se corresponde con el valor de lo
que el cracker espera obtener. ¡Si eres responsable de activos tan valiosos que ya tienes en cuenta un gran esfuerzo por parte de los potenciales
crackers, afortunadamente no tendrás necesidad de esta receta!
Información Extra
firewall.status
Si quieres examinar las cadenas que componen tu cortafuegos y el orden en el que las reglas hacen efecto:
# Inicio $rc_base/init.d/firewall.status
echo "iptables.mangling:"
iptables −t mangle −v −L −n −−line−numbers
echo
echo "iptables.nat:"
iptables −t nat −v −L −n −−line−numbers
echo
echo "iptables.filter:"
iptables −v −L −n −−line−numbers
EOF
firewall.stop
# Inicio $rc_base/init.d/firewall.stop
# desactivar IP−Forwarding
echo 0 > /proc/sys/net/ipv4/ip_forward
iptables −Z
iptables −F
iptables −t nat −F PREROUTING
Conclusión 52
Más Allá de Linux From Scratch
GnuPG−1.2.3
Introducción a GnuPG
El paquete GnuPG contiene un encriptador de llaves públicas/privadas. Es útil para firmar ficheros o mensajes de correo como prueba de identidad y
prevenir que se trampee el contenido del fichero o del mensaje.
Instalación de GnuPG
Contenido
Descripciones
gpg
gpgsplit
gpgv
Tripwire−2.3.1−2
Introducción a Tripwire
El paquete Tripwire contiene los programas usados por Tripwire para verificar la integridad de los ficheros en un sistema.
GnuPG−1.2.3 53
Más Allá de Linux From Scratch
Descarga adicional
• Parche requerido para corregir múltiples errores de compilación (mira el parche para mas información):
http://www.linuxfromscratch.org/patches/blfs/5.0/tripwire−2.3.1−2−gcc3−build−fixes.patch
Instalación de Tripwire
./install.sh &&
cp /etc/tripwire/tw.cfg /usr/sbin &&
cp policy/*.txt /usr/share/doc/tripwire
cp install.{sh,cfg} . : Estos ficheros se copian al directorio principal de Tripwire para poder usar el guión para instalar el paquete.
Configuración de Tripwire
Ficheros de configuración
/etc/tripwire
Tripwire usa un fichero de políticas para determinar a qué ficheros se les chequeará su integridad. El fichero de políticas por defecto (twpol.txt en
/etc/tripwire/) es para una instalación basada en Redhat 7.0 y está muy desactualizado.
Los ficheros de políticas son personales y deberían ser adaptados a cada distribución y/o instalación en particular. Encontrarás algunos de estos ficheros
personalizados aquí abajo:
http://home.iprimus.com.au/glombowski/blfs/twpol−all.txt
Comprueba la integridad de todos los ficheros
http://home.iprimus.com.au/glombowski/blfs/twpol−lfs.txt
Fichero de políticas adaptado para un sistema base LFS 3.0
http://home.iprimus.com.au/glombowski/blfs/twpol−suse7.2.txt
Fichero de políticas adaptado para un sistema SuSE 7.2
Descarga el fichero de políticas que quieras probar, cópialo a /etc/tripwire/, y úsalo en lugar de twpol.txt. Sin embargo, recomendamos que
crees tu propio fichero de políticas personalizado basándote en las ideas que aportan los ficheros anteriores y leyendo
/usr/share/doc/tripwire/policyguide.txt. twpol.txt es un buen fichero de políticas para principiantes, ya que advertirá sobre
cualquier cambio en el sistema de ficheros y puede incluso servir como una forma molesta de rastrear los cambios producidos al desinstalar software.
Durante la configuración Tripwire creará dos claves: una para el sitio y una local, que serán almacenadas en /etc/tripwire/.
Información de uso
Para usar Tripwire tras esto y genera un informe, utiliza el siguiente comando:
Mira la salida para verificar la integridad de tus ficheros. Puedes generar un informe automático a través de una utilidad cron para planificar las
ejecuciones.
Descarga adicional 54
Más Allá de Linux From Scratch
Ten en cuenta que después de ejecutar un chequeo de integridad debes verificar el informe o correo electrónico y seguidamente modificar la base de
datos de Tripwire de los ficheros de tu sistema para que Tripwire no te avise contínuamente que los ficheros que modificaste intencionadamente son
una violación de la seguridad. Para lograrlo, primero ejecuta ls /var/lib/tripwire/report/ y anota el nombre del fichero más nuevo que
comience con linux− y termina con .twr. Este fichero encriptado se creó durante el último informe y es necesario para actualizar la base de datos de
Tripwire para tu sistema. Luego ejecuta lo siguiente, reemplazando adecuadamente los '?':
tripwire −m u −r /var/lib/tripwire/report/linux−???????−??????.twr
Entrarás en vim con una copia del informe frente a tí. Si los cambios son correctos, sólo teclea :x y, después de ingresar tu clave local, la base de datos
será actualizada. Si hay ficheros sobre los que quieres que se te advierta, solo elimina la 'x' delante del nombre del fichero en el informe y ejecuta :x.
Si no estás conforme con tu fichero de políticas y quieres modificarlo o usar uno nuevo, modifícalo y ejecuta los siguientes comandos:
Contenido
Ext3
Ext3 es un sistema de ficheros transaccional (journaling) que es una extensión del sistema de ficheros ext2. Es compatible hacia atrás con ext2 y la
conversión de ext2 a ext3 es trivial.
No necesitas instalar nada para usar ext3. Todos los paquetes necesarios están disponibles con el sistema base LFS.
Cuando construyas el núcleo, asegúrate de que tienes compilado el soporte para ext3. Si quieres que tu partición raíz sea ext3, entonces compila el
soporte dentro del núcleo, en caso contrario puedes compilarlo como módulo. Recompila el núcleo si es necesario.
Edita tu /etc/fstab. Para cada partición que quieras convertir a ext3, edita su entrada para que tenga un aspecto similar a la siguiente línea.
En la línea anterior, sustituye /dev/hdXX por la partición (p.e. /dev/hda2) y /mnt_point por el punto de montaje (p.e. /home). El 0 en el
último campo asegura que el guión checkfs no comprobará la consistencia de la partición durante el arranque. En lo anterior puedes sustituir ext3 por
auto si quieres asegurarte de que la partición se monte aunque, accidentalmente, olvides activar el soporte ext3 en el núcleo.
Para cada partición que hayas convertido a ext3 en /etc/fstab, activa las transaciones para la partición ejecutando el siguiente comando.
tune2fs −j /dev/hdXX
Remonta las particiones implicadas o, simplemente, reinicia si has recompilado el núcleo para activar el soporte ext3.
ReiserFS−3.6.11
Introducción a ReiserFS
El paquete ReiserFS contiene varias utilidades que se usan con el sistema de ficheros Reiser.
Instalación de ReiserFS
−−prefix=/usr : Esto asegura que las páginas de manual se instalan en su lugar correcto mientras que instalamos los programas en /sbin como debe
ser.
−−sbindir=/sbin : Esto asegura que las utilidades ReiserFS se instalen en /sbin como debe ser.
Contenido
Descripciones
debugreiserfs
debugreiserfs puede ayudar en ocasiones en la resolución de problemas con los sistemas de ficheros ReiserFS. Si se le llama sin opciones muestra el
superbloque de cualquier sistema de ficheros reiserfs encontrado en el dispositivo.
mkreiserfs
reiserfsck
reiserfstune
reiserfstune sirve para afinar el registro de transacciones de ReiserFS. PELIGRO: No uses esta utilidad sin haber leído primero con atención su página
de manual.
resize_reiserfs
unpack
La utilidad unpack puede usarse para volcar información de sistemas de ficheros ReiserFS a ficheros para su depuración, muy parecido a
debugreiserfs.
XFS−2.5.6
Parche del núcleo para XFS
El parche del núcleo para XFS debe aplicarse para usar sistemas de ficheros XFS.
• Descarga (HTTP):
• Descarga (FTP): ftp://oss.sgi.com/projects/xfs/download/patches/2.4.22/xfs−2.4.22−all−i386.bz2
• Tamaño del paquete: 860 KB
Construye un núcleo Linux−2.4.22 con soporte XFS mediante los siguientes comandos:
cd /usr/src/linux &&
make mrproper &&
bzcat ../xfs−2.4.22−all−i386.bz2 | patch −Np1 &&
make menuconfig &&
make CC=/opt/gcc−2.95.3/bin/gcc dep &&
make CC=/opt/gcc−2.95.3/bin/gcc bzImage &&
make CC=/opt/gcc−2.95.3/bin/gcc modules &&
make CC=/opt/gcc−2.95.3/bin/gcc modules_install &&
cp arch/i386/boot/bzImage /boot/vmlinuz−xfs &&
cp System.map /boot/System.map−xfs
Introducción a XFS
El paquete XFS contiene herramientas de administración y depuración para los sistemas de ficheros XFS.
Descripciones 57
Más Allá de Linux From Scratch
Instalación de XFS
./configure &&
make &&
make install
Contenido
XFS contiene xfs_growfs, xfs_admin, xfs_freeze, xfs_mkfile, xfs_check, xfs_bmap, xfs_rtcp, xfs_repair, xfs_db, xfs_logprint, xfs_ncheck,
mkfs.xfs y fsck.xfs.
Descripciones
xfsgrowfs
xfs_admin
xfs_freeze
xfs_mkfile
xfs_mkfile crea un fichero XFS, que por defecto está lleno de ceros.
xfs_check
xfs_bmap
xfs_rtcp
xfs_repair
xfs_db
xfs_logprint
xfs_ncheck
xfs_ncheck genera nombres de rutas a partir de números de inodos para sistemas de ficheros XFS.
mkfs.xfs
fsck.xfs
fsck.xfs simplemente sale con estado cero, pues las particiones se comprueban en el momento de montarlas.
Instalación de XFS 58
Capítulo 6. Editores
Este capítulo se referencia en el Libro LFS para aquellos que desean utilizar otros editores en su sistema LFS. Además, tenemos la oportunidad de
mostrarte cómo algunos programas instalados en el LFS se benefician al recompilarlos tras instalar las librerías gráficas.
Vim−6.2
Introducción a Vim
El paquete Vim, que es una abreviatura de VI IMproved (VI Mejorado), contiene un clon de vi con varios extras, si se compara con el vi original.
Las instrucciones de instalación en el LFS instalan vim como parte del sistema base, pero debido a la ausencia de las librerias X durante la instalación
base, Vim necesita ser recompilado una vez que X ha sido instalado para habilitar el modo GUI. No hay necesidad de instrucciones especiales, ya que
el soporte para X es detectado automáticamente.
Dependencias de Vim
Requerida
XFree86−4.3.0.1
Opcionales
GTK+−2.2.4 y LessTif−0.93.46
Instalación de Vim
Contenido
El paquete Vim contiene eview, evim, ex, gview, gvim, gvimdiff, rgview, rgvim, rview, rvim, view, vim, vimdiff, vimtutor y xxd. Excepto por
vimtutor y xxd, el resto de los comandos son enlaces simbólicos a vim que lo ejecutan con diferentes opciones. vimtutor es una herramienta para
aprender los comandos de vim y xxd es un comando que crea volcados hexadecimales.
Emacs−21.3
Introducción a Emacs
Capítulo 6. Editores 59
Más Allá de Linux From Scratch
Dependencias de Emacs
Opcionales
Instalación de Emacs
./configure −−prefix=/usr \
−−libexecdir=/usr/sbin &&
make bootstrap &&
make install
Contenido
El paquete Emacs contiene emacs, b2m, ctags, ebrowse, emacsclient, etags, grep−changelog, rcs−checkin, cvt−mail, digest−doc, emacsserver,
fakemail, hexl, movemail, profile, rcs2log, sorted−doc, vcdiff y yow.
Descripciones
emacs
El propio editor.
b2m
b2m es un programa para convertir ficheros de correo del formato RMAIL al formato `mbox' de Unix.
ctags
ctags genera ficheros de datos con etiquetas de referencias cruzadas para código fuente.
ebrowse
ebrowse permite navegar por las jerarquías de las clases C++ desde emacs.
emacsclient
emacsclient conecta una sesión de emacs a una instancia de emacsserver que esté ejecutándose.
etags
etags es otro programa para generar etiquetas de referencias cruzadas para código fuente.
grep−changelog
grep−changelog muestra las entradas en Change Logs que cumplan ciertos criterios.
rcs−checkin
rcs−checkin es un guión del intérprete de comandos usado para comprobar ficheros en RCS.
cvt−mail
digest−doc
emacsserver
emacserver permite a otras aplicaciones/intérpretes de comandos acceder a una sesión activa de emacs y compartir los almacenadores intermedios
(buffers).
Dependencias de Emacs 60
Más Allá de Linux From Scratch
fakemail
hexl
hexl convierte ficheros para editarlos con el modo de edición hexadecimal de emacs.
movemail
profile
profile genera eventos periódicos para los perfiles de código Lisp de Emacs.
rcs2log
sorted−doc
vcdiff
yow
nano−1.2.2
Introducción a nano
El paquete nano contiene un editor de texto pequeño y simple pensado para sustituir a Pico, el editor por defecto del paquete Pine.
Dependencias de nano
Opcional
slang−1.4.9
Instalación de nano
Configuración de nano
Ficheros de configuración
/etc/nanorc, ~/.nanorc
Ejemplo de configuración
fakemail 61
Más Allá de Linux From Scratch
set autoindent
set const
set fill 72
set historylog
set multibuffer
set nohelp
set regexp
set smooth
set suspend
Contenido
Descripción
nano
nano es un editor de texto pequeño y simple pensado para sustituir a Pico, el editor por defecto del paquete Pine.
JOE−2.9.8
Introducción a JOE
Instalación de JOE
Ficheros de configuración
JOE puede hacer uso de muchos ficheros de configuración. La información sobre estos ficheros se encuentra en la página de manual de joe. Estos
ficheros son /etc/jmacsrc, /etc/joerc, /etc/jpicorc, /etc/jstarrc, y /etc/rjoerc. JOE también puede hacer uso de
~/.joerc, que puede ser una copia de /etc/joerc personalizada al gusto de cada usuario.
Contenido
Descripciones
jmacs
jmacs es un enlace simbólico a joe usado para lanzar el modo de emulación de Emacs.
joe
jpico
jpico es un enlace simbólico a joe usado para lanzar el modo de emulación de Pico.
Contenido 62
Más Allá de Linux From Scratch
jstar
jstar es un enlace simbólico a joe usado para lanzar el modo de emulación de WordStar.
rjoe
rjoe es un enlace simbólico a joe que limita a JOE para que edite sólo los ficheros indicados en la línea de comandos.
termidx
termidx es un programa usado por joe para generar el fichero índice de termcap.
jstar 63
Capítulo 7. Intérpretes de comandos
Estamos familiarizados con el intérprete de comandos Bourne Again SHell (bash), pero hay otros dos intérpretes considerados modernos y útiles: el
intérprete UNIX C de Berkeley y el intérprete Korn. En este capítulo se instalan paquetes compatibles con estos tipos adicionales de intérpretes.
ASH−0.4.0
Introdución a ASH
El intérprete ash es el más compatible con el intérprete de comandos Bourne (no confundirse con el intérprete Bourne Again, Bash, instalado en el
LFS) sin características adicionales. El intérprete de comandos Bourne se encuentra disponible en la mayoría de los sitemas UNIX comerciales. Por lo
tanto ash es útil para probar guiones y hacerlos compatibles con sh. También necesita menos memoria y espacio que otros intérpretes compatibles con
sh.
• Descarga (HTTP):
• Descarga (FTP): ftp://distro.ibiblio.org/pub/Linux/distributions/slackware/slackware_source/ap/ash/ash−0.4.0.tar.gz
• Tamaño del paquete: 118 KB
• Estimación del espacio necesario en disco: 2.7 MB
• Tiempo estimado de construcción: 0.06 SBU
Descarga adicional
Instalación de ASH
Configuración de ASH
Ficheros de configuración
Contenido
Descripción
ash
Tcsh−6.12.00
Introducción a Tcsh
El paquete Tcsh contiene una versión mejorada pero completamente compatible con el intérprete de comandos UNIX C de Berkeley (csh). Es útil como
intérprete de comandos alternativo para aquellos que prefieren la sintaxis de C a la de bash, y también porque algunos programas necesitan el intérprete
de comandos C para instalarse.
Instalación de Tcsh
cp tcsh.man /usr/share/man/man1/tcsh.1 : Tcsh no instala su página de manual correctamente, de modo que lo hacemos manualmente.
ln −s /usr/bin/tcsh /bin/csh : La norma FHS determina que si hay un intérprete de comandos C instalado, debería haber un enlace simbólico de
/bin/csh a él. Esto crea ese enlace.
Configuración de Tcsh
Ficheros de configuración
Hay bastantes ficheros de configuración para el intérprete de comandos C. Algunos ejemplos son /etc/csh.cshrc, /etc/csh.login,
~/.tcshrc, ~/.cshrc, ~/.history, ~/.login, ~/.cshdirs, /etc/csh.logout, ~/.logout y ~/.logout. Se puede encontrar más
información sobre estos ficheros en la página de manual de tcsh(1).
Contenido
Descripción
tcsh
tcsh es una versión mejorada, pero completamente compatible, del intérprete de comandos UNIX C de Berkeley, csh. Puede utilizarse como intérprete
de comandos interactivo o como procesador de guiones.
ZSH−4.1.1
Introducción a ZSH
El paquete ZSH contiene el intérprete de comandos zsh, que puede utilizarse como intérprete interactivo de ingreso y como procesador de de guiones.
De los intérpretes de comandos estándar, ZSH se parece a KSH pero incluye muchas mejoras.
Instalación de ZSH
Configuración de ZSH
Ficheros de configuración
Hay un gran número de ficheros de configuración de ZSH, incluyendo /etc/zshenv, /etc/zprofile, /etc/zshrc, /etc/zlogin y
/etc/zlogout. Puedes encontrar más información sobre ellos en la página de manual de zsh(1) y en las páginas de manual relacionadas.
Instalación de Tcsh 65
Más Allá de Linux From Scratch
Contenido
Descripción
zsh
zsh es un intérprete de comandos que incluye edición de órdenes en línea, corrección integrada, completado de comandos programable, funciones (con
carga automática), historial, y un montón de características más.
Contenido 66
III. Librerías y Utilidades Generales
Índice
8. Librerías Generales
9. Librerías Gráficas
10. Utilidades Generales
11. Utilidades del Sistema
12. Programación
Hay dos tipos de librerías: estáticas y compartidas. Las librerías compartidas (normalmente libXXX.so) son cargadas en memoria en tiempo de
ejecución a partir de una copia compartida (de aquí el nombre). Las librerías estáticas (libXXX.a) en realidad se enlazan dentro del propio ejecutable,
lo que hace que el fichero del programa sea más grande. Con frecuencia encontrarás en tu sistema las copias estática y compartida de la misma librería.
Generalmente sólo necesitas instalar librerías cuando instalas software que necesita la funcionalidad que proporcionan. En el libro BLFS cada paquete
se lista con sus dependencias (conocidas). Así puedes hacerte una idea de qué librerías necesitas antes de instalar ese programa. Si instalas algo sin usar
las instrucciones del BLFS, los ficheros README o INSTALL contendrán normalmente detalles de los requisitos del programa.
Hay ciertas librerías que casi con seguridad todos necesitaremos en algún momento. En este capítulo mencionamos estas y algunas otras, y explicamos
por qué puedes querer instalarlas.
OpenSSL−0.9.7c
Introducción a OpenSSL
El paquete OpenSSL contiene herramientas de administración y librerías relacionadas con la criptografía. Son útiles para suministrar funciones
criptográficas a otros paquetes, sobre todo OpenSSH y navegadores web (para acceso seguro a sitios https).
Descarga adicional
Instalación de OpenSSL
no−rc5 no−idea : Cuando se añaden al comando ./config, eliminan la construcción de dichos métodos de encriptación. Puedes necesitar licencias
sobre las patentes para utilizar cualquiera de estos métodos en tus proyectos.
rm doc/apps/passwd.pod : Hacemos esto porque de otra forma OpenSSL instalaría su página de manual de passwd sobre la existente en el sistema,
que es algo que no queremos.
make MANDIR=/usr/share/man
make MANDIR=/usr/share/man install
: Estos comandos instalan OpenSSL colocando las páginas de manual en /usr/share/man en lugar de en su ubicación por defecto que es
/etc/ssl/man.
rmdir /etc/ssl/lib : Esto es simplemente un comando de limpieza. Por alguna razón, la rutina de instalación de openssl crea el directorio
/etc/ssl/lib aunque las librerías se hayan instalado en /usr/lib. ¡Lo eliminamos para mantener todo bonito y limpio!
chmod 755 /usr/lib/pkgconfig: El proceso de instalación modifica los permisos de este directorio al modo 644. Este comando restaura los permisos a
los establecidos antes de la instalación (modo 755).
Configuración de OpenSSL
Ficheros de configuración
/etc/ssl/openssl.cnf
Quienes sólo quieran usar openssl para proporcionar funciones a otros programas, como OpenSSH y navegadores web, no tienen que preocuparse de
configurarlo. La configuración de OpenSSL es un tema avanzado. Por eso se supone que quien quiere hacerlo sabe cómo, o es capaz de averiguar cómo
se hace.
Contenido
Descripciones
c_rehash
c_rehash es un guión Perl que revisa todos los ficheros de un directorio y añade enlaces simbólicos apuntando a sus valores aleatorios (hash values).
openssl
El programa openssl es una herramienta para usar desde la línea de comandos las funciones criptográficas de la librería crypto de OpenSSL. Puede
utilizarse para varias tareas que están documentadas en man 1 openssl.
libcrypto
La librería crypto de OpenSSL implementa una amplia gama de los algoritmos criptográficos usados en varias normas de Internet. Los servicios
facilitados por esta librería son usados por las implementaciones OpenSSL de SSL, TLS y S/MIME, y también están siendo utilizados para
implementar OpenSSH, OpenPGP y otros estándares criptográficos.
libssl
La librería SSL de OpenSSL implementa los protocolos Secure Sockets Layer (Capa de Conectores de Red Segura) (SSL v2/v3) y Transport Layer
Security (Capa de Transporte Segura) (TLS v1). Posee una completa API cuya documentación puede encontrarse ejecutando man 3 ssl.
pcre−4.3
Introducción a PCRE
El paquete PCRE contiene librerías de expresiones regulares compatibles con Perl. Son útiles para implementar búsquedas de patrones de expresiones
regulares usando las misma sintaxis y semántica que Perl 5.
Instalación de PCRE
Contenido
Configuración de OpenSSL 69
Más Allá de Linux From Scratch
Descripciones
pcregrep
pcretest
pcre−config
pcre−config se utiliza durante el proceso de compilación de los programas que se enlazan con esta librería.
popt−1.7
Introducción a popt
El paquete popt contiene las librerías popt que son usadas por algunos programas para analizar opciones de la línea de comandos.
Instalación de popt
Contenido
Descripción
Librería popt
slang−1.4.9
Introducción a slang
El paquete slang contiene la librería slang, utilizada para crear software multiplataforma robusto.
Instalación de slang
Descripciones 70
Más Allá de Linux From Scratch
Configuración de slang
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
FAM−2.6.10
Introducción a FAM
El paquete FAM contiene un Supervisor de Alteración de Ficheros que sirve para notificar a las aplicaciones sobre los cambios ocurridos en el sistema
de ficheros.
Descarga adicional
Dependencias de fam
Requerida
portmap−5beta
Instalación de FAM
Nota: Recibirás advertencias sobre que make install no puede combinar las entradas en /etc/rpc. Puedes ignorarlas junto con
cualquier advertencia sobre IMON o inetd.conf, pues configuraremos estos ficheros después de la instalación.
patch −Np1 −i ../fam−dnotify.patch : Este parche hace que FAM utilice el mecanismo dnotify del núcleo Linux para informar al proceso que hace la
llamada de modificaciones de ficheros, en vez de interrogar para ello al sistema de ficheros.
libtoolize −−force
aclocal
automake −−add−missing
autoconf
Estos comandos son necesarios debido a que el parches afecta al fichero configure.in. Este regenera un nuevo guión configure con los cambios
necesarios.
Configuración de slang 71
Más Allá de Linux From Scratch
Configuración de FAM
Ficheros de configuración
echo "sgi_fam/1−2 stream rpc/tcp wait root /usr/bin/fam fam" >> /etc/inetd.conf
Si utilizas xinetd, añade una entrada en /etc/xinetd.conf con el siguiente comando (asegúrate que el grupo "nogroup" existe):
Contenido
Descripción
fam
libxml−1.8.17
Introducción a libxml
El paquete libxml contiene las librerías libxml. Son útiles para analizar ficheros XML.
Instalación de libxml
Contenido
Configuración de FAM 72
Más Allá de Linux From Scratch
Descripción
Librerías libxml
Las librerías libxml facilitan a los programas funciones para analizar ficheros que utilicen el formato XML.
libxml2−2.5.11
Introducción a libxml2
El paquete libxml2 contiene librerías XML. Son útiles para analizar ficheros XML.
Dependencias de libxml2
Opcional
Python−2.3.2
Instalación de libxml2
Contenido
Descripciones
Librerías libxml2
Las librerías libxml2 facilitan a los programas funciones para analizar ficheros que utilicen el formato XML.
xmllint
xmllint analiza ficheros XML y muestra informes (basados en opciones) para detectar errores en el código XML.
xmlcatalog
libxslt−1.0.33
Introducción a libxslt
El paquete libxslt contiene las librerías XSLT. Son útiles para añadir a las librerías libxml2 soporte de ficheros XSLT.
Descripción 73
Más Allá de Linux From Scratch
Dependencias de libxslt
Requerida
libxml2−2.5.11
Instalación de libxslt
Contenido
El paquete libxslt contiene las librerías libxslt, las librerías libexslt y xsltproc.
Descripciones
Librerías libxslt
Las librerías libxslt facilitan extensiones a las librerías libxml2 para analizar ficheros en formato XSLT.
xsltproc
readline−4.3
Introducción a readline
La librería readline proporciona un conjunto de funciones que pueden usar las aplicaciones para permitir a los usuarios editar líneas de comandos
mientras son tecleadas. Están disponibles modos de edición de Emacs y vi.
Instalación de readline
make SHLIB_LIBS=−lcurses : Este comando pone los símbolos adecuados a disposición de las aplicaciones que asumen que readline se compila
enlazada con ncurses.
Configuración de readline
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
Dependencias de libxslt 74
Más Allá de Linux From Scratch
GMP−4.1.2
Introducción a GMP
El paquete GMP contiene una librería matemática. Tiene funciones útiles para aritmética de precisión arbitraria.
Dependencias de gmp
Opcional
readline−4.3
Instalación de GMP
Contenido
Descripción
Librerías gmp
Las librerías libgmp contienen funciones para operar con números enteros con signo, racionales y de coma flotante.
GDBM−1.8.3
Introducción a GDBM
El paquete GDBM contiene el Administrador de Bases de Datos de GNU. Es un formato de fichero de disco para bases de datos que guarda pares de
clave/dato en ficheros únicos. El dato real de cualquier entrada guardada es indexado mediante una clave única, que puede recuperarse en menos
tiempo que si se guardase en un fichero de texto.
Instalación de GDBM
Adicionalmente, puede que necesites instalar las cabeceras de compatibilidad para GDBM. Por ejemplo, Apache 1.3 necesitará estas cabeceras. Instala
GMP−4.1.2 75
Más Allá de Linux From Scratch
BINOWN=root BINGRP=root : Este comando cambia el propietario de los ficheros al usuario root en vez de al usuario bin.
Contenido
Descripción
Librerías gdbm
Las librerías libgdbm contienen funciones que preparan rutinas de bases de datos usando tablas de dispersión ampliables (extendible hashing).
GLib−1.2.10
Introducción a GLib
El paquete glib contiene una librería base de bajo nivel. Es útil para proporcionar el manejo de estructuras de datos para C, envoltorios de portabilidad e
interfaces para funcionalidades en tiempo de ejecución tales como bucles de eventos, hilos, carga dinámica y un sistema de objetos.
Instalación de GLib
Contenido
Descripción
Librerías GLib
Las librerías GLib contienen las librerías base de bajo nivel para la Caja de Herramientas de GIMP (Gimp Toolkit).
GLib−2.2.3
Introducción a GLib
El paquete glib contiene una librería base de bajo nivel. Sirve para proporcionar el manejo de estructuras de datos para C, envoltorios de portabilidad e
interfaces para funcionalidades en tiempo de ejecución tales como bucles de eventos, hilos, carga dinámica y un sistema de objetos.
Dependencias de GLib
Requerida
pkgconfig−0.15.0
Opcionales
Instalación de GLib
Contenido
Descripción
Librerías GLib
Las librerías GLib contienen una librería base de bajo nivel para la Caja de Herramientas de GIMP (Gimp Toolkit).
expat−1.95.6
Introducción a expat
El paquete expat contiene una librería C orientada a flujo para procesar XML.
Descargas adicionales
Instalación de expat
El fichero expat.h declara XML_Status después de su primer uso. Aplica este parche para corregirlo:
Contenido
Dependencias de GLib 77
Más Allá de Linux From Scratch
Descripción
xmlwf
xmlwf es una utilidad sin validación para comprobar si un documento XML está bien formado o no.
libesmtp−1.0
Introducción a libesmtp
El paquete libesmtp contiene las librerías libesmtp, que son usadas por algunos programas para manejar la entrega de correo a una capa de transporte de
correo.
Instalación de libesmtp
Contenido
Descripción
Librería libesmtp
La librería libesmtp se usa para manejar la entrega de correo electrónico a un Agente de Transporte de Correo (MTA).
aspell−0.50.3
Introducción a aspell
El paquete aspell contiene la librería aspell, usada como interfaz con las librerías de revisión ortográfica.
Descarga adicional
Instalación de aspell
Descripción 78
Más Allá de Linux From Scratch
Configuración de aspell
Después de instalar Aspell debes instalar al menos un diccionario. Puedes encontrarlos en http://aspell.net/.
./configure &&
make &&
make install
Contenido
Descripción
Librería aspell
ispell−3.2.06.epa6
Introducción a ispell
El paquete ispell contiene un corrector ortográfico que puede manejar lenguajes internacionales.
Instalación de ispell
Por defecto, ispell sólo instala el diccionario de Inglés Americano. Para instalar otros lenguajes, consulta el fichero config.X y busca las definiciones
para agregar a local.h.
make &&
make install
Contenido
Guile−1.6.4
Introducción a Guile
El paquete Guile contiene la librería del lenguaje de extensión del Proyecto GNU. Guile también contiene un intérprete autónomo de Scheme.
Configuración de aspell 79
Más Allá de Linux From Scratch
Dependencias de Guile
Opcional
readline−4.3
Instalación de Guile
Contenido
Además de las librerías libguile el paquete Guile contiene guile, guile−config y guile−snarf.
Descripciones
guile
guile−config
guile−config es un guión Guile que proporciona la información necesaria para enlazar tus programas con la librería Guile, de la misma forma que lo
hace pkgconfig−0.15.0.
guile−snarf
guile−snarf es un guión que analiza las declaraciones en tu código en busca de funciones de C visibles por Scheme , objetos de Scheme utilizables por
tu código C, etc.
slib−2d6
Introducción a slib
Dependencias de slib
Requeridas
Guile−1.6.4
Instalación de slib
cp −R slib /usr/share/guile
Contenido
G−Wrap−1.3.4
Dependencias de Guile 80
Más Allá de Linux From Scratch
Introducción a G−Wrap
Dependencias de G−wrap
Requeridas
Guile−1.6.4 y slib−2d6
Instalación de G−Wrap
Contenido
Descripción
g−wrap−config
g−wrap−config es una herramienta que genera CFLAGS para enlazar código C a las librerías en tiempo de ejecución de Scheme.
LZO−1.08
Introducción a LZO
LZO es una librería de compresión de datos diseñada para comprimir y descomprimir en tiempo real. Esto significa que favorece la velocidad frente al
ratio de compresión.
Instalación de LZO
Contenido
Descripción
Introducción a G−Wrap 81
Más Allá de Linux From Scratch
liblzo
liblzo 82
Capítulo 9. Librerías Gráficas
Dependiendo de para qué vayas a usar tu sistema, puede que necesites o no las librerías gráficas. Muchas máquinas de escritorio las querrán para
utilizar aplicaciones gráficas. Por otro lado, la mayoría de los servidores no las necesitarán.
lcms−1.11
Introducción a lcms
Dependencias de lcms
Opcionales
Instalación de lcms
Contenido
El paquete lcms contiene las librerías liblcms, icc2ps, icclink, icctrans y, opcionalmente, tifficc, jpegicc, la librería _lcms y lcms.py.
Descripciones
Librería liblcms
Las librerías liblcms son usadas por otros programas para proporcionar administración de color.
icc2ps
icclink
icclink enlaza dos o mas perfiles dentro de un único perfil de dispositivo de enlace.
icctrans
tifficc
jpegicc
libjpeg−6b
Introducción a libjpeg
El paquete libjpeg contiene librerías que permiten la compresión de ficheros de imagen basándose en el estándar del Joint Photographic Experts Group.
Es un algoritmo de compresión "con pérdidas".
Instalación de libjpeg
./configure −−enable−static −−enable−shared −−prefix=/usr : Este comando le indica a libjpeg que construya tanto las librerías estáticas como las
compartidas y que las instale en /usr.
Configuración de libjpeg
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
El paquete libjpeg contiene cjpeg, djpeg, jpegtran, rdjpgcom, wrjpgcom y las librerías libjpeg.
Descripciones
cjpeg
cjpeg comprime ficheros de imagen para generar un fichero JPEG/JFIF en la salida estándar. Los formatos de entrada soportados actualmente son:
PPM (formato de color PBMPLUS), PGM (formato de escala de grises PBMPLUS), BMP y Targa.
djpeg
djpeg descomprime ficheros de imagen en formato JPEG/JFIF a formato PPM (formato de color PBMPLUS), PGM (formato de escala de grises
PBMPLUS), BMP o Targa.
jpegtran
rdjpgcom
wrjpgcom
Librerías jpeg
Estas librerías las utilizan muchos programas para leer y escribir ficheros en formato JPEG.
Introducción a libjpeg 84
Más Allá de Linux From Scratch
libpng−1.2.5
Introducción a libpng
El paquete libpng contiene librerías utilizadas por otros programas para leer y escribir ficheros PNG.
Instalación de libpng
make prefix=/usr \
ZLIBINC=/usr/include ZLIBLIB=/usr/lib −f scripts/makefile.linux &&
make prefix=/usr install −f scripts/makefile.linux
ZLIBINC=/usr/include ZLIBLIB=/usr/lib : Esto fuerza a libpng a buscar los includes y librerías de zlib donde los tenemos instalados.
−f scripts/makefile.linux : Esto hace que make utilice la versión del makefile para Linux, pues libpng no utiliza la rutina autoconf y en su lugar
incluye varios makefiles para diferentes plataformas.
Configuración de libpng
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
Descripciones
Librerías png
La librería PNG es una colección de rutinas para crear y manipular ficheros PNG. El formato PNG fue diseñado como sustituto de GIF y, en menor
medida, de TIFF, con muchas mejoras y extensiones y sin problemas de patentes.
libpng−config
libtiff−3.6.0
Introducción a libtiff
El paquete libtiff contiene las librerías tiff y aplicaciones asociadas. Las librerías las utilizan muchos programas para leer y escribir ficheros tiff, y las
aplicaciones son útiles para todo tipo de operaciones con ficheros tiff.
libpng−1.2.5 85
Más Allá de Linux From Scratch
Instalación de libtiff
−−noninteractive : Esta opción se utiliza para evitar la rutina de configuración que solicita la confirmación de los directorios de instalación (que de
todas formas le pasamos a configure mediante opciones).
−−with−DIR_MAN=/usr/share/man : Usamos esto porque a pesar de que le pasamos −−prefix=/usr, la rutina configure intenta instalar las páginas de
manual en /usr/local/man en lugar de en el sitio correcto.
Configuración de libtiff
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
El paquete libtiff contiene fax2ps, fax2tiff, gif2tiff, pal2rgb, ppm2tiff, ras2tiff, rgb2ycbcr, thumbnail, tiff2bw, tiff2ps, tiff2rgba, tiffcmp, tiffcp,
tiffdither, tiffdump, tiffinfo, tiffmedian, tiffsplit y las librerías tiff.
Descripciones
fax2ps
fax2tiff
fax2tiff crea un fichero de fax TIFF Clase F a partir de datos directos de fax.
gif2tiff
pal2rgb
pal2rgb convierte una imagen de paleta de colores TIFF en una imagen a color completo.
ppm2tiff
ras2tiff
rgb2ycbcr
thumbnail
tiff2bw
Instalación de libtiff 86
Más Allá de Linux From Scratch
tiff2ps
tiff2rgba
tiffcmp
tiffcp
tiffdither
tiffdump
tiffinfo
tiffmedian
tiffsplit
Librerías tiff
Las librerías tiff las usan muchos programas para leer y escribir ficheros TIFF.
libungif−4.1.0b1
Introducción a libungif
El paquete libungif contiene librerías para leer todos los GIFs y escribir GIFs sin compresión, así como programas para convertir y trabajar con ficheros
GIF. Las librerías son útiles para cualquier programa gráfico que desee manejar ficheros GIF, mientras que los programas son útiles para tareas de
conversión y limpieza de imágenes.
La razón por la que libungif sólo escribe GIFs sin compresión se debe a un tema legal con la compresión LZW (sobre la que Unisys reclama la
patente). Leer GIFs no es problema ya que las rutinas de descompresión no parecen estar limitadas de este modo. Advierte que esto fue muy discutido
en el pasado. La mejor forma de evitar todo este lío es utilizar libungif simplemente para ver las imágenes GIF de la web, mientras que en cualquier
página que diseñes puedes utilizar en su lugar el formato PNG de código abierto (que utiliza, no te asombres, la librería libpng) que no tiene ningún
problema de patentes.
Descarga adicional
tiff2ps 87
Más Allá de Linux From Scratch
Instalación de libungif
Contenido
El paquete libungif contiene gif2epsn, gif2ps, gif2rgb, gifasm, gifbg, gifburst, gifclip, gifclrmp, gifcolor, gifcomb, gifcompose, giffiltr, giffix,
gifflip, gifhisto, gifinfo, gifinter, gifinto, gifovly, gifpos, gifrotat, gifrsize, gifspnge, giftext, gifwedge, icon2gif, raw2gif, rgb2gif, text2gif y las
librerías libungif.
Descripciones
gif2epsn
gif2ps
gif2rgb
gifasm
gifbg
gifburst
gifclip
gifclrmp
gifcolor
gifcomb
gifcompose
giffiltr
giffix
Instalación de libungif 88
Más Allá de Linux From Scratch
gifflip
gifhisto
gifinfo
gifinter
gifinto
gifovly
gifpos
gifrotat
gifrsize
gifspnge
giftext
gifwedge
Crea un GIF de prueba que se asemeja al patrón de prueba de color del monitor.
icon2gif
raw2gif
rgb2gif
text2gif
libmng−1.0.5
gifflip 89
Más Allá de Linux From Scratch
Introducción a libmng
La librería libmng la utilizan los programas que quieren leer y escribir ficheros Gráficos de Imágenes Múltiples para Red (Multiple−image Network
Graphics, MNG), que son los equivalentes animados de los ficheros PNG.
Dependencias de libmng
Requeridas
libjpeg−6b y lcms−1.11
Instalación de libmng
: Este comando establece el directorio de instalación y también le indica a la rutina de cofiguración que busque y encuentre zlib, libjpeg y lcms.
cp doc/man/*.X /usr/share/man/manX : El proceso de instalación no instala correctamente las páginas de manual, por eso lo hacemos manualmente.
Contenido
Descripción
Librerías MNG
libmng proporciona funciones a los programas que desean leer y escribir ficheros MNG, que son ficheros de animaciones sin los problemas de
patentes asociados con otros formatos.
Imlib−1.9.14
Introducción a Imlib
El paquete Imlib contiene librerías de imagen. Son útiles para cargar, generar o difuminar una extensa variedad de formatos de imágenes.
Dependencias de Imlib
Introducción a libmng 90
Más Allá de Linux From Scratch
Requeridas
Instalación de Imlib
−−sysconfdir=/etc/imlib : Esto instala y combina los ficheros de configuración en /etc en lugar de en /usr/etc.
Contenido
Descripción
Librerías imlib
Las librerías libimlib proporcionan a los programas funciones para mostrar y editar una extensa variedad de formatos de imágenes.
AAlib−1.4rc5
Introducción a AAlib
Dependencias de AAlib
Opcionales
XFree86−4.3.0.1 y slang−1.4.9
Instalación de AAlib
Contenido
El paquete AAlib contiene las librerías libaa, aalib−config, aainfo, aatest y aasavefont.
Descripciones
La librería ASCII Art es una colección de rutinas para representar cualquier entrada gráfica en formato portable a ASCII Art. Puede ser usada por
muchos programas y tiene una API muy bien documentada, de modo que puedes incluirla fácilmente en tus propios programas.
aalib−config
Requeridas 91
Más Allá de Linux From Scratch
aainfo
aatest
aafire
aafire es otro juguete de AAlibaalib, que muestra un fuego animado en ASCII Art.
aasavefont
SVGAlib−1.4.3
Introducción a SVGAlib
SVGAlib es una librería gráfica de bajo nivel que proporciona modos VGA y SVGA en la consola. Es útil para programas que se ejecutan en la consola
y requieren capacidades gráficas.
Descarga adicional
Instalación de SVGAlib
Nota: Debes compilar e instalar como usuario root. Si no lo haces, nada malo ocurrirá durante la compilación, pero ciertas
herramientas no podrán instalarse como SUID root, necesario para un funcionamiento adecuado. Sin embargo, esto conlleva el
riesgo de exponer tu sistema ante cualquier agujero de seguridad en esas herramientas que pueda ser usado para ganar acceso
como root, así que úsalas con cuidado.
cd doc && for dir in man?; do for file in $dir/*; do gunzip /usr/share/man/$file; done; done : SVGAlib instala sus páginas de manual en formato
comprimido, así que las descomprimimos.
Configuración de SVGAlib
Ficheros de configuración
/etc/vga/libvga.config y ~/.svgalibrc
Debes editar el fichero de configuración para establecer el tipo de monitor y ratón que usas. Dependiendo del hardware, puede que necesites
configuración adicional.
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
aainfo 92
Más Allá de Linux From Scratch
Contenido
El paquete SVGAlib contiene las librerías libvga y libvgagl, dumpreg, mode3, restorefont, restorepalette, restoretextmode, savetextmode,
textmode y svgakeymap.
Descripciones
Librería libvga
Librería libvgagl
dumpreg
mode3
restorefont
restorepalette
restoretextmode
savetextmode, textmode
savetextmode y textmode guardan o restauran el estado SVGA completo para el modo texto.
svgakeymap
DirectFB−0.9.19
Introducción a DirectFB
DirectFB es una librería gráfica que funciona sobre el dispositivo de framebuffer de Linux. Ofrece un rendimiento máximo en aceleración por hardware
a un costo mínimo en uso de recursos y carga del sistema.
Descarga adicional
Dependencias de DirectFB
Requieridas
Contenido 93
Más Allá de Linux From Scratch
Opcionales
Instalación de DirectFB
Nota: DirectFB necesita un núcleo Linux con soporte para frame buffer. Consulta la documentación en el árbol de fuentes del
núcleo (/usr/src/linux/Documentation/fb/) para saber como activar el dispositivo frame buffer para tu tarjeta de
gráficos.
Si decides añadir el video e imagen opcional suministrado, entonces también debes instalar el paquete DirectFB−extra:
Nota: La versión actual de avifile no funciona con DirectFB. Tendrás que usar la versión de avifile que se encuentra en
http://www.directfb.org/download/contrib/ o, alternativamente, desactivar el video avifile suministrado invocando a configure
con −−disable−avifile.
Configuración de DirectFB
Ficheros de configuración
/etc/directfbrc, ~/.directfbrc
Los valores por defecto de DirectFB son aceptables, pero puede que quieras afinar las cosas. Hay varias formas de hacerlo: puedes editar el fichero de
configuración del sistema /etc/directfbrc, el fichero de usuaruio ~/.directfbrc, o puedes configurar la aplicación DirectFB por medio de
la línea de comandos. Consulta la página de manual de directfbrc(5) para más detalles.
Contenido
El paquete DirectFB contiene dfbdump, dfbg, dfbinfo, dfblayer, directfb−config, directfb−csource y las librerías libdirectfb.
Descripciones
dfbdump
Esta es una herramienta simple de depurado para DirectFB que muestra una lista de superficies y ventanas.
dfbg
dfbinfo
dfblayer
directfb−config
directfb−config proporciona todas las opciones para enlazar binarios estáticos con controladores a elección y otros módulos internos.
directfb−csource
Opcionales 94
Más Allá de Linux From Scratch
Librerías libdirectfb
Proporcionan aceleración de gráficos por hardware, manejo y abstracción de los dispositivos de entrada, un sistema de ventanas integrado con soporte
para ventanas translúcidas y múltiples capas de pantalla sobre el dispositivo de framebuffer de Linux.
Imlib2−1.1.0
Introducción a Imlib2
Imlib2 es una librería gráfica para la carga. guardado transformación y manipulación rápida de ficheros.
Dependencias de Imlib2
Requeridas
Opcionales
Instalación de Imlib2
Contenido
Este paquete contiene la librería libImlib2 y varias librerías de filtro y carga de imágenes.
Descripción
libImlib2
libImlib2 suministra a los programas las funciones para manejar varios formatos de datos de imágenes.
Librerías libdirectfb 95
Capítulo 10. Utilidades Generales
bc−1.06
Introducción a bc
Dependencias de bc
Requerida
readline−4.3
Instalación de bc
Contenido
Descripciones
bc
bc es una calculadora.
dc
rep−gtk−0.18
Introducción a rep−gtk
El paquete rep−gtk contiene un vínculo entre Lisp y GTK. Es útil para ampliar las librerías GTK−2 y GDK con Lisp. El paquete rep−gtk−0.15 contiene
los vínculos para GTK y utiliza las mismas instrucciones. Si es necesario puedes instalar ambos.
Dependencias de rep−gtk
Requeridas
Instalación de rep−gtk
Contenido
Descripción
Vínculos Lisp
Los vínculos Lisp son librerías almacenadas en /usr/lib/rep/i686−pc−linux−gnu/gui/ que ayudan en la comunicación entre Lisp y las
librerías GTK.
Compface−1.4
Introducción a Compface
Compface proporciona utilidades y una librería para convertir a/desde formato X−Face, que es un formato de mapa de bits de 48x48 usado para incluir
pequeñas imagenes del autor de un correo en la cabecera del mismo.
Descarga adicional
Instalación de Compface
Contenido
Descripciones
compface
compface es un filtro para generar representaciones altamente comprimidas de ficheros de imagenes de caras de 48x48x1.
uncompface
libcompface
libcompface hace que se puedan usar los algoritmos de compresión y descompresión en otros programas como por ejemplo MTAs.
Requeridas 97
Capítulo 11. Utilidades del Sistema
Este capítulo contiene principalmente utilidades para el hardware. También contiene aplicaciones usadas por otras aplicaciones del libro por motivos de
instalación.
GPM−1.20.1
GPM (El demonio del ratón de proposito general) es un servidor de ratón para aplicaciones que se ejecutan en consola. No solo proporciona soporte
general para cortar y pegar, si no que su librería es usada por diverso software, como links, para proporcionar soporte completo del ratón a la
aplicación. Es útil en escritorios, especialmente si sigues las instrucciones de (Mas alla de) Linux From Scratch. ¡Con frecuencia es mucho mas fácil (y
menos propenso a errores) copiar y pegar entre dos ventanas de consola que escribirlo todo a mano!
Introducción a GPM
El paquete GPM contiene un servidor de ratón para consola y xterm. Es útil para cortar y pegar texto en la consola, y también porque muchos
programas basados en consola lo necesitan para incluir soporte de ratón.
• Descarga (HTTP):
• Descarga (FTP): ftp://arcana.linux.it/pub/gpm/gpm−1.20.1.tar.bz2
• Tamaño del paquete: 556 KB
• Estimación del espacio necesario en disco: 5.3 MB
• Tiempo estimado de construcción: 0.09 SBU
Descargas adicionales
Instalación de GPM
export LDFLAGS="−lm" : La librería matemática debe enlazarse con gpm, ya que se usa la función ceil() en el código de movimiento del cursor.
Sólo se necesita LDFLAGS si se utiliza la optimización de tamaño para gpm.
ldconfig −n −l : Durante la instalación, gpm muestra un mensaje pidiendo que se ejecute el anterior comando para crear los enlaces correctos a las
librerías.
Configuración de GPM
El guión gpm para init.d puede crearse usando los siguientes comandos:
source /etc/sysconfig/rc
source $rc_functions
if [ −f /etc/sysconfig/mouse ]
then
source /etc/sysconfig/mouse
fi
if [ −z "$MDEVICE" ] || [ −z "$PROTOCOL" ]
then
echo "Por favor crea un fichero /etc/sysconfig/mouse que contenga"
echo "los valores de MDEVICE y PROTOCOL"
exit 1;
fi
case "$1" in
start)
echo "Iniciando gpm..."
loadproc gpm −m $MDEVICE −t $PROTOCOL
;;
stop)
echo "Parando gpm..."
killproc gpm
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc gpm
;;
*)
echo "Uso: $0 {start|stop|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/gpm
EOF
chmod 755 /etc/rc.d/init.d/gpm
Ahora necesitas crear los enlaces simbólicos a este fichero en los directorios correspondientes de rc.d. Por ejemplo:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/gpm ../rc0.d/K10gpm &&
ln −sf ../init.d/gpm ../rc1.d/K10gpm &&
ln −sf ../init.d/gpm ../rc2.d/K10gpm &&
ln −sf ../init.d/gpm ../rc3.d/S70gpm &&
ln −sf ../init.d/gpm ../rc4.d/S70gpm &&
ln −sf ../init.d/gpm ../rc5.d/S70gpm &&
ln −sf ../init.d/gpm ../rc6.d/K10gpm
Ficheros de configuración
/etc/sysconfig/mouse Este fichero contiene el nombre del dispositivo de ratón y el protocolo que utiliza. Para crear este fichero ejecuta lo
siguiente:
MDEVICE=/dev/psaux
PROTOCOL=imps2
Una lista de los protocolos conocidos puede obtenerse ejecutando gpm −t −help. Tu MDEVICE depende del tipo de ratón que tengas. Por ejemplo,
/dev/ttyS0 para un ratón serie (en Windows esto es COM1), /dev/input/mice se utiliza normalmente para ratones USB, y /dev/psaux
para ratones PS2. Normalmente se supone que no es buena idea enlazar /dev/mouse al dispositivo correspondiente, y que en cambio hay que
referirse a él directamente.
Contenido
Ficheros de configuración 99
Más Allá de Linux From Scratch
Descripciones
gpm
gpm es una utilidad para cortar y pegar y un servidor de ratón para consolas virtuales.
gpm−root
gpm−root es un manejador predefinido para gpm. Se utiliza para dibujar menús en la ventana raíz.
disable−paste
mev
Fcron−2.9.3
Introducción a Fcron
El paquete Fcron contiene un planificador de tareas periódicas pensado como sustituto de Vixie Cron.
Dependencias de Fcron
Opcionales
Instalación de Fcron
Fcron utiliza la facilidad cron de syslog para registrar todos los mensajes. Puesto que LFS no establece esta facilidad en /etc/syslog.conf,
debemos hacerlo antes de instalar Fcron. Este comando añadirá la línea necesaria al actual fichero /etc/syslog.conf.
cron.* −/var/log/cron.log
El fichero de configuración ha sido modificado, por tanto recarga el demonio sysklogd para activar los cambios.
/etc/rc.d/init.d/sysklogd reload
Por razones de seguridad, necesitamos crear un usuario y un grupo sin privilegios para fcron:
Descripciones 100
Más Allá de Linux From Scratch
−−without−sendmail: Fcron no necesita un MTA para funcionar pero puede usarlo, si está instalado, para enviarte por correo los resultados del guión
fcron. Si deseas usar esta característica, cambia la opción por −−with−sendmail=[ruta a tu MTA] .
−−with−answer−all=no: Tras instalar los ficheros, el guión make install entra en una rutina de configuración. La primera prueba trata sobre la
instalación de un guión de arranque en el directorio /etc/rc.d/init.d con sus correspondientes enlaces simbólicos en los niveles de arranque 2,
3, 4, y 5. La segunda es para detener cualquier proceso fcron actual e iniciar uno nuevo. Puesto que esta es probablemente tu primera instalación y
queremos un guión de arranque basado en la plantilla de BLFS, respondemos "n" en ambas pruebas.
Configuración de Fcron
Ficheros de configuración
No son necesarios cambios en los ficheros de configuración. Puedes encontrar información sobre la configuración en la página de manual de
fcron.conf.
Los guiones de fcron se escriben usando fcrontab. Dirigete a su página de manual para ver los parámetros apropiados para tu situación.
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando fcron..."
loadproc fcron
;;
stop)
echo "Parando fcron..."
killproc fcron
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc fcron
;;
*)
echo "Uso: $0 {start|stop|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/fcron
EOF
chmod 755 /etc/rc.d/init.d/fcron
Crea los enlaces simbólicos a este fichero en los directorios rc.d apropiados con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/fcron ../rc0.d/K08fcron &&
ln −sf ../init.d/fcron ../rc2.d/S40fcron &&
ln −sf ../init.d/fcron ../rc3.d/S40fcron &&
ln −sf ../init.d/fcron ../rc4.d/S40fcron &&
ln −sf ../init.d/fcron ../rc5.d/S40fcron &&
Contenido
Descripciones
fcron
fcrontab
fcrontab es el programa usado para instalar, editar, listar y eliminar las tablas usadas por fcron.
fcronsighup
fcrondyn
fcrondyn es una herramienta de usuario pensada para interactuar con un demonio fcron que esté ejecutandose.
hdparm−5.4
Introducción a hdparm
El paquete hdparm contiene una aplicación útil para controlar tanto las controladoras ATA/IDE como los discos duros, para incrementar sus
prestaciones y, en ocasiones, mejorar la estabilidad.
¡ADVERTENCIA! Al igual que es útil, un uso incorrecto de hdparm puede destruir tu información y, en casos raros, tus discos. Utilízalo con cuidado y
asegúrate de que sabes lo que estás haciendo. Si tienes dudas, te recomendamos que dejes los valores predeterminados por el núcleo.
Instalación de hdparm
make &&
make install
Advierte que, por defecto, hdparm se instala en /sbin pues algunos sistemas pueden necesitarlo en el arranque antes de que /usr sea montado. Si
deseas instalar hdparm bajo la jerarquía /usr, entonces sustituye el comando anterior por el siguiente:
make &&
make binprefix=/usr install
Contenido
Descripción
hdparm
hdparm proporciona una interfaz en línea de comandos para varios ioctls soportados por el controlador de dispositivo del subsistema ATA/IDE de
Linux.
Contenido 102
Más Allá de Linux From Scratch
which−2.14 y alternativas
La presencia / ausencia del programa which en el libro LFS es posiblemente una de las más polémicas discusiones que hemos tenido en las listas de
correo, provocando al menos una disputa recientemente. Para poner de una vez un final feliz a esto, presentamos dos de las varias opciones que hay
para equipar tu sistema con "which". La cuestión sobre qué "which" usar la decides tu.
Introducción a which
Instalación de which
Contenido
Descripción
which
El guión 'which'
La segunda opción (para aquellos que no quieran instalar el programa) es crear un sencillo guión:
Normalmente esto debería funcionar correctamente y es, posiblemente, la solución más facil para máquinas que no necesitan trabajar con un buen
entorno de usuario.
UnZip−5.50
Introducción a UnZip
El paquete UnZip contiene utilidades de extracción ZIP. Son útiles para extraer ficheros de archivos ZIP. Los archivos ZIP se generan con las
utilidades de PKZIP o Info−ZIP , sobre todo en entornos DOS.
Descargas adicionales
Instalación de UnZip
Por defecto, UnZip no soporta descompresión por encogimiento (shrink decompression). Para activarla u obtener mas información, consulta la FAQ de
UnZip en http://www.info−zip.org/pub/infozip/FAQ.html#unshrink.
make prefix=/usr linux : Este comando sobreescribe la variable prefix, que está establecida a /usr/local en el Makefile, y construye los
ejecutables para un sistema linux. Las alternativas a 'linux' pueden verse con el comando 'make list'.
make prefix=/usr linux_shlibz : Construye la librería compartida libunzip y enlaza UnZip con ella y con zlib.
Contenido
Descripciones
unzip
funzip
unzipfsx
unzipfsx es el fragmento de auto−extracción que puede incorporarse a un archivo ZIP. Los ficheros en este formato permiten al receptor descomprimir
el archivo sin instalar UnZip.
zipgrep
zipinfo
zipinfo genera información técnica sobre los ficheros de un archivo ZIP, como los permisos de acceso del fichero, estado de encriptación, tipo de
compresión, etc.
Zip−2.3
Introducción a Zip
El paquete Zip contiene utilidades Zip. Son útiles para comprimir ficheros dentro de archivos Zip.
Instalación de Zip
cp unix/Makefile . &&
make prefix=/usr generic_gcc &&
make prefix=/usr install
make prefix=/usr generic_gcc : Este comando sobreescribe la variable prefix, que está establecida a /usr/local en el Makefile, y construye los
ejecutables para un sistema linux. Las alternativas a 'generic_gcc' pueden verse con el comando 'make list'.
Contenidos
Descripciones
zip
zipcloak
zipcloak está desactivado en esta versión de Zip. Mostrará un mensaje sobre cómo soportar encriptación recompilando con zcrypt27.zip.
zipnote
zipsplit
zipsplit es una utilidad para trocear ficheros ZIP en ficheros más pequeños.
PCI Utilities−2.1.11
Introducción a PCI Utilities
El paquete PCI Utilities está formado por programas que permiten listar dispositivos PCI, inspeccionar su estado y establecer sus registros de
configuración.
Requeridas
Wget−1.8.2 o Lynx−2.8.4
Contenido
Descripciones
lspci
lspci es una utilidad que muestra información sobre todos los buses PCI del sistema y todos los dispositivos conectados a ellos.
setpci
update−pciids
pkgconfig−0.15.0
Introducción a pkgconfig
El paquete pkgconfig contiene herramientas para indicarle al compilador la ruta a las cabeceras y/o a las librerías durante la fase make.
Instalación de pkgconfig
Configuración de pkgconfig
export PKG_CONFIG_PATH=/usr/X11R6/lib/pkgconfig
Contenidos
Descripción
pkg−config
cpio−2.5
Introducción a cpio
Descripciones 106
Más Allá de Linux From Scratch
Instalación de cpio
−−bindir=/bin : Este comando instala cpio en /bin en lugar de en /usr/bin, como recomienda el estándar FHS.
Contenido
Descripciones
cpio
mt
rmt
MC−4.6.0
Introducción a MC
MC (Midnight Commander) es un administrador de ficheros e intérprete de comandos visual en modo texto y a pantalla completa. Facilita una interfaz
limpia, amigable y en cierto modo protegida a un sistema Unix mientras hace mas eficientes muchas de las operaciones frecuentes con ficheros y
conserva el poder completo de la línea de comandos.
Dependencias de MC
Requeridas
GLib−1.2.10 o GLib−2.2.3
Opcionales
Instalación de MC
Configuración de MC
Ficheros de configuración
~/.mc/*
El directorio ~/.mc y su contenido se crean cuando inicias mc por primera vez. Entonces puedes editar el fichero principal de configuración
~/.mc/ini manualmente o mediante la interfaz de MC . Consulta los detalles en la página de manual de mc(1).
Contenido
Descripciones
mc
mcedit
mcview
Configuración de MC 108
Capítulo 12. Programación
Un LFS es un sistema de desarrollo, pero solo para C, C++ y Perl. Este capítulo amplía los lenguajes disponibles.
Python−2.3.2
Introdución a Python
El paquete Python contiene el entorno de desarrollo Python. Es útil para programación orientada a objetos, escribir guiones, hacer prototipos de
programas extensos o desarrollarlos por completo.
Descarga adicional
Dependencias de Python
Opcionales
Instalación de Python
Contenido
Descripciones
python
pydoc
Módulos de Perl
Introducción a los módulos de Perl
Los paquetes de módulos de Perl añaden objetos útiles al lenguaje Perl. Los módulos utilizados por otros paquetes a lo largo del BLFS están listados
aquí, junto con sus dependencias.
Paquetes Perl
• PDL−2.4.0
♦ Astro−FITS−Header−2.7.1
• Gtk−Perl−0.7008
♦ XML−Writer−0.4
♦ XML−Parser−2.31
• Parse−RecDescent−1.94
A continuación tienes las instrucciones de instalación para módulos que parecen estar rotos a día de hoy.
Gtk−Perl−0.7008:
librep−0.16.2
Introducción a librep
El paquete librep contiene un sistema Lisp. Es útil para hacer guiones o para aplicaciones que puedan usar el intérprete Lisp como un lenguaje de
extensión.
Dependencias de librep
Requeridas
GMP−4.1.2 y GDBM−1.8.3
Opcional
readline−4.3
Instalación de librep
Contenido
Descripciones
rep
Librerías librep
Las librerías librep contienen las funciones necesarias para el intérprete Lisp.
J2SDK−1.4.1
Introducción a J2SDK
El paquete J2SDK contiene el entorno de desarrollo de Java de Sun. Sirve para desarrollar programas Java y proporciona el entorno de ejecución
necesario para ejecutar dichos programas. También incluye un módulo (plugin) para que los navegadores puedan ejecutar programas Java .
El JDK viene en dos sabores, un binario precompilado y un paquete fuente. Anteriormente, el módulo incluido en el paquete binario JDK no podía
utilizarse en LFS debido a la incompatibilidad con los navegadores compilados con GCC−3. Esto ya no es así
El paquete fuente requiere que te registres en el sitio de desarrolladores de Sun y que aceptes la Licencia Comunitaria de Sun (Sun Community Source
License). El código fuente no puede ser descargado desde ciertos países, de modo que para los usuarios de esos países la única opción es usar el
binario.
Incluso si planeas compilar el código fuente del JDK, necesitarás descargar la versión binaria para construir el JDK. Sigue el enlace de abajo para
descargar los paquetes fuente y binario. Cuando descargues el código fuente descarga también el paquete con los ficheros de cabecera de Mozilla,
disponible en la misma dirección.
Descargas adicionales
• http://www.linuxfromscratch.org/patches/blfs/5.0/j2sdk−1.4.1−fix−intl−files.patch
• http://www.linuxfromscratch.org/patches/blfs/5.0/j2sdk−1.4.1−gcc33−1.patch
• http://www.linuxfromscratch.org/patches/blfs/5.0/j2sdk−1.4.1−link−missing−libs.patch
• http://www.linuxfromscratch.org/patches/blfs/5.0/j2sdk−1.4.1−motif−mkmsgcat.patch
• http://www.linuxfromscratch.org/patches/blfs/5.0/j2sdk−1.4.1−remove−fixed−paths.patch
• http://www.linuxfromscratch.org/patches/blfs/5.0/j2sdk−1.4.1−syntax−fixes.patch
• http://www.linuxfromscratch.org/patches/blfs/5.0/j2sdk−1.4.1−use−included−motif.patch
Dependencias de J2SDK
Requeridas
Instalación de J2SDK
Instalar el JDK precompilado es fácil, basta con cambiar el bit de ejecución del fichero descargado, cambiar al directorio donde quieres que se instale y
ejecutar el fichero descargado:
VERSION=1.4.2_01 &&
MV=`echo $VERSION | cut −d "_" −f 1,1` &&
V=`echo ${VERSION} | sed −e "s/\./_/g"` &&
chmod +x j2sdk−${V}−linux−i?86.bin &&
./j2sdk−${V}−linux−i?86.bin &&
cd j2sdk${VERSION} &&
install −d /opt/j2sdk/j2sdk−precompiled−${MV} &&
mv * /opt/j2sdk/j2sdk−precompiled−${MV}
rep 111
Más Allá de Linux From Scratch
Si no quieres compilar el código fuente, o no estás en posición de descargar las fuentes debido a las restricciones de la licencia, pasa a la sección de
configuración.
VERSION=1.4.1 &&
V=`echo $VERSION | sed −e "s/\./_/g"` &&
unzip j2sdk−${V}−src−scsl.zip &&
unzip j2sdk−${V}−mozilla_headers−unix.zip &&
patch −Np1 −i j2sdk−${VERSION}−gcc33−1.patch &&
patch −Np1 −i j2sdk−${VERSION}−fix−intl−files.patch &&
patch −Np1 −i j2sdk−${VERSION}−link−missing−libs.patch &&
patch −Np1 −i j2sdk−${VERSION}−remove−fixed−paths.patch &&
patch −Np1 −i j2sdk−${VERSION}−syntax−fixes.patch &&
patch −Np1 −i j2sdk−${VERSION}−motif−mkmsgcat.patch &&
patch −Np1 −i j2sdk−${VERSION}−use−included−motif.patch
export HOTSPOT_BUILD_JOBS=$MAKE_PARALLEL
Si el Motif incluido no se construye correctamente, el error se advierte mucho mas tarde en la construcción. Una solución es construir la librería de
Motif antes de compilar el J2SDK.
cd motif/lib/Xm &&
make &&
cd ../../..
Crea e instala el J2SDK con los siguientes comandos. Habrá un montón de mensajes sobre ficheros no encontrados que parecerán errores. Mientras la
compilación no se detenga, los mensajes son inofensivos, ignóralos.
cd control/make &&
make &&
cd ../.. &&
cd control/build/linux−i?86 &&
cp −a j2sdk−image /opt/j2sdk/j2sdk−1.4.1
export ALT_BOOTDIR="$JAVA_HOME" : Esta variable establece la localización del JDK precompilado que se utilizará para compilar el código
fuente del JDK.
export ALT_MOZILLA_PATH=$PWD : Esto establece la variable que apunta a donde has descomprimido los ficheros de cabecera de Mozilla.
export ALT_DEVTOOLS_PATH="/usr/bin" : Esto cambia la localización donde el guión de construcción encuentra los ejecutables necesarios.
export BUILD_NUMBER="blfs−`date +%s`" : Esto te ayudará a identificar esta versión compilada del entorno de ejecución y máquina virtual,
añadiendo esta información a la versión, en la salida de java −version.
export DEV_ONLY=true : Este comando evita compilar la documentación y elimina una dependencia con rpm.
unset JAVA_HOME : Esto borra la variable JAVA_HOME y evita problemas durante la compilación.
unset CLASSPATH : Esto borra la variable CLASSPATH y evita problemas durante la compilación.
unset CFLAGS... : Estas opciones causan una mala compilación. Nunca las uses.
export INSANE=true : A menos que especifiques que estás loco (insane), la compilación no procederá. La plataforma certificada para compilar es
RedHat 6.1. Esta variable asegura que todos los errores por compilar en una plataforma no certificada se conviertan en advertencias.
Configuración de J2SDK
Tenemos dos Java 2 SDK instalados en /opt/j2sdk. Decide cual quieres utilizar por defecto. Por ejemplo, si decides utilizar el J2SDK compilado a
partir de los fuentes, haz lo siguiente:
Añade las siguientes líneas a tu fichero de inicio del intérprete de comandos (p.e. /etc/profile).
export JAVA_HOME=/opt/j2sdk/j2sdk
export PATH=$PATH:$JAVA_HOME/bin
El plugin Java está en el directorio $JAVA_HOME/jre/plugin/i?86/ns610/. Crea un enlace simbólico al fichero en este directorio desde tu
directorio de plugins.
Contenido
El paquete J2SDK contiene appletviewer, extcheck, idlj, jar, jarsigner, java, javac, javadoc, javah, javap, jdb, keytool, native2ascii, orbd,
policytool, rmic, rmid, rmiregistry, rmiregistry, serialver, servertool y tnameserv.
Descripciones
appletviewer
extcheck
extcheck comprueba en un fichero JAR los conflictos en el título y la versión con cualquier extensión instalada en el software JDK.
idlj
jar
jarsigner
jarsigner firma ficheros JAR (Java ARchive) y verifica las firmas e integridad de un JAR firmado.
java
java lanza una aplicación Java iniciando el entorno de ejecución Java, cargando la clase especificada e invocando el método principal de esa clase.
javac
javac lee definiciones de clases e interfaces, escritas en el lenguaje de programación Java, y las compila en un fichero de clases de código de bytes.
javadoc
javadoc procesa las declaraciones y comentarios de documentación en un conjunto de ficheros fuente Java y genera un conjunto de páginas HTML con
la descripción de clases, interfaces, constructores, métodos y campos.
javah
javah genera las cabeceras C y los ficheros fuente necesarios para implementar métodos nativos.
javap
jdb
keytool
native2ascii
native2ascii convierte ficheros que contienen codificaciones de caracteres no soportados a ficheros con codificaciones Latin−1 o Unicode.
orbd
orbd se usa para permitir a los clientes localizar e invocar transparéntemente objetos persistentes en servidores en el entorno CORBA.
policytool
rmic
rmic genera cabos y ficheros de esqueleto de clases para objetos remotos a partir de los nombres de clases Java compiladas que contienen
implementaciones de objetos remotos.
rmid
rmiregistry
rmiregistry crea e inicia un registro de objeto remoto en el puerto indicado de la máquina actual.
serialver
serialver devuelve el serialVersionUID para una o más clases en un formato adecuado para copiarlo en una clase envolvente.
servertool
servertool proporciona una interfaz fácil de usar para programadores que permite registrar, desregistrar, iniciar y parar un servidor.
tnameserv
Ruby−1.8.0
Introducción a Ruby
El paquete Ruby contiene el entorno de desarrollo Ruby. Es útil para guiones orientados a objetos.
javah 114
Más Allá de Linux From Scratch
Instalación de Ruby
Contenido
Descripciones
ruby
ruby es un lenguaje de guiones interpretado para una rápida y fácil programación orientada a objetos.
irb
GCC−3.3.1
Introducción a GCC
El paquete GCC contiene compiladores GNU. Es útil para compilar programas escritos en Ada, C, C++, Fortran, Java y Objective C.
Descargas adicionales
Instalación de GCC
Si planeas compilar Ada necesitarás instalar GNAT temporalmente para satisfacer la dependencia circular cuando recompìlas GCC para incluir Ada.
• Descarga (HTTP):
• Descarga (FTP): ftp://cs.nyu.edu/pub/gnat/3.15p/gnat−3.15p−i686−pc−redhat71−gnu−bin.tar.gz
• Tamaño del paquete: 13.2 MB
• Estimación del espacio necesario en disco: 48.9 MB
• Tiempo estimado de construcción: 0.01 SBU
Dependencias de GNAT
Requerida
Tcsh−6.12.00
Instalación de GNAT
./doconfig
Este guión te preguntará cómo y dónde quieres instalar GNAT. Para evitar conflictos con el gcc del sistema, instalaremos este paquete en un directorio
aparte, que pueda ser borrado más adelante.
En cuanto a las preguntas que hace el guión doconfig, teclea 3 para responder a la primera pregunta y /opt/gnat para responder a la segunda.
./doinstall
El compilador GNAT puede ser invocado ejecutando el binario gcc que el guión acaba de instalar.
PATH_HOLD=$PATH &&
export PATH=/opt/gnat/bin:$PATH &&
cd gcc/ada &&
touch treeprs.ads [es]info.h nmake.ad[bs] &&
cd ../.. &&
mkdir ../gcc−build &&
cd ../gcc−build &&
CC=/usr/bin/gcc ../gcc−3.3.1/configure −−prefix=/usr −−enable−shared \
−−enable−languages=c,c++,objc,f77,ada,java −−enable−threads=posix \
−−enable−__cxa_atexit −−enable−clocale=gnu &&
make bootstrap &&
make −C gcc gnatlib_and_tools &&
make install &&
ln −sf g77 /usr/bin/f77 &&
export PATH=$PATH_HOLD
rm −rf /opt/gnat
PATH_HOLD=$PATH : Este comando guarda tu PATH actual antes de que sea modificado, para poder restaurarlo después de la instalación.
export PATH=/opt/gnat/bin:$PATH : Este comando permite encontrar el compilador Ada de GNAT para construir Ada.
touch treeprs.ads [es]info.h nmake.ad[bs] : Este comando crea los ficheros necesarios para construir Ada. Puedes omitir este paso si no quieres
compilar el frontal (frontend) para Ada.
CC=/usr/bin/gcc : Este comando es para evitar el uso del nuevo PATH que pone al gcc de GNAT como compilador primario.
−−enable−languages=c,c++,objc,f77,ada,java : Este comando construye todos los lenguajes disponibles en el paquete GCC. Puedes modificar este
comando para eliminar los lenguajes que no desees.
−−enable−shared −−enable−threads=posix −−enable−__cxa_atexit : Estos comandos son necesarios para construir las librerías C++ según los
estándares publicados.
make gnatlib_and tools : Este comando completa el proceso de construcción de Ada. Omítelo si no incluiste Ada entre los lenguajes.
Contenido
El paquete GCC contiene c++, c++filt, cpp, g++, g77, gcc, gccbug, gcov, glob, gnat, gnatbind, gnatbl, gnatchop, gnatfind, gnatkr, gnatlink,
gnatls, gnatmake, gnatprep, gnatpsta, gnatpsys, gnatxref y las librerías GCC.
Descripciones
Los programas y librerías que no se describen aquí se encuentran documentados en la página sobre GCC−3.3.1 del libro LFS.
g77
add2line
add2line convierte los elementos orbitales de 2 líneas contenidos en un fichero del formato ASCII al binario y los añade a los ficheros orbdata.
gcov
gdb
gnatbind
gnatbl
gnatchop
gnatchop renombra ficheros para que cumplan con las convenciones de nombres de ficheros del Ada estándar.
gnatelim
gnatelim sirve para detectar y eliminar subprogramas sin usar en una partición Ada.
gnatfind
gnatgcc
gnatgcc es el compilador.
gnathtml.pl
gnathtml.pl convierte ficheros de código Ada a HTML para visualizarlos con navegadores Web.
gnatkr
gnatkr sirve para determinar el nombre truncado de un fichero dado, cuando se trunca a un largo máximo especificado.
gnatlink
gnatls
gnatemake
gnatmem
gnatmem es la utilidad GNAT que supervisa la actividad de asignación y desasignación dinámica de un programa.
gnatprep
gnatpsta
gnatpsta determina los valores de todos los parámetros relevantes en Standard y los muestra por la salida estándar.
add2line 117
Más Allá de Linux From Scratch
gnatpsys
gnatpsys determina los valores de todos los parámetros relevantes en System y los muestra por la salida estándar.
gnatstub
gnatxref
gvd
Tcl−8.4.4
Introducción a Tcl
El paquete Tcl contiene las Herramientas del Lenguaje de Comandos (Tool Command Language).
Instalación de Tcl
VERSION=8.4.4 &&
V=`echo $VERSION | cut −d "." −f 1,2` &&
DIR=$PWD &&
cd unix &&
./configure −−prefix=/usr &&
make &&
sed −i "s:${DIR}/unix:/usr/lib:" tclConfig.sh &&
sed −i "s:${DIR}:/usr/include/tcl${V}:" tclConfig.sh &&
sed −i "s,^TCL_LIB_FILE='libtcl${V}..TCL_DBGX..so',TCL_LIB_FILE=\"libtcl${V}\$\{TCL_DBGX\}.so\"," tclConfig.sh &&
make install &&
install −d /usr/include/tcl${V}/unix &&
install −m644 *.h /usr/include/tcl${V}/unix/ &&
install −d /usr/include/tcl${V}/generic &&
install −c −m644 ../generic/*.h /usr/include/tcl${V}/generic/ &&
rm −f /usr/include/tcl${V}/generic/{tcl,tclDecls,tclPlatDecls}.h &&
ln −nsf /usr/include/tcl${V} /usr/lib/tcl${V}/include &&
ln −sf libtcl${V}.so /usr/lib/libtcl.so &&
ln −sf tclsh${V} /usr/bin/tclsh
sed −i ...: El paquete Tcl asume que las fuentes usadas para construir Tcl se guardan siempre para construir paquetes que dependen de Tcl. Estos sed's
eliminan las referencias al directorio de construcción y las sustituyen por localizaciones sanas del lado del sistema.
install ...: Estos comandos instalan las cabeceras internas en una localización del lado del sistema.
Tk−8.4.4
Introducción a Tk
gnatpsys 118
Más Allá de Linux From Scratch
Dependencias de Tk
Requeridas
XFree86−4.3.0.1 y Tcl−8.4.4
Instalación de Tk
VERSION=8.4.4 &&
V=`echo $VERSION | cut −d "." −f 1,2` &&
DIR=$PWD &&
cd unix &&
./configure −−prefix=/usr &&
make &&
sed −i "s:${DIR}/unix:/usr/lib:" tkConfig.sh &&
sed −i "s:${DIR}:/usr/include/tk${V}:" tkConfig.sh &&
make install &&
install −d /usr/include/tk${V}/unix &&
install −m644 *.h /usr/include/tk${V}/unix/ &&
install −d /usr/include/tk${V}/generic &&
install −m644 ../generic/*.h /usr/include/tk${V}/generic/ &&
rm −f /usr/include/tk${V}/generic/{tk,tkDecls,tkPlatDecls}.h &&
ln −nsf /usr/include/tk${V} /usr/lib/tk${V}/include &&
ln −sf libtk${V}.so /usr/lib/libtk.so &&
ln −sf wish${V} /usr/bin/wish
sed −i ...: El paquete Tk asume que las fuentes usadas para construirTk se guardan siempre para construir paquetes que dependen de Tk. Estos seds
eliminan las referencias al directorio de construcción y las sustituyen por una localización sana del lado del sistema.
install ...: Estos comandos instalan las cabeceras internas en una localización del lado del sistema.
GCC−2.95.3
Introducción a GCC−2.95.3
Hay dos razones para instalar GCC−2.95.3. La primera es que los desarrolladores del núcleo han certificado a GCC−2.95.3 como el compilador
preferido para compilar el núcleo. La otra razón (y la más convincente) es que algunos paquetes comerciales de código cerrado (como Netscape
Navigator o Yahoo Pager) y paquetes precompilados (como Mozilla) están enlazados con las librerías de GCC−2.95.3.
Descargas adicionales
• http://www.linuxfromscratch.org/patches/blfs/5.0/gcc−2.95.3−2.patch
• http://www.linuxfromscratch.org/patches/blfs/5.0/gcc−2.95.3−no−fixinc.patch
• http://www.linuxfromscratch.org/patches/blfs/5.0/gcc−2.95.3−returntype−fix.patch
Instalación de GCC
Configura GCC para que construya los compiladores de C y C++ y active las opciones relacionadas con C++.
../gcc−2.95.3/configure \
−−prefix=/opt/gcc−2.95.3 \
−−enable−shared −−enable−languages=c,c++ \
−−enable−threads=posix
Mueve las librerías de C++ al directorio estándar de librerías para no tener que añadir /opt/gcc−2.95.3/lib a /etc/ld.so.conf.
Configuración de GCC
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Las instrucciones anteriores crean los enlaces simbólicos que necesitan los paquetes precompilados de BLFS. Puede que necesites crear otros enlaces
simbólicos según tus necesidades.
Cuando necesites usar GCC−2.95.3 en vez del compilador instalado en el sistema, agrega /opt/gcc−2.95.3/bin al principio de tu PATH o
(preferiblemente) establece la variable de entorno CC antes de compilar el paquete en cuestión.
Contenido
El paquete GCC−2.95.3 contiene los compiladores C y C++ de gcc−2.95.3 y la librería libstdc++.so de GCC−2.95.3 que necesitan varios
paquetes comerciales y precompilados.
NASM−0.98.38
Introducción a NASM
NASM (El Ensamblador Netwide) es un ensamblador para 80x86 diseñado para ser portable y modular. Incluye también un desensamblador.
Instalación de NASM
Contenido
Descripciones
nasm
ndisasm
El libro LFS describe cómo configurar una red para conectarse a una LAN con una dirección IP estática. Hay otros métodos para conectarse a una LAN
u a otras redes (como Internet). En este capítulo tratamos los métodos más populares.
Índice
13. Entorno de Red por Marcado Telefónico (Dial−Up)
14. Clientes DHCP
15. Otras formas de conexión
El paquete PPP contiene el demonio pppd y el programa chat. Se utiliza para conectarse a otras máquinas, y a menudo para conectarse a Internet
mediante una conexión telefónica a un ISP.
Descarga adicional
• Parche requerido si piensas usar RP−PPPoE−3.5 con marcación de demanda o el modo PPPoE del núcleo
http://www.linuxfromscratch.org/patches/blfs/5.0/ppp−2.4.1−pppoe−5.patch
Instalación de PPP
Nota: Debes activar el soporte de PPP en el núcleo, ya sea integrado en él o disponible como módulo.
./configure &&
make &&
make install
Configuración de PPP
Ficheros de configuración
/etc/ppp/*
El demonio PPP necesita muy poca configuración. El problema principal es crear el guión para establecer la conexión. Esto puede hacerse usando el
programa chat que viene en este paquete o usando WvDial−1.53.
Contenido
Descripciones
chat
El programa chat establece un diálogo entre el ordenador y el módem. Su función principal es establecer la conexión entre el demonio del Protocolo
Punto a Punto (Point−to−Point Protocol Daemon, PPPD) y el proceso pppd remoto.
pppd
pppdump
pppstats
WvDial−1.53
Introducción a WvDial
El paquete WvDial proporciona una alternativa inteligente, rápida y fácil de usar frente a chat y guiones pppd. Si simplemente quieres conectarte
mediante un módem sin las molestias y problemas de chat, entonces quieres esto.
Dependencias de WvDial
Requeridas
WvStreams−3.70 y PPP−2.4.1
Instalación de WvDial
Configuración de WvDial
Ficheros de configuración
/etc/wvdial.conf, /etc/ppp/peers/*
wvdial
Para más información, consulta las páginas de manual de wvdialconf, wvdial.conf y wvdial.
Contenido
Descripciones
wvdial
wvdialconf
pppstats 124
Capítulo 14. Clientes DHCP
DHCP significa Protocolo de Configuración Dinámica del Anfitrión (Dynamic Host Configuration Protocol). Es un protocolo muy usado para
proporcionar automáticamente información como direcciones IP, máscaras de subred e información de encaminamiento entre computadoras. Si tu red
usa DHCP, necesitarás un cliente DHCP para poder conectarte a ella. DHCP también se usa en algunos módems de cable.
En la actualidad facilitamos instrucciones de instalación para dos clientes DHCP, dhclient (del paquete dhcp) y dhcpcd. Comenzamos con una página
que muestra cómo modificar los guiones de arranque de LFS para incluir soporte genérico de DHCP. Seguidamente presentamos dos lotes de
instrucciones de instalación en las que también se expone cómo crear un fichero de configuración apropiado para trabajar con el cliente DHCP que
elijas.
/etc/sysconfig/network, /etc/sysconfig/network−devices/ifup−eth0,
/etc/sysconfig/network−devices/ifdown−eth0, /etc/sysconfig/network−devices/ifconfig.eth0
Ten en cuenta que en esta y en las siguientes páginas utilizamos eth0 como ejemplo de interfaz de red. Si quieres configurar una diferente (o más de
una), simplemente reemplaza eth0 por la interfaz que desees usar.
Estas instrucciones convertirán los ficheros de configuración de LFS (una configuración estática) en una configuración que utilice el protocolo DHCP.
Ten en cuenta que las interfaces estáticas y DHCP pueden coexistir en un sistema LFS. Para conseguirlo, basta con hacer las modificaciones sólo en las
interfaces que necesiten soporte DHCP. Todas las instrucciones de esta página son válidas sin importar el cliente DHCP que pienses utilizar.
Si la interfaz que piensas utilizar como puerta de enlace por defecto va a usar DHCP, el primer paso es eliminar las variables GATEWAY y
GATEWAY_IF de /etc/sysconfig/network. Esto sólo necesitas hacerlo una vez.
cd /etc/sysconfig &&
cp network network.bak &&
sed "s/GATEWAY/# GATEWAY/" network.bak > network
Ahora necesitas crear los guiones que sobreescribirán los guiones de red por defecto y proporcionarán el soporte DHCP. Estos dos guiones son
genéricos y pueden usarse con ambos clientes DHCP. Primero el guión ifup−eth0:
DHCP−3.0pl2
El paquete DHCP incluye tanto el programa cliente (llamado dhclient) como el servidor para usar DHCP. Si quieres instalarlo puedes encontrar las
instrucciones en DHCP−3.0pl2. Ten en cuenta que si sólo quieres usar el cliente, no necesitas lanzar el servidor y, por tanto, no necesitas los guiones de
arranque y enlaces suministrados para el demonio servidor. Sólo necesitas ejecutar el servidor DHCP si tú suministras este servicio a una red, y seguro
que sabrás si este es el caso. Si no es así, ¡no ejecutes el servidor! Una vez instalado el paquete, vuelve aquí para ver la información sobre cómo
configurar el cliente (dhclient).
Primero, crea el fichero ifconfig.eth0 con los siguientes comandos (advierte que esto sobreescribirá el fichero, si ya existe):
cd /etc/sysconfig/network−devices &&
cat > /etc/sysconfig/network−devices/ifconfig.eth0 << "EOF"
ONBOOT=yes
DHCP_PROG=/sbin/dhclient
DHCP_START=<parametros de inicio apropiados>
DHCP_STOP=−r
EOF
Para más información sobre los posibles valores de DHCP_START y DHCP_STOP, consulta la página de manual de dhclient.
interface "eth0"{
prepend domain−name−servers 127.0.0.1;
request subnet−mask, broadcast−address, time−offset, routers,
domain−name, domain−name−servers, host−name;
require subnet−mask, domain−name−servers;
}
# Fin de dhclient.conf
EOF
dhcpcd−1.3.22−pl4
Introducción a dhcpcd
El paquete dhcpcd contiene el cliente dhcpcd. Es útil para conectar tu ordenador a una red que utilice DHCP para asignar las direcciones de red.
Descarga adicional
Instalación de dhcpcd
patch −Np1 −i ../dhcpcd−1.3.22−pl4−fhs.patch : Dhcpcd sin parchear coloca todos sus ficheros de configuración y temporales en /etc/dhcpc.
Esto es muy molesto cuando dhcpcd dice estar funcionando y no lo está. Tu buscas en /var/run el fichero PID, pero no está ahí. El fichero PID que
se debe borrar está en /etc/dhcpc. Este parche hace que el programa cumpla el FHS, pero lo más importante es que pone los ficheros donde esperas
que estén.
−−prefix="" : Hay una buena razón para ignorar aquí la convención normal de BLFS de usar −−prefix=/usr. Si estás instalando DHCP, posiblemente
se necesitará durante el proceso de arranque y /usr puede que se monte por red, en cuyo caso ¡dhcpcd no estará disponible, pues se encuentra en la
red!. Por tanto, dependiendo de tu situación, querrás que se instale en /sbin o /usr/sbin. Con este comando se instala en /sbin.
dhcpcd−1.3.22−pl4 126
Más Allá de Linux From Scratch
Configuración de dhcpcd
Ficheros de configuración
/var/lib/dhcpc/*
Para configurar dhcpcd, crea el fichero ifconfig.eth0 con los siguientes comandos (advierte que esto sobreescribirá el fichero si ya existe):
cd /etc/sysconfig/network−devices &&
cat > ifconfig.eth0 << "EOF"
ONBOOT=yes
DHCP_PROG=/sbin/dhcpcd
DHCP_START=<parámetros de inicio apropiados>
DHCP_STOP=−k
EOF
Para más información sobre los posibles valores de DHCP_START y DHCP_STOP, consulta la página de manual de dhcpcd.
Contenido
Descripción
dhcpcd
dhcpcd es una implementación del cliente DHCP especificado en los RFC2131 y RFC1541 (dependiendo de las opciones que se especifiquen).
RP−PPPoE−3.5
Introducción a RP−PPPoE
El paquete Roaring Penguin PPPoE contiene un cliente y un componente de servidor que funciona junto con el cliente. El cliente te permite conectarte
a grandes redes que usan el protocolo PPPoE, muy común entre los proveedores de ADSL. El componente de servidor se ejecuta a la par del cliente,
permitiéndote configurar otros clientes que envíen una petición de configuración.
Dependencias de RP−PPPoE
Requerida
PPP−2.4.1
Instalación de RP−PPPoE
Si piensas usar marcación bajo demanda o el modo PPPoE del núcleo, confirma que has aplicado el parche durante la instalación de PPP−2.4.1. Puedes
encontrar información adicional sobre el modo PPPoE del núcleo en rp−pppoe−3.5/doc/KERNEL−MODE−PPPOE.
cd src &&
./configure &&
make &&
make install
Estos son los comandos estándares que se instalarán bajo el directorio /usr. Opcionalmente, puedes usar el guión go que está en la raíz del árbol de
las fuentes para ejecutar los mismos comandos, que serán inmediatamente seguidos por el guión adsl−setup.
Configuración de RP−PPPoE
Ficheros de configuración
Para configurar RP−PPPoE una vez instalado, tienes que ejecutar el guión adsl−setup.
Al configurar tu conexión, necesitarás tener a mano los datos sobre los servidores de nombres de tu ISP, así como tu nombre de usuario y contraseña.
También se te preguntará si quieres configurar una conexión de marcado bajo demanda o permanente. Si tu proveedor no te cobra en base al tiempo que
estés conectado, suele ser buena idea dejar que un guión de arranque se encargue de establecer la conexión por ti. Por supuesto, puedes elegir no
instalar el guión de arranque y, en cambio, iniciar la conexión manualmente con el guión adsl−start.
Ejecuta los siguientes comandos para crear el guión de arranque adsl opcional:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Activando la interfaz ADSL..."
/usr/sbin/adsl−start
evaluate_retval
;;
stop)
echo "Desactivando la interfaz ADSL..."
/usr/sbin/adsl−stop
evaluate_retval
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
/usr/sbin/adsl−status
;;
*)
echo "Uso: $0 {start|stop|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/adsl
EOF
chmod 755 /etc/rc.d/init.d/adsl
Contenido
El paquete RP−PPPoE contiene adsl−setup, adsl−start, adsl−status, adsl−stop, pppoe, pppoe−relay, pppoe−server y pppoe−sniff.
Descripciones
adsl−setup
adsl−start
adsl−status
adsl−stop
pppoe
pppoe−relay
Contenido 129
Más Allá de Linux From Scratch
pppoe−server
pppoe−sniff
Un pequeño husmeador (sniffer) de red diseñado para ayudarte a establecer los parámetros de PPPOE_EXTRA.
pppoe−server 130
V. Entorno de Red básico
Índice
16. Librerías para trabajo en Red
17. Navegadores Web en modo texto
18. Programas Básicos para Trabajo en Red
19. Utilidades Básicas para el Trabajo en Red
20. Clientes de Correo y Noticias
21. Utilidades de D.J. Bernstein
cURL−7.10.7
Introducción a cURL
El paquete cURL contiene curl y su librería de soporte. Es útil para transferir ficheros con sintaxis URL. Por ejemplo, curl
http://curl.haxx.se/download/curl−7.10.7.tar.gz > curl−7.10.7.tar.gz descargaría este programa en el directorio actual. Esta habilidad para descargar
y redireccionar ficheros puede incorporarse en otros programas para soportar funciones como los flujos multimedia.
Dependencias de cURL
Opcionales
OpenSSL−0.9.7c y OpenLDAP−2.1.22
Instalación de cURL
Contenido
Descripciones
curl
curl es un cliente que puede obtener o enviar documentos mediante cualquiera de los siguientes protocolos: HTTP, HTTPS (necesita
OpenSSL−0.9.7c), FTP, GOPHER, DICT, TELNET, LDAP (necesita OpenLDAP−2.1.22) o FILE.
curl−config
curl−config imprime información sobre la última compilación, como las librerías enlazadas y los prefijos establecidos.
Librería curl
WvStreams−3.70
Introducción a WvStreams
El paquete WvStreams contiene librerías de programación para red. Son necesarias para compilar wvdial.
Descargas adicionales
Dependencias de WvStreams
Requerida
OpenSSL−0.9.7c
Instalación de WvStreams
make PREFIX=/usr LDFLAGS="−lcrypt" : Esto corrige algunos problemas de libwvstreams para enlazarse con la librería criptográfica de
OpenSSL.
Configuración de WvStreams
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
Descripciones
wvcrypto
wvstreams
wvutils
GNet−2.0.4
Introducción a GNet
El paquete GNet contiene una librería de red simple. Sirve para soportar conexiones TCP, multidifusión por UDP e IP, búsquedas DNS asíncronas y
más.
Dependencias de GNet
Requerida
GLib−2.2.3
Instalación de GNet
Contenido
libsoup−1.99.23
Introducción a libsoup
El paquete libsoup contiene una implementación en C de una librería HTTP. Sirve para acceder a servidores HTTP en un modo completamente
asíncrono.
Dependencias de libsoup
Opcional
OpenSSL−0.9.7c
Instalación de libsoup
Contenido
Descripción
Librerías libsoup
Las librerías libsoup proporcionan funciones para realizar conexiones HTTP asíncronas.
Links−2.1pre11
Introducción a Links
Links es un navegador WWW en modos texto y gráfico. Incluye soporte para tablas y marcos (frames), realiza descargas en segundo plano y puede
mostrar colores, entre otras cosas.
Dependencias de Links
Opcionales
Instalación de Links
−−enable−graphics: Añade esta opción si quieres usar Links en modo gráfico. También deberás activar el soporte de framebuffer en el núcleo e
instalar GPM−1.20.1, o instalar una de las librerías gráficas soportadas.
Configuración de Links
Ficheros de configuración
~/.links/*
Links almacena la configuración propia de cada usuario dentro de su directorio ~/.links. Estos ficheros se generan automáticamente cuando se
lanza links.
Contenido
Descripción
links
Lynx−2.8.4
Introducción a Lynx
Dependencias de lynx
Requerida
OpenSSL−0.9.7c
Instalación de Lynx
−−libdir=/etc : Por alguna razón, las rutinas de configure y make para lynx usan libdir como prefijo para el fichero de configuración. Establecemos esto
a /etc para que el fichero de configuración del sistema sea /etc/lynx.cfg.
DOCDIR=... HELPDIR=... : Establecemos estas variables para evitar que los ficheros de documentación y ayuda se instalen en /etc.
sed... mv /etc/lynx.bak /etc/lynx.cfg : Este comando sed cambia el fichero /etc/lynx.cfg para que se busque la ayuda en el lugar correcto.
Configuración de Lynx
Ficheros de configuración
/etc/lynx.cfg
Varios ajustes, como el servidor de caché (proxy) a usar, pueden hacerse de forma global para el sistema en el fichero lynx.cfg que se encuentra en
/etc.
Contenido
Descripción
lynx
lynx es un navegador de información distribuida, de propósito general y en modo texto para la World Wide Web.
w3m−0.4.1
Introducción a w3m
w3m es primordialmente un paginador, pero también puede usarse como navegador web en modo texto.
Dependencias de w3m
Opcionales
Instalación de w3m
Configuramos w3m para usar el modelo "monster", que incluye color, menú, ratón, galletas (cookies), y soporte SSL. Otros modelos incluidos:
./configure −yes: Establece todos los parámetros a sus valores por defecto.
−model=monster: Esto establece el modelo de construcción monster. Los modelos de construcción alternativos se mencionan arriba.
Contenido
Descripciones
w3m
w3mman
w3m−0.4.1 137
Capítulo 18. Programas Básicos para Trabajo en Red
Estas aplicaciones son, en general, aplicaciones clientes usadas para acceder al servidor apropiado dentro del sistema o por todo el mundo. Tcpwrappers
y portmap son programas de soporte para demonios que puedes tener en ejecución en tu sistema.
NcFTP−3.1.6
Introducción a NcFTP
El paquete NcFTP contiene una potente y flexible interfaz para el protocolo de Transferencia de Ficheros de Internet. Pretende reemplazar o
complementar al programa estándar ftp.
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.ncftp.com/ncftp/ncftp−3.1.6−src.tar.bz2
• Tamaño del paquete: 396 KB
• Estimación del espacio necesario en disco: 5.2 MB
• Tiempo estimado de construcción: 0.26 SBU
Instalación de NcFTP
Hay dos formas de construir NcFTP. La primera (y óptima), construye la mayor parte de la funcionalidad como una librería compartida y después
construye e instala el programa enlazándolo con esta librería. El segundo método simplemente enlaza toda la funcionalidad en el binario estáticamente.
Esto hace que la librería dinámica no esté disponible para que la utilicen otras aplicaciones. Debes elegir qué método prefieres. Ten en cuenta que el
segundo método no crea un binario enlazado estáticamente por completo, sólo la parte de libncftp se enlaza estáticamente. También se ha de tener
en cuenta que la construcción y uso de la librería compartida está bajo la Clarified Artistic License (Licencia Artística Clarificada). Si embargo, el
desarrollo de aplicaciones que utilicen la librería compartida está sujeto a una licencia diferente.
Para instalar NcFTP usando el primer (y óptimo) método, ejecuta los siguientes comandos:
Para instalar NcFTP usando el segundo método (con la funcionalidad de libncftp enlazada estáticamente), ejecuta los siguientes comandos:
cd libncftp &&
make shared &&
make soinstall
Estos comandos crean e instalan la librería dinámica libncftp contra la que se enlazará el programa principal cuando lo compilemos.
Configuración de NcFTP
Ficheros de configuración
La mayor parte de la configuración de NcFTP se hace mientras se usa el programa y los ficheros se actualizan automáticamente. Una excepción a esto
es ~/.ncftp/prefs_v3. Hay varias opciones para añadir, incluyendo:
yes−i−know−about−NcFTPd=yes
Contenido
El paquete NcFTP contiene ncftp, ncftpbatch , ncftpbookmarks, ncftpget, ncftpls, ncftpput y ncftpspooler.
Descripciones
ncftp
ncftpbatch
ncftpbookmarks
ncftpget
ncftpls
ncftpput
ncftpspooler
Cliente OpenSSH−3.7.1p2
El cliente ssh es un sustituto seguro de telnet. Si quieres instalarlo encontrarás las instrucciones en el Capítulo 23 − OpenSSH−3.7.1p2. Ten en cuenta
que si sólo quieres usar el cliente no necesitas lanzar el servidor y, por tanto, no necesitas los guiones y enlaces de inicio. De acuerdo con las buenas
costumbres, lanza el servidor solamente si lo necesitas en realidad (y si no sabes para qué puedes necesitarlo, ¡entonces es que no lo necesitas!).
Cliente rsync−2.5.6
rsync es una utilidad de transferencia de ficheros rápida e incremental. Si quieres instalarla, encontrarás las instrucciones en el Capítulo 23 −
rsync−2.5.6. Advierte que para usar sólo el cliente, no hace falta ejecutar el servidor y, por tanto, no necesitas los guiones de arranque y sus enlaces. Es
de buena práctica ejecutar un servidor únicamente si en verdad lo necesitas (y si no sabes si lo necesitas o no, ¡lo más probable es que no!).
CVS−1.11.6
Introducción a CVS
CVS es el Sistema de Versiones Concurrentes. Es un sistema de control de versiones útil para proyectos que utilizan un repositorio central para
almacenar los ficheros y conservar todos los cambios hechos en dichos ficheros. Estas instrucciones instalan el cliente usado para manipular el
repositorio. La creación de un repositorio se cubre en cvsserver.
Instalación de CVS
Contenido 139
Más Allá de Linux From Scratch
make install
Configuración de CVS
Ficheros de configuración
~/.cvsrc, ~/.cvswrappers
~/.cvsrc es el principal fichero de configuración de CVS. Este fichero es utilizado por los usuarios para especificar las opciones por defecto de los
diferentes comandos de cvs, por ejemplo, para hacer que todos los comandos cvs diff se ejecuten con −u, el usuario puede añadir diff −u en su
fichero .cvsrc.
~/.cvswrappers especifica los envoltorios (wrappers) que se van a usar además de los indicados en el fichero CVSROOT/cvswrappers del
repositorio.
Contenido
Descripciones
cvs
cvsbug
Se usa para enviar informes de problemas con CVS a un sitio central de soporte.
rcs2log
Wget−1.8.2
Introducción a Wget
El paquete Wget contiene wget, una utilidad para descargar ficheros de la Web en modo no interactivo.
Dependencias de Wget
Opcional
OpenSSL−0.9.7c
Instalación de Wget
Configuración de Wget
Ficheros de configuración
/etc/wgetrc, ~/.wgetrc
Contenido
Descripción
wget
wget obtiene ficheros de la Web usando los protocolos HTTP, HTTPS y FTP. Está pensado para no ser interactivo, trabajar en segundo plano, o usarlo
en operaciones desatendidas.
tcpwrappers−7.6
Introducción a tcpwrappers
El paquete tcpwrappers proporciona programas envoltorios para demonios, que informan sobre el nombre del cliente que solicita servicios de red y el
servicio solicitado.
Descarga adicional
• Parche requerido (Corrige algunos problemas de compilación y añade la construcción de una librería compartida):
http://www.linuxfromscratch.org/patches/blfs/5.0/tcp_wrappers−7.6−shared−lib−plus−plus.patch
Instalación de tcpwrappers
Configuración de tcpwrappers
Ficheros de configuración
/etc/hosts.allow, /etc/hosts.deny
Protección de ficheros: el envoltorio (wrapper), todos los ficheros utilizados por el envoltorio y todos los directorios en la ruta que conduce a esos
ficheros, deben ser accesibles pero no escribibles por usuarios sin privilegios (modo 755 o 555). No instales el envoltorio con el bit set−uid activado.
pasa a ser:
Si usas xinetd, se deben hacer cambios similares, poniendo énfasis en que debes llamar a /usr/sbin/tcpd en vez de llamar directamente al demonio del
servicio, y pasarle el nombre del demonio del servicio a tcpd.
Contenido
Descripciones
tcpd
tcpd es el demonio principal de control de acceso para todos los servicios de internet, que es lanzado por inetd o xinetd en lugar del demonio del
servicio solicitado.
tcpdchk
tcpdchk es una herramienta para examinar la configuración del envoltorio tcpd e informar de problemas.
tcpdmatch
tcpdmatch se utiliza para predecir cómo el envoltorio tcp manejaría una petición específica para un servicio.
try−from
try−from puede llamarse mediante un intérprete de comandos remoto para averiguar si el nombre del sistema y su dirección se reconocen
correctamente.
safe_finger
safe_finger es un envoltorio para la utilidad finger que proporciona búsqueda inversa de nombres automática.
portmap−5beta
Introducción a portmap
El paquete portmap es un sustituto más seguro para el paquete portmap original de SUN. Portmap se utiliza para reenviar peticiones RPC a demonios
RPC como NFS y NIS.
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.porcupine.org/pub/security/portmap_5beta.tar.gz
• Tamaño del paquete: 20 KB
• Estimación del espacio necesario en disco: 250 KB
• Tiempo estimado de construcción: 0.03 SBU
Descargas adicionales
Dependencias de portmap
Requerida
tcpwrappers−7.6
Instalación de portmap
Nota: La instalación de arriba coloca el ejecutable portmap en /sbin. Puedes elegir mover el fichero a /usr/sbin. Si lo
haces, recuerda modificar el guión de arranque.
Contenido 142
Más Allá de Linux From Scratch
Configuración de portmap
Ficheros de configuración
/etc/rc.d/init.d/portmap
source /etc/rc.d/init.d/functions
case "$1" in
start)
echo "Iniciando RPC Portmap"
loadproc /sbin/portmap
;;
stop)
echo "Parando Portmap"
killproc /sbin/portmap
;;
restart)
$0 stop
/bin/sleep 1
$0 start
;;
*)
echo "Uso: $0 {start|stop|restart}"
exit 1
;;
esac
# Fin de /etc/rc.d/init.d/portmap
EOF
chmod 754 /etc/rc.d/init.d/portmap &&
cd /etc/rc.d/init.d &&
ln −sf ../init.d/portmap ../rc0.d/K49portmap &&
ln −sf ../init.d/portmap ../rc1.d/K49portmap &&
ln −sf ../init.d/portmap ../rc2.d/K49portmap &&
ln −sf ../init.d/portmap ../rc3.d/S22portmap &&
ln −sf ../init.d/portmap ../rc4.d/S22portmap &&
ln −sf ../init.d/portmap ../rc5.d/S22portmap &&
ln −sf ../init.d/portmap ../rc6.d/K49portmap
Contenido
Descripciones
portmap
pmap_dump
pmap_set
Inetutils−1.4.2
Introducción a Inetutils
El paquete Inetutils contiene clientes y servidores de red. La instalación de Inetutils en LFS carece de la instalación de los diversos servidores que se
incluyen en el paquete. Las instrucciones en BLFS eliminan esta deficiencia.
Dependencias de Inetutils
Opcionales
Linux−PAM−0.77, y tcpwrappers−7.6
Instalación de Inetutils
−−disable−syslogd : Esta opción evita que Inetutils instale el Demonio de Registro del Sistema, el cual se instaló en el Libro LFS.
−−with−wrap : Esta opción hace que Inetutils se compile contra tcp−wrappers. Omite esta opción si no instalaste tcp−wrappers.
−−disable−whois: Esta opción evitará que Inetutils instale un cliente Whois, pues el cliente whois incluido está anticuado. Añade esta opción si
planeas instalar Whois−4.6.7.
−−with−pam : Esta opción hace que Inetutils se compile contra Linux−PAM . Añade esta opción si quieres utilizar PAM.
−−disable−servers: Varios de los servidores incluidos con Inetutils son inseguros por naturaleza y en algunos casos existen alternativas mejores.
Puedes elegir esta opción y elegir solo los servidores que desees, evitando instalar servidores indeseados.
Contenido
Descripciones
ftp
logger
ping
rcp
rlogin
rsh
syslogd
talk
telnet
tftp
whois
ftpd
inetd
rexecd
rlogind
rshd
talkd
telnetd
tftpd
uucpd
NCPFS−2.2.3
Introducción a NCPFS
El paquete NCPFS contiene herramientas cliente y de administración para usar con redes Novell.
syslogd 145
Más Allá de Linux From Scratch
Instalación de NCPFS
−−prefix="": Instala los binarios en la partición raíz para que estén disponibles al iniciar el sistema. Puede que esto no sea lo ideal en todos los
sistemas. Si /usr se monta localmente, −−prefix=/usr sea tal vez la mejor opción.
−−includedir=/usr/include: Le indica a configure que busque los ficheros de cabecera en /usr/include. También hace que make instale
aquí las cabeceras de NCPFS.
Nota: Si no necesitas usar el protocolo IPX, o usas algún otro paquete IPX, puedes pasarle opcionalmente −−disable−ipx y/o
−−disable−ipx−tools al guión configure para deshabilitar estas opciones.
Configuración de NCPFS
Ficheros de configuración
~/.nwclient
Debería colocarse un fichero ~/.nwclient en el directorio personal de cada usuario que desee usar ncpfs. Los permisos de este fichero deberían
establecerse a 600, por razones obvias de seguridad. El fichero de configuración deberá contener una única línea por cada servidor que el usuario
utilice, y cada línea contendrá el nombre del servidor, el nombre de usuario y opcionalmente su contraseña. Más abajo hay un fichero .nwclient de
ejemplo.
Servidor1/Usuario1 Contraseña
Servidor2/Usuario1
Servidor2/Invitado1 −
La sintaxis del fichero .nwclient es simple, nombre_servidor/nombre_usuario contraseña. Sé extremadamente cuidadoso al crear o
editar este fichero, ya que las utilidades cliente son muy rígidas en cuanto a la sintaxis. Siempre debe haber un espacio en blanco justo después del
nombre de usuario. Si usas una tabulación o más de un espacio, no conseguirás los resultados esperados al usar las herramientas NCPFS. Si no pones
una contraseña, las utilidades cliente la solicitarán cuando sea necesario. Si no se necesita contraseña (por ejemplo al acceder con una cuenta de
invitado) basta con poner un único '−' en su lugar.
Ten en cuenta que no se debería usar ncpmount para montar volúmenes individuales, porque cada punto de montaje crea una nueva conexión cliente
con el servidor Novell. Sería imprudente montar cada volumen individual de forma separada, ya que al montar todos los volúmenes en un servidor bajo
un mismo punto de montaje se usa sólo una conexión cliente.
Si necesitas configurar el protocolo IPX al inicio del sistema, puedes crear los guiones siguientes. Estos guiones asumen que configurarás IPX para el
dispositivo eth0 y que el tipo de red es 802.2. Debes verificar si estos datos son correctos y ajustarlos a tus necesidades.
# Fin de /etc/sysconfig/network−devices/ifup−ipx0
EOF
# Fin de /etc/sysconfig/network−devices/ifdown−ipx0
EOF
echo "ONBOOT=yes" > /etc/sysconfig/network−devices/ifconfig.ipx0
chmod 755 /etc/sysconfig/network−devices/ifup−ipx0
chmod 755 /etc/sysconfig/network−devices/ifdown−ipx0
Contenido
• Utilidades cliente: ncpmount, ncpumount, nprint, nsend, nwpasswd, nwsfind, pqlist, pqrm, pqstat y
slist.
• Utilidades de administración del servidor: ncopy, nwbocreate, nwbols, nwboprops, nwborm, nwbpadd,
nwbpcreate, nwbprm, nwbpset, nwbpvalues, nwdir, nwdpvalues, nwfsctrl, nwfsinfo, nwfstime,
nwgrant, nwpurge, nwrevoke, nwrights, nwtrustee, nwtrustee2, nwuserlist y nwvolinfo.
• Utilidades de la interfaz IPX: ipx_cmd, ipx_configure, ipx_interface, ipx_internal_net e ipx_route.
• Otras utilidades: ncpmap y nwauth.
NTP−4.1.2
Introducción a NTP
El paquete NTP contiene un cliente y servidor para mantener sincronizada la hora entre diversas computadoras de una red. Este paquete es la
implementación oficial de referencia del protocolo NTP.
Dependencias de NTP
Opcional
readline−4.3
Instalación de NTP
Configuración de NTP
Ficheros de configuración
/etc/ntp.conf
El siguiente fichero de configuración define el uso de varios servidores NTP junto con el servidor primario marcado con la opción prefer. También crea
un fichero drift en el que ntpd guarda la frecuencia de actualización. Puesto que la documentación incluida con el paquete es escueta, visita la página
web de NTP en http://www.ntp.org/ para obtener mas información.
Contenido 147
Más Allá de Linux From Scratch
driftfile /var/cache/ntp.drift
Sincronizar la hora
Hay dos opciones. La primera es ejecutar contínuamente ntpd y permitirle que sincronice la hora de forma gradual. La otra es ejecutar ntpd
periódicamente (usando cron) y actualizar la hora cada vez que ntpd es lanzado.
Si eliges la primera opción, crea el guión de arranque /etc/rc.d/init.d/ntp y pon los enlaces simbólicos de inicio y parada:
#!/bin/bash
# Inicio de $rc_base/init.d/ntp
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando ntpd..."
loadproc ntpd
;;
stop)
echo "Parando ntpd..."
killproc ntpd
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc ntpd
;;
*)
echo "Uso: $0 {start|stop|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/ntp
ntpd −q
Contenido
Descripciones
ntpd: Demonio NTP que se ejecuta en segundo plano y mantiene sincronizada la fecha y la hora basandose en la respuesta de los servidores NTP
configurados. También actua como servidor NTP.
ntpdate: Cliente NTP que establece la fecha y la hora basandose en la respuesta de un servidor NTP. Este comando es obsoleto.
ntp−genkeys: Este programa genera los ficheros de datos criptográficos usados por los esquemas de autenticación y de identificación de NTPv4.
Traceroute−1.4a12
Introducción a Traceroute
El paquete Traceroute contiene un programa usado para mostrar la ruta que toman los paquetes por la red para alcanzar una máquina concreta. Es una
herramienta estándar para solucionar problemas en las redes. Si te encuentras con que eres incapaz de conectar con otro sistema, traceroute puede
ayudarte a localizar el problema.
Instalación de Traceroute
Ajusta el Makefile para que el programa se instale con usuario root en lugar de usuario bin (que no existe en un sistema LFS normal).
make install: Instala traceroute con el UID establecido a root en el directorio /usr/sbin. Esto permite que todos los usuarios puedan usar
traceroute. Para una completa seguridad, elimina el bit SUID de los permisos de traceroute con el comando:
El peligro es que si se encuentra en el código de Traceroute un problema de seguridad, como un desbordamiento de la memoria intermedia (buffer
overflow), un usuario normal de tu sistema podría obtener privilegios de root si el programa tiene el SUID root. Por supuesto, eliminar el permiso
SUID hace imposible que otros usuarios, aparte de root, utilicen traceroute. Así que decide lo correcto para tu situación personal.
Ahora, para cumplir por completo con el FHS, como es nuestro objetivo, si dejas el binario traceroute con el SUID a root, entonces debes moverlo a
/usr/bin con el siguiente comando:
mv /usr/sbin/traceroute /usr/bin
Esto asegura que el binario esté en la ruta correcta para los usuarios que no son root.
Contenido
Descripción
traceroute
traceroute hace básicamente lo que dice: traza la ruta que siguen los paquetes desde la máquina en la que estás trabajando a otra máquina de la red,
mostrando todos los pasos intermedios (routers) en su camino.
Nmap−3.30
Introducción a Nmap
Nmap es una utilidad de exploración de red y auditoría de seguridad. Soporta escaneado ping, escaneado de puertos e identificación TCP/IP (TCP/IP
fingerprinting).
Dependencias de Nmap
Opcional
Instalación de Nmap
Contenido
Descripción
nmap
nmap es una utilidad de exploración de red y auditoría de seguridad. Soporta escaneado ping, escaneado de puertos e identificación TCP/IP.
Whois−4.6.7
Introducción a Whois
Whois es una aplicación cliente que pregunta en el servicio de directorio whois la información relativa a un dominio.
Instalación de Whois
make &&
make prefix=/usr install
Contenido
Descripción
whois
whois es una aplicación cliente que pregunta en el servicio de directorio whois la información relativa a un dominio.
BIND Utilities−9.2.2
Introducción a BIND Utilities
BIND Utilities no es un paquete aparte, es una colección de programas cliente que vienen con BIND−9.2.2. El paquete BIND incluye programas cliente
como nslookup, dig y host. Si instalas el servidor BIND, estos programas se instalarán automáticamente. Esta sección es para aquellos usuarios que no
necesitan el servidor BIND completo, pero sí estas aplicaciones cliente.
make −C lib/...: Construye las librerías que necesitan los programas cliente.
Contenido
Los clientes de noticias también nos ayudan a recibir, ordenar, leer y responder, pero estos mensajes viajan a través de USENET (un sistema
internacional de boletines) usando el Protocolo de Transferencia de de Noticias en Red (Network News Transfer Protocol, NNTP).
Nail−10.5
Introducción a Nail
El paquete Nail contiene un Agente de Correo de Usuario de línea de comandos compatible con el comando mail disponible en las versiones
comerciales de Unix. El comando mail puede usarse al escribir guiones.
Dependencias de Nail
Opcional
OpenSSL−0.9.7c
Instalación de Nail
Instala Nail ejecutando los siguientes comandos. (Nota: Si quieres que nail se enlace con openssl, agrega la opción −−with−openssl al comando
configure que se menciona a continuación.)
Configuración de Nail
Ficheros de configuración
/etc/nail.rc
Contenido
El paquete Nail contiene nail, un programa compatible con el comando mail disponible en las versiones comerciales de Unix.
Descripción
nail
Procmail−3.22
Introducción a Procmail
El paquete Procmail contiene un procesador de correo autónomo. Sirve para filtrar y clasificar el correo entrante.
Instalación de Procmail
Configuración de Procmail
Ficheros de configuración
/etc/procmailrc, ~/.procmailrc
Las recetas (recipes) deben escribirse y colocarse en el fichero ~/.procmailrc para que se ejecuten. La página de manual de procmailex es el sitio
donde aprender a escribir estas recetas.
Contenido
Descripciones
procmail
procmail es un procesador autónomo de correo. Realiza todas las funciones de un MDA (Agente de Entrega de Correo).
formail
formail es un filtro que puede usarse para formatear correo en formato mailbox.
lockfile
lockfile es una utilidad que puede bloquear un fichero para uso simple, interactivamente o mediante un guión.
mailstat
mailstat imprime un resumen del correo que ha sido filtrado por procmail desde la última vez que mailstat fue lanzado.
Fetchmail−6.2.3
Introducción a Fetchmail
El paquete Fetchmail contiene un programa de recogida de correo. "Este recibe el correo de los servidores remotos y lo reenvía al sistema de entrega
local (cliente) de tu máquina, de modo que pueda ser leído por los agentes de correo de usuario normales."
Dependencias de Fetchmail
Requeridas
Instalación de Fetchmail
−−with−ssl : Esto activa SSL si se encuentra, de forma que puedas establecer conexiones seguras con servidores POP3 e IMAP.
−−enable−fallback=procmail : Esto le dice a Fetchmail que el correo entrante se lo pase a Procmail para su reparto si tu servidor de correo en el
puerto 25 no existe o no responde.
Configuración de Fetchmail
Ficheros de configuración
~/.fetchmailrc
poll NOMBRESERVIDOR :
user "usuario" pass "contraseña";
mda "/usr/bin/procmail −f %F −d %T";
Esto es una configuración de ejemplo que puede ser suficiente para muchas personas. Puedes añadir tantos usuarios y servidores como necesites,
usando la misma sintaxis.
man fetchmail : Busca cerca del final de la página la sección CONFIGURATION EXAMPLES (EJEMPLOS DE CONFIGURACIÓN), que muestra
también varios ejemplos rápidos. Hay una gran cantidad de opciones de configuración que puedes usar.
Contenido
Descripciones
fetchmail
Cuando se ejecuta como usuario, se usa como fuente el ~/.fetchmailrc del usuario y descarga el correo correspondiente.
fetchmailconf
Este programa proporciona una interfaz gráfica en Tk para tu ~/.fetchmailrc, haciendo más fácil su configuración. Sin embargo, necesitarás
Python y debes tener disponible el módulo Tkinker.
Mutt−1.4.1i
Introducción a Mutt
El paquete Mutt contiene un Agente de Correo de Usuario. Es útil para leer, escribir, responder, guardar y borrar tu correo.
Dependencias de Mutt
Opcional
GnuPG−1.2.3
Instalación de Mutt
Mutt necesita un grupo lamado 'mail'. Puedes añadir este grupo, si aún no existe, con este comando:
groupadd mail
Si no instalas un MTA, como Postfix−2.0.16 o Sendmail−8.12.10, necesitas modificar el propietario de /var/mail con este comando:
Configuración de Mutt
Ficheros de configuración
No es necesario hacer cambios en estos ficheros para empezar a usar Mutt. Cuando estés listo para hacer cambios, la página de manual de muttrc es
un buen punto de partida.
Contenido
Descripciones
mutt
mutt es un Agente de Correo de Usuario (MUA) que te permite leer, editar y borrar tu correo.
flea
muttbug
mutt_dotlock
pgpwrap
Opcional 155
Más Allá de Linux From Scratch
pgpring
Pine−4.58
Introducción a Pine
El paquete Pine contiene el Agente de Correo de Usuario Pine y varios demonios servidores para varios protocolos de correo, aparte de algunos
agradables programas de edición/navegación de ficheros y directorios.
Dependencias de Pine
Requerida
OpenSSL−0.9.7c
Opcionales
OpenLDAP−2.1.22 y Keberos5
Descarga adicional
Instalación de Pine
patch −Np1 −i ../pine−4.58−fhs.patch : Este parche hace que Pine use /etc para los ficheros de configuración.
El proceso de construcción de Pine es algo inusual, pues las opciones que normalmente se pasan a ./configure o se ponen en $CFLAGS debe ponerse
todas en la línea de comandos del guión ./build.
./build slx : Pine ofrece varias plataformas de destino; slx especifica Linux usando −lcrypt para obtener la función crypt. Consulta el fichero
doc/pine−ports para más información y otros métodos de autenticación.
DEBUG=−O : Esta opción compila una versión optimizada de pine y pico que no genera ficheros de depuración.
cd bin &&
install pine imapd ipop2d ipop3d mailutil mtest pico pilot rpdump \
rpload /usr/bin
pgpring 156
Más Allá de Linux From Scratch
Configuración de Pine
Ficheros de configuración
~/.pinerc
El ejecutable pine no necesita una configuración global. Los usuarios pueden poner las opciones de Pine en ~/.pinerc, usando un menú de
configuración interno.
Contenido
El paquete Pine contiene pine, pico, pilot, imapd, ipop2d, ipop3d, mtest, rpload y rpdump.
Descripciones
pine
pico
pilot
imapd
ipop2d
ipop3d
mtest
rpload
rpload es la utilidad de datos remotos de Pine, usada para convertir ficheros de configuración local de Pine, o libretas de direcciones, en
configuraciones o libretas de direcciones remotas.
rpdump
rpdump se usa para copiar los datos de ficheros de configuración remotos de Pine, o libretas de direcciones, en ficheros locales.
slrn−0.9.7.4
Introducción a slrn
slrn es un lector de noticias basado en slang, capaz de leer colas (spools) de noticias locales o grupos de un servidor NNTP. También pueden crearse
pequeñas colas de noticias locales mediante el programa slrnpull incluido.
Dependencias de slrn
Requeridas
Instalación de slrn
Configuración de slrn
Ficheros de configuración
La primera vez que se lanza slrn debe crearse el fichero $HOME/.jnewsrc. Para que esta configuración funcione, debes tener establecida una
variable de entorno, NNTPSERVER. En un funcionamiento normal debería exportarse al entorno desde un fichero de inicio, como /etc/profile o
~/.bashrc. Aquí lo pondremos simplemente en el entorno del paso de configuración. Usaremos en el ejemplo el servidor de noticias de LFS, pero
deberías utilizar el servidor que prefieras.
NNTPSERVER=news.linuxfromscratch.org \
slrn −f $HOME/.jnewsrc −−create
Contenido
Descripciones
slrn
slrnpull
slrnpull se usa para obtener alimentación de noticias de un servidor NNTP, para leerlas sin conexión.
Mozilla−1.5 incluye tanto un cliente de correo como un lector de noticias en su instalación, junto con indicaciones para instalar Mozilla Thunderbird,
un cliente de correo y noticias basado en el código base de Mozilla.
daemontools−0.76
Introducción a daemontools
El paquete daemontools es un sustituto para inetd o xinetd. La razón principal para utilizarlo aquí es porque se recomienda usarlo con qmail y djbdns.
Descargas adicionales
Instalación de daemontools
cd admin/daemontools−0.76 &&
patch −Np1 −i ../../daemontools−0.76−errno.patch &&
package/compile &&
cd package &&
sed 's|command|usr/sbin|' boot.inittab > boot.inittab~ &&
mv boot.inittab~ boot.inittab &&
cd ../command &&
sed −e 's|/command:/usr/local/bin:/usr/local/sbin:||' \
−e 's|command|usr/sbin|' \
−e 's|/service|/etc/service|g' svscanboot > svscanboot~ &&
mv svscanboot~ svscanboot &&
chmod 555 svscanboot &&
cp * /usr/sbin &&
cd ../package &&
cat /etc/inittab boot.inittab > /etc/inittab~ &&
mv −f /etc/inittab~ /etc/inittab &&
mkdir /etc/service &&
telinit Q
El paquete daemontools no viene con páginas de manual, así que instala este paquete si quieres ayuda en línea con los programas de daemontools:
Lo primero que hay que entender al instalar cualquier paquete escrito por Daniel J. Bernstein, y esto incluye qmail, djbdns y ucspi−tcp aparte de
daemontools, es que incumple los estándares si su idea de hacer bien las cosas difiere de un estándar en particular. El profesor Bernstein es un estándar
por sí mismo en lo que a su software se refiere.
Esto implica que es necesario hacer algunos cambios en los comandos de instalación de sus paquetes para poder instalarlos de forma que cumplan el
Estándar de la Jerarquía del Sistema de Ficheros (FHS). Muchos de los siguientes comandos se deben a este hecho.
cd admin/daemontools−0.76 : Primero, el paquete se desempaqueta en un directorio admin. Encontrarás el paquete en sí dos directorios por debajo
de este.
Como vamos a instalar los binarios en /usr/sbin en lugar de crear un directorio /command que no es estándar, debemos cambiar varias rutas:
sed −e 's|/command:/usr/local/bin:/usr/local/sbin:||' \
−e 's|command|usr/sbin|' \
−e 's|/service|/etc/service|g' svscanboot > svscanboot~ &&
Esto cambia varias rutas en el guión svscanboot. En nuestra configuración svscan comprobará en el directorio /etc/service los demonios a
lanzar, en lugar de usar /service.
Estos comandos añaden una línea en /etc/inittab para que init lance el guión svscanboot.
mkdir /etc/service : Este comando crea el directorio de control de daemontools, que es necesario que exista aunque esté vacío, para que daemontools
funcione correctamente.
telinit Q : Este comando le dice al proceso init que lea de nuevo su fichero de configuración (inittab) y actúe en consecuencia según los cambios
que se hayan producido. Se ejecuta el guión svscanboot.
Contenido
El paquete daemontools contiene svscanboot, svscan, supervise, svc, svok, svstat, fghack, pgrphack, readproctitle, multilog, tai64n, tai64nlocal,
setuidgid, envuidgid, envdir, softlimit y setlock. Una descripción más detallada de estos comandos puede encontrarse en
http://cr.yp.to/daemontools.html.
Descripciones
svscanboot
svscan
svscan comprueba en el directorio service los demonios a lanzar e inicia un proceso supervise para cada guión encontrado.
supervise
supervise lanza los guiones de inicio que le pasa svscan y monitoriza el proceso que inicia el guión, de modo que si este muere, supervise lo reinicia.
svc
svok
svstat
fghack
pgrphack
readproctitle
multilog
multilog es un programa de registro de eventos. Toma la salida de un demonio y la añade a cualquier número de registros.
Contenido 160
Más Allá de Linux From Scratch
tai64n
tai64nlocal
setuidgid
envuidgid
envuidgid realiza la misma función que setuidgid, pero establece las variables de entorno UID y GID igual a los UID y GID de la cuenta especificada.
envdir
envdir lanza un programa con las variables de entorno especificadas por los ficheros de un directorio.
softlimit
setlock
ucspi−tcp−0.88
Introducción a ucspi−tcp
El paquete ucspi−tcp consiste en un conjunto de herramientas que facilitan la creación de demonios tcp cliente−servidor. tcpserver es una alternativa
más segura a inetd. Tiene integradas funcionalidades para control de acceso basado en reglas, y puede posponer conexiones de forma fácil cuando se
alcanza la carga máxima configurada, al contrario que inetd. tcpserver también está recomendado para usarlo con qmail, que fue escrito por el mismo
autor.
Descarga adicional
Instalación de ucspi−tcp
tai64n 161
Más Allá de Linux From Scratch
cd /usr/sbin
mv tcpclient *@ mconnect delcr addcr tcpcat /usr/bin
Contenido
El paquete ucspi−tcp contiene tcpserver, tcprules, tcprulescheck, argv0, fixcrio, recordio, rblsmtpd, tcpclient, who@, date@, finger@, http@,
tcpcat, mconnect, addcr y delcr
Puedes encontrar una descripción detallada de cada uno de estos programas en http://cr.yp.to/ucspi−tcp/tcpserver.html, pero aquí tienes un breve
resumen:
Descripciones
tcpserver
tcpserver escucha las conexiones TCP entrantes en un puerto, y lanza el programa de tu elección en respuesta a la conexión.
tcprules
tcprules compila las reglas que rigen el control de acceso para tcpserver en un formato de base de datos de acceso rápido.
tcprulescheck
tcprulescheck hace posible ver cómo reaccionará tcpserver a las conexiones provenientes de una dirección concreta, sin necesidad de tener que
conectarse desde esa dirección. Esto es útil para comprobar si las reglas de control de acceso que estás usando hacen lo que esperas.
argv0
fixcrio
recordio
recordio graba todas las entradas y salidas de un programa dado como argumento.
rblsmtpd
rblsmtpd es un programa de bloqueo de correo indeseado (spam) que trabaja en conjunción con tu demonio SMTP y tcpserver.
tcpclient
who@
who@ es un programa de demostración que usa tcpclient y que tiene la funcionalidad del programa rwho. Necesita un servidor que ejecute sysstat en
el puerto 11.
date@
date@ es un programa de demostración que usa tcpclient. Devuelve la fecha del sistema de un ordenador remoto en el que se ejecuta el servicio
daytime en el puerto 13.
finger@
finger@ es un programa de demostración que usa tcpclient y que imita la funcionalidad del programa finger. Necesita un servidor que ejecute fingerd
en el puerto 79.
http@
Contenido 162
Más Allá de Linux From Scratch
tcpcat
tcpcat conecta a un puerto TCP e imprime lo que es devuelto por ese puerto.
mconnect
mconnect conecta a un puerto TCP, envía cualquier entrada al puerto, e imprime las salidas del mismo.
addcr
addcr añade retornos de carro a los ficheros. Este y delcr son útiles para la conversión de ficheros de formato Windows a formato UNIX.
delcr
tcpcat 163
VI. Servidores de Red
Índice
22. Servidores de Correo
23. Otros servidores
Aparte de servidores SMTP hay un servidor POP (qpopper) y un servidor IMAP (Courier−IMAP).
Postfix−2.0.16
Introducción a Postfix
El paquete Postfix contiene un Agente de Transporte de Correo (MTA). Es útil para enviar correo a otros usuarios de tu máquina. También puede
configurarse como servidor de correo central para tu dominio, agente de reenvío de correo o, simplemente, como agente de entrega de correo a tu
Proveedor de Servicios de Internet (ISP) local.
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.porcupine.org/mirrors/postfix−release/official/postfix−2.0.16.tar.gz
• Tamaño del paquete: 1.3 MB
• Estimación del espacio necesario en disco: 94 MB
• Tiempo estimado de construcción: 0.29 SBU
Dependencias de Postfix
Requerida
Berkeley DB−4.1.25
Instalación de Postfix
Antes de que compiles el programa, necesitas crear unos usuarios y grupos que se espera que estén en su lugar cuando se ejecute el guión de
instalación. Añade los usuarios y grupos con los siguientes comandos:
make &&
sh postfix−install daemon_directory=/usr/sbin \
manpage_directory=/usr/share/man \
sample_directory=/usr/share/doc/postfix \
−non−interactive
sh postfix−install ... −non−interactive : No queremos que el guión de instalación nos haga preguntas, por lo que lo invocamos de forma no interactiva
y aceptamos todos los directorios de destino por defecto, excepto en tres casos.
Configuración de Postfix
Ficheros de configuración
MAILER−DAEMON: postmaster
postmaster: root
root: LOGIN
# Fin de /etc/aliases
EOF
El fichero /etc/aliases que acabamos de crear, main.cf y master.cf deben personalizarse para tu sistema. El fichero aliases necesita una
identidad distinta de root para que el correo dirigido a root pueda ser reenviado a un usuario. El fichero main.cf necesita el nombre cualificado
completo de tu máquina. Todas estas modificaciones pueden hacerse con comandos sed introducidos en la consola con las sustituciones apropiadas de
tu nombre distinto de root por [usuario] y el nombre cualificado completo de tu máquina por [localhost.localdomain]. Encontrarás que el fichero
main.cf está autodocumentado, por lo que puedes cargarlo en tu editor para hacer los cambios específicos para tus necesidades.
cp /etc/aliases /etc/aliases.bak
cp /etc/postfix/main.cf /etc/postfix/main.cf.bak
cp /etc/postfix/master.cf /etc/postfix/master.cf.bak
sed "s/LOGIN/[usuario]/" /etc/aliases.bak > /etc/aliases
sed "s/#myhostname = host.domain.tld/myhostname = \
[localhost.localdomain]/" \
/etc/postfix/main.cf.bak > /etc/postfix/main.cf
/usr/bin/newaliases
/usr/sbin/postfix start
Para automatizar la ejecución de Postfix, utiliza los siguientes comandos para crear el guión de init.d:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando Postfix..."
loadproc postfix start
;;
stop)
echo "Parando Postfix..."
loadproc postfix stop
;;
reload)
echo "Recargando Postfix..."
loadproc postfix reload
;;
restart)
$0 stop
sleep 1
$0 start
;;
*)
echo "Uso: $0 {start|stop|reload|restart}"
exit 1
;;
esac
# Fin de $rc_base/init.d/postfix
EOF
chmod 755 /etc/rc.d/init.d/postfix
Crea los enlaces simbólicos a este fichero en los directorios apropiados de rc.d con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/postfix ../rc0.d/K25postfix &&
ln −sf ../init.d/postfix ../rc1.d/K25postfix &&
ln −sf ../init.d/postfix ../rc2.d/K25postfix &&
ln −sf ../init.d/postfix ../rc3.d/S35postfix &&
ln −sf ../init.d/postfix ../rc4.d/S35postfix &&
ln −sf ../init.d/postfix ../rc5.d/S35postfix &&
ln −sf ../init.d/postfix ../rc6.d/K25postfix
Contenido
El paquete Postfix contiene bounce , cleanup, error, flush, lmtp, local, mailq, master, newaliases, nqmgr, pickup, pipe,
postalias, postcat, postconf, postdrop, postfix, postkick, postlock, postlog, postmap, postqueue, postsuper, qmgr, qmqpd, sendmail, showq,
smtp, smtpd, spawn, trivial−rewrite, y virtual.
Descripciones
postfix
master
master es el proceso residente que lanza bounce, cleanup, error, flush, lmtp, local, nqmgr, pickup, pipe, qmgr, qmqpd, showq,
smtp, smtpd, spawn, trivial−rewrite y virtual bajo demanda. Estos programas no están diseñados para trabajar como comandos de
usuario.
postqueue
postqueue implementa el interfaz de usuario de Postfix para administrar la cola. Implementa todas las operaciones disponibles tradicionalmente
mediante el comando sendmail.
sendmail
sendmail implementa la interfaz de compatibilidad Postfix a Sendmail. mailq y newaliases son enlaces simbólicos a sendmail.
showq
showq emula el comando mailq cuando el sistema de correo Postfix no se está ejecutando.
postsuper
postalias
postcat
postconf
postdrop
postkick
postkick hace accesible el sistema privado de correo mediante IPC para utilizarlo en guiones del intérprete de comandos.
postlock
postlock bloquea un fichero para su acceso exclusivo y ejecuta un comando en ese fichero.
postlog
postlog implementa una interfaz de acceso para utilizarla en guiones del intérprete de comandos.
postmap
Contenido 167
Más Allá de Linux From Scratch
qmail−1.03
Introducción a qmail
El paquete qmail contiene el Agente de Transporte de Correo (MTA) de Dan Bernstein. qmail proporciona entrega/retransmisión de correo local y
remoto.
Descarga adicional
Instalación de qmail
qmail necesita que se añadan ciertas cuentas de usuario y grupos antes de instalar el software. Añade los usuarios y grupos con l os siguientes
comandos:
Configuración de qmail
Ficheros de configuración
qmail−1.03 168
Más Allá de Linux From Scratch
server = /var/qmail/bin/tcp−env
server_args = /var/qmail/bin/qmail−smtpd
env = RELAYCLIENT=
only_from = 127.0.0.1
log_on_failure += USERID
}
EOF
Para automatizar la ejecución de qmail, utiliza los siguientes comandos para crear el guión de init.d:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando Qmail..."
/var/qmail/rc &
;;
stop)
echo "Parando Qmail..."
killall qmail−send
;;
restart)
$0 stop
sleep 1
$0 start
;;
*)
echo "Uso: $0 {start|stop|restart}"
exit 1
;;
esac
# Fin de $rc_base/init.d/qmail
EOF
chmod 755 /etc/rc.d/init.d/qmail
Crea los enlaces simbólicos a este fichero en los directorios apropiados de rc.d con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/qmail ../rc0.d/K25qmail &&
ln −sf ../init.d/qmail ../rc1.d/K25qmail &&
ln −sf ../init.d/qmail ../rc2.d/K25qmail &&
ln −sf ../init.d/qmail ../rc3.d/S35qmail &&
ln −sf ../init.d/qmail ../rc4.d/S35qmail &&
ln −sf ../init.d/qmail ../rc5.d/S35qmail &&
ln −sf ../init.d/qmail ../rc6.d/K25qmail
Puede encontrarse información sobre la configuración para algunos de los MUAs (Mail User Agent, Agente de Correo de Usuario) más comúnmente
usados en el fichero /var/qmail/doc/INSTALL.mbox. La mayoría de MUAs pueden configurarse para utilizar el formato Mailbox de qmail
poniendo lo siguiente en ~/.profile:
Contenido
El paquete qmail contiene bouncesaying, condredirect, except, forward, maildir2mbox, maildirmake, maildirwatch,
mailsubj, preline, qbiff, qreceipt, qmail−clean, qmail−inject, qmail−local, qmail−pop3d, qmail−popup,
qmail−qstat, qmail−send, qmail−smtpd y qmail−start.
Descripciones
bouncesaying
condredirect
except
forward
maildir2mbox
maildir2mbox mueve el correo actual de un directorio en formato maildir a un fichero en formato mailbox.
maildirmake
maildirwatch
maildirwatch vigila el maildir de un usuario e imprime un nuevo resumen de correo cada 30 segundos.
mailsubj
mailsubj envía un mensaje de correo con el asunto indicado en la línea de comandos. El cuerpo del mensaje se lee de la entrada estándar.
preline
qbiff
qreceipt
qmail−clean
qmail−inject
qmail−local
qmail−pop3d
qmail−popup
qmail−qstat
bouncesaying 170
Más Allá de Linux From Scratch
qmail−send
qmail−smtpd
qmail−start
qmail−start activa los servicios de entrega de correo, iniciando qmail−send, qmail−lspawn, qmail−rspawn, y qmail−clean.
Sendmail−8.12.10
Introducción a Sendmail
Dependencias de Sendmail
Requeridas
Instalación de Sendmail
Antes de construir Sendmail, necesitamos crear los usuarios, grupos y directorios que este necesita, mediante los siguientes comandos:
Configuración de Sendmail
Ficheros de configuración
/etc/mail/*
qmail−send 171
Más Allá de Linux From Scratch
postmaster: root
MAILER−DAEMON: root
EOF
cd /etc/mail &&
cp −R /usr/src/sendmail−8.12.10/cf/* . &&
cp −R /usr/src/sendmail−8.12.10/cf/cf/submit.mc . &&
cp −R /usr/src/sendmail−8.12.10/cf/cf/sendmail.mc . &&
newaliases −v
Para iniciar y parar Sendmail durante el arranque/cierre del sistema crea el guión de arranque sendmail con los siguientes comandos:
Nota: La opción −qNm, donde N es el número de minutos, controla cada cuanto tiempo procesa Sendmail la cola de correo.
Aquí se usa un valor por defecto de 5 minutos. Los usuarios de estaciones de trabajo puede que quieran utilizar un valor de 1
minuto. En las instalaciones grandes que manejan más correo este valor será mayor.
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando sendmail..."
loadproc /usr/sbin/sendmail −bs −bd −q5m start
;;
stop)
echo "Parando Sendmail..."
killproc sendmail
;;
status)
statusproc sendmail
;;
restart)
$0 stop
sleep 1
$0 start
;;
*)
echo "Uso: $0 {start|stop|status|restart}"
exit 1
;;
esac
# Fin de $rc_base/init.d/sendmail
EOF
chmod 755 /etc/rc.d/init.d/sendmail
Crea los enlaces simbólicos en los niveles de arranque con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/sendmail ../rc0.d/K25sendmail &&
ln −sf ../init.d/sendmail ../rc1.d/K25sendmail &&
ln −sf ../init.d/sendmail ../rc2.d/K25sendmail &&
ln −sf ../init.d/sendmail ../rc3.d/S35sendmail &&
ln −sf ../init.d/sendmail ../rc4.d/S35sendmail &&
ln −sf ../init.d/sendmail ../rc5.d/S35sendmail &&
ln −sf ../init.d/sendmail ../rc6.d/K25sendmail
Contenido
El paquete Sendmail contiene mail.local, rmail, smrsh, editmap, makemap, mailq, newaliases, sendmail, vacation, praliases y mailstats.
Descripciones
mail.local
Contenido 172
Más Allá de Linux From Scratch
rmail
smrsh
editmap
makemap
mailq
newaliases
sendmail
vacation
praliases
mailstats
Exim−4.24
Introducción a Exim
El paquete Exim contiene un Agente de Transporte de Correo escrito por la Universidad de Cambridge, liberado bajo la Licencia Pública GNU.
Dependencias de Exim
Requerida
Berkeley DB−4.1.25
Opcional
XFree86−4.3.0.1
Instalación de Exim
Antes de construir Exim necesitamos crear el grupo y usuario exim con los que se ejecutará el demonio exim:
rmail 173
Más Allá de Linux From Scratch
sed −e ... > Local/Makefile : Muchas de las opciones de configuración de Exim se compilan internamente. Aquí especificamos un número mínimo de
ellas, BIN_DIRECTORY, CONFIGURE_FILE y EXIM_USER. También aplazamos la construcción del programa monitor de Exim, que necesita el
soporte del Sistema X Window, comentando la línea EXIM_MONITOR en el Makefile.
ln −s /usr/sbin/exim /usr/sbin/sendmail : Crea un enlace sendmail para las aplicaciones que lo necesitan. Exim aceptará muchas de las opciones de
línea de comandos de Sendmail.
Configuración de Exim
Ficheros de configuración
/etc/exim.conf, /etc/aliases
Nota: Para proteger un fichero /etc/aliases existente, añadimos estos alias en él si existe. Este fichero será verificado y los
alias duplicados, si los hay, se eliminarán.
Para iniciar y parar Exim durante el arranque/cierre del sistema, crea el guión de arranque de exim con los siguientes comandos:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando exim..."
loadproc /usr/sbin/exim −bd −q1m
;;
stop)
echo "Parando exim..."
killproc exim
;;
status)
statusproc exim
;;
restart)
$0 stop
sleep 1
$0 start
;;
*)
echo "Uso: $0 {start|stop|status|restart}"
exit 1
;;
esac
# Fin de $rc_base/init.d/exim
EOF
chmod 755 /etc/rc.d/init.d/exim
Crea los enlaces simbólicos de los niveles de arranque con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/exim ../rc0.d/K25exim &&
ln −sf ../init.d/exim ../rc1.d/K25exim &&
ln −sf ../init.d/exim ../rc2.d/K25exim &&
ln −sf ../init.d/exim ../rc3.d/S35exim &&
ln −sf ../init.d/exim ../rc4.d/S35exim &&
ln −sf ../init.d/exim ../rc5.d/S35exim &&
ln −sf ../init.d/exim ../rc6.d/K25exim
Contenido
El paquete Exim contiene exim, exim_dumpdb, exim_fixdb, exim_tidydb, exinext, exiwhat, exim_dbmbuild, exicyclog, exigrep, eximstats,
exiqsumm, exiqgrep, exim_lock y exim_checkaccess.
Descripciones
exim
exim_dumpdb
exim_fixdb
exim_tidydb
exinext
exiwhat
exim_dbmbuild
exicyclog
exigrep
eximstats
exiqsumm
Contenido 175
Más Allá de Linux From Scratch
exim_lock
exim_checkaccess
exim_checkaccess indica si una dirección de recepción de correo procedente de una determinada máquina es aceptable o no.
Qpopper−4.0.5
Introducción a Qpopper
Dependencias de Qpopper
Requerida
Instalación de Qpopper
Configuración de Qpopper
exim_lock 176
Más Allá de Linux From Scratch
Contenido
Descripción
qpopper
Courier−0.43.2
Introducción a Courier
El paquete Courier contiene un Agente de Transporte de Correo (MTA). Es útil para enviar correo a otros usuarios de tu máquina. También puede
configurarse como servidor central de correo para tu dominio o como agente de reenvio de correo. El paquete Courier incluye también una interfaz de
correo basada en web, IMAP, IMAP−SSL , POP3, y POP 3−SSL. La configuración listada a continuación permitirá el acceso al correo a usuarios con
PAM y a usuarios virtuales en una base de datos MySQL.
Dependencias de Courier
Requeridas
Opcionales
Instalación de Courier
Antes de compilar el programa, necesitas crear los usuarios y grupos que se espera encontrar cuando se ejecute el guión de instalación. Añade los
usuarios y grupos con los siguientes comandos:
−−with−piddir=/var/run: Especifica el directorio en el que se guardará el fichero PID de Courier cuando Courier esté activo.
−−libexecdir=/usr/sbin: libexecdir contiene programas y librerías que no pueden ejecutarse en la línea de comandos.
−−datadir=/usr/share/courier: Especifica el directorio en el que se instalarán los diversos guiones del intérprete de comandos, guiones de Perl y
ficheros de datos.
−−localstatedir=/var/spool/courier: Especifica el directorio que contendrá la cola de correo y otros datos temporales. La opción por defecto es el
subdirectorio var dentro del directorio especificado con la opción −−prefix.
Contenido 177
Más Allá de Linux From Scratch
−−with−db=gbbm: Courier necesita que esté instalada la librería de bases de datos GDBM o DB. Si ambas están presentes se usa GDBM. Esta opción
fuerza la selección de la librería de bases de datos.
−−with−mailuser=courier: Todos los demonios de Courier excepto dos se ejecutan como usuario sin priviliegios. Esta opción especifica el
identificador de usuario con el que Courier se instalará y ejecutará.
−−enable−workarounds−for−imap−client−bugs: Hay varios errores confirmados en algunos clientes IMAP que no implementan correctamente el
protocolo IMAP4rev1. Esta opción activa algunos arreglos para esos clientes IMAP erroneos. NOTA: make check fallará si se usa esta opción. Primero
deberías configurar sin esta opción y, si todas las pruebas de posconfiguración tienen exito, relanzar configure con esta opción y recompilar.
−−with−ispell=/usr/bin/aspell: El servidor webmail de Courier puede usar revisión gramatical, si el programa aspell está disponible. Si configure
encuentra ispell activa la revisión gramatical. Si aspell no está en la ruta de búsqueda actual, utiliza −−with−ispell=[programa] para indicar
explícitamente la localización de aspell.
Configuración de Courier
Ficheros de configuración
/etc/courier/authmysqlrc
MYSQL_SERVER localhost
MYSQL_USERNAME courier
MYSQL_PASSWORD (tu elección)
MYSQL_SOCKET /tmp/mysql.sock
MYSQL_PORT 3306
MYSQL_DATABASE courier−mail
MYSQL_USER_TABLE users
MYSQL_CLEAR_PWFIELD clear
DEFAULT DOMAIN (tu dominio)
MYSQL_QUOTA_FIELD quota
Si utilizas PAM:
# Fin de /etc/pam.d/esmtp
EOF
cat > /etc/pam.d/pop3 << "EOF
# Inicio de /etc/pam.d/pop3
# Fin de /etc/pam.d/pop3
EOF
cat > /etc/pam.d/imap << "EOF
# Inicio de /etc/pam.d/imap
# Fin de /etc/pam.d/imap
EOF
cat > /etc/pam.d/webmail << "EOF
# Inicio de /etc/pam.d/webmail
# Fin de /etc/pam.d/webmail
EOF
grant all privileges on *.* to courier@localhost identified by '[contraseña]' with grant option;
/etc/courier/defaultdomain
/etc/courier/me
/etc/courier/locals
/etc/courier/esmtpacceptmailfor.dir/system
/etc/courier/aliases/system
Si quieres denegar el acceso para enviar correo desde algunas máquinas, necesitarás editar /etc/courier/smtpaccess/default.
Despues de completar los pasos anteriores necesitarás ejecutar los siguientes comandos:
makesmtpaccess
makehosteddomains
makealiases
Configuración SMTP/SMTMP−SSL
/etc/courier/esmtpd
ESMTPDSTART=YES
/etc/courier/esmtpd−ssl
ESMTPDSSLSTART=YES
Configuración POP3/POP3−SSL
/etc/courier/pop3d
POP3DSTART=YES
/etc/courier/pop3d−ssl
POP3DSLLSTART=YES
Configuración IMAP/IMAP−SSL
/etc/courier/imapd
IMAPDSTART=YES
/etc/courierd/imapd−ssl
IMAPDSSLSTART=YES
Esta sección explica cómo crear MailDirs para los usuarios de tu sistema.
cd /home/[usuario]
maildirmake Maildir
chown [usuario].[grupo] Maildir −R
Esta sección explica cómo ajustar Maildir para tus usuarios virtuales.
cd /home/vmailman
mkdir [usuario_virtual]
cd [usuario_virtual]
maildirmake Maildir
chown vmailman.vmailman Maildir −R
Añade el usuario virtual a la base de datos MySQL. Necesitas introducir al menos una versión de la contraseña, ya sea en texto claro o encriptada.
ejemplo
Esta sección explica cómo ajustar el sistema de correo basado en Web de Courier.
cp −a /usr/sbin/courier/webmail/webmail /var/www/cgi−bin
Necesitarás copiar las imágenes a un directorio bajo el directorio htdocs de tu servidor Apache. El directorio debe llamarse webmail o deberás
especificarlo durante la fase configure con −−enable−imageurl=/url.
cp −a /usr/share/courier/sqwebmail/images /var/www/htdocs/webmail
Esta sección explica cómo ajustar el sistema de administración de Courier basado en Web.
cp −a /usr/sbin/courier/webmail/webadmin /var/www/cgi−bin
/etc/courier/webadmin/password
Si no utilizas SSL en tu servidor Apache, necesitarás añadir /etc/courier/webadmin/unsecureok para ser capaz de usar tus herramientas de
administración basadas en web.
touch /etc/courier/webadmin/unsecureok
El guión de inicio que viene con el paquete Courier es el mas facil de usar. Automáticamente creará los ficheros de datos ausentes y certificados SSL si
no los encuentra. Para instalar el fichero init.d de Courier necesitarás usar los siguientes comandos:
Crea los enlaces simbólicos a este fichero en los directorios rc.d apropiados con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/courier ../rc0.d/K25courier &&
ln −sf ../init.d/courier ../rc1.d/K25courier &&
ln −sf ../init.d/courier ../rc2.d/K25courier &&
ln −sf ../init.d/courier ../rc3.d/S35courier &&
ln −sf ../init.d/courier ../rc4.d/S35courier &&
ln −sf ../init.d/courier ../rc5.d/S35courier &&
ln −sf ../init.d/courier ../rc6.d/K25courier
Contenido
El paquete Courier contiene cancelmsg, courier−config, couriermlm, couriertls, deliverquota, dotforward, imapd, lockmail,
mailbot, maildirkw, maildrop, mailq, makedat, makemime, mimegpg, preline, reformail, reformime, rmail, sendmail, testmxlookup,
courier, courierfilter, courierlogger, couriertcpd, esmtpd, esmtpd−msa, esmtp−ssl, filterctl, imapd, imapd−ssl,
makeacceptmailfor, makealiases, makehosteddomains, makepercentrelay, makesmtpacces, makesmtpaccess−msa, makeuserdb,
makeuucpneighbors, mksmtpcert, mkimapdcert, mkpop3cert, pop3d, pop3d−ssl, pw2userdb, showconfig, showmodules, userdb,
userdbpw, webgpg, authdaemon, authdaemon.mysql, authdaemon.plain, aliascombine, aliascreate, aliasexp, courierd,
courierpop3d, courierpop3login, imaplogin, makedatprog, pcpd, submit, submitmkdir, webadmin, webmail,
courierdsn, addcr, authend, authstate, courieresmtp, courieresmtpd, courierfax, courierdeliver, courierlocal,
courieruucp, perlfilter y dupfilter.
Descripciones
cancelmsg
couriermlm
lockmail
mailbot
mailbot lee un mensaje de correo en la entrada estándar y crea un mensaje de correo en respuesta al remitente del mensaje original.
maildirkw
maildirkw modifica las palabras clave de mensaje en los maildir compatibles de Courier−IMAP.
maildrop
maildrop es un sustituto para el agente local de entrega de correo que incluye un lenguaje de filtros.
mailq
mailq muestra una lista de todos los mensajes que aún no han sido entregados.
reformail
reformail lee un mensaje en la entrada estándar, lo reformatea de algún modo y lo escribe en la salida estándar.
reformime
sendmail
sendmail lee un mensaje de correo y lo entrega a su destinatario. El comando sendmail es parte del servdor de correo Courier, sin embargo intenta
emular el comportamiento del MTA sendmail original.
testmxlookup
testmxlookup lista los nombres y direcciones IP de los reenviadores de correo que reciben correo para el dominio. Es útil para diagnosticar
problemas de entrega de correo.
courier
courier es un agente de transporte de correo multiprotocolo y modular. El comando courier es un comando administrativo y muchas de sus opciones
solo están disponibles para el superusuario.
courierfilter
courierfilter instala o desinstala filtros globales de correo. Los filtros globales de correo se usan para bloquear selectivamente correo indeseado.
filterctl
filterctl instala o desinstala filtros globales de correo. Los filtros globales de correo se usan para bloquear selectivamente correo indeseado.
makeacceptmailfor
makeacceptmailfor construye una lista de dominios de los que se acepta correo procedente del directorio
/etc/courier/esmtpacceptmailfor.dir.
makealiases
makealiases construye una lista de alias procedente de los directorios /etc/courier/aliases o /etc/courier/aliasdir.
makehosteddomains
couriermlm 182
Más Allá de Linux From Scratch
makepercentrelay
makepercentrelay construye una lista de dominios %−relayed procedente del directorio percentrelay.dir.
makesmtpaccess
makesmtpacces construye una lista de acceso a servidores ESMTP procedente del directorio /etc/courier/smtpaccess.
makesmtpaccess−msa
makesmtpaccess−msa construye una lista de acceso a servidores ESMTP procedente del directorio /etc/courier/smtpaccess. Esta lista de
esmtp es para el protocolo MSA.
makeuucpneighbors
showconfig
showmodules
authdaemon
makepercentrelay 183
Capítulo 23. Otros servidores
Aquí encontrarás muchas formas de compartir tu máquina con el resto del mundo o con tu red local. Antes de instalar cualquier paquete de este
capítulo, necesitas asegurarte de que comprendes lo que el paquete hace y cómo configurarlo correctamente. También puede servir de ayuda aprender
sobre las consecuencias de una incorrecta configuración para que puedas analizar los riesgos.
BIND−9.2.2
Introducción a BIND
Instalación de BIND
Configuración de BIND
Ficheros de configuración
Configuraremos BIND para que se ejecute en una jaula chroot como usuario sin privilegios (named). Esta configuración es más segura pues un
compromiso en el DNS sólo puede afectar a unos pocos ficheros en el directorio HOME del usuario named.
cd /home/named &&
mkdir −p dev etc/namedb/slave var/run &&
mknod /home/named/dev/null c 1 3 &&
mknod /home/named/dev/random c 1 8 &&
chmod 666 /home/named/dev/{null,random} &&
mkdir /home/named/etc/namedb/pz &&
cp /etc/localtime /home/named/etc
Crea el fichero named.conf, del cual named leerá la localización de los ficheros de zona, servidores raices de nombres y llaves DNS seguras:
};
controls {
inet 127.0.0.1 allow { localhost; } keys { rndc_key; };
};
key "rndc_key" {
algorithm hmac−md5;
secret "c3Ryb25nIGVub3VnaCBmb3IgYSBtYW4gYnV0IG1hZGUgZm9yIGEgd29tYW4K";
};
zone "." {
type hint;
file "root.hints";
};
zone "0.0.127.in−addr.arpa" {
type master;
file "pz/127.0.0";
};
EOF
Nota: Debes tener la precaución de asegurarte de que no dejas espacios sobrantes en este fichero.
El fichero rndc.conf contiene información para controlar las operaciones de named con la utilidad rndc.
Crea o modifica resolv.conf para utilizar el nuevo servidor de nombres con los siguientes comandos:
status)
statusproc /usr/sbin/named
;;
*)
echo "Uso: $0 {start|stop|restart|status}"
exit 1
;;
esac
# End $rc_base/init.d/bind
EOF
/etc/rc.d/init.d/bind start
Comprobación de BIND
Comprueba la nueva instalación de BIND 9. Primero consulta la dirección de la máquina local con dig:
dig −x 127.0.0.1
Ahora prueba la búsqueda de un nombre externo, tomando nota de la diferencia de velocidad en repetidas consultas debido al caché. Lanza el comando
dig dos veces sobre la misma dirección:
Verás que el resultado es casi instantáneo cuando named consulta las direcciones almacenadas. Para saber todas las opciones de configuración consulta
bind−9.2.2/doc/arm/Bv9ARM.html, el Manual de Referencia del Administrador de BIND.
Contenido
El paquete BIND contiene dig, host, rndc, rndc−confgen, named−checkconf, named−checkzone, lwresd, named, dnssec−signzone,
dnssec−signkey, dnssec−keygen, dnssec−makekeyset y nsupdate.
Descripciones
dig
host
rndc
rndc−confgen
named−checkconf
named−checkzone
lwresd
lwresd es un servidor de nombres que sólo busca consultas guardadas, para usar con procesos locales.
named
dnssec−signzone
dnssec−signkey
dnssec−keygen
dnssec−makekeyset
dnssec−makekeyset genera un grupos de llaves a partir de una o más llaves creadas con dnssec−keygen.
nsupdate
Contenido 187
Más Allá de Linux From Scratch
Requeridas
CVS−1.11.6 y OpenSSH−3.7.1p2
Expondremos la activación de un servidor CVS utilizando OpenSSH como método de acceso remoto. Otros métodos de acceso, que incluyen :pserver:
y :server:, no deberían usarse como acceso de escritura al repositorio CVS. El método :pserver: envía las contraseñas por la red en texto claro y el
método :server: no está soportado en todas las versiones de CVS. Pueden encontrarse instrucciones para acceso anónimo al CVS, en modo sólo lectura,
utilizando :pserver:, al final de esta sección.
1. Crea un repositorio.
Crea un nuevo repositorio CVS con los siguientes comandos, siendo root:
Importa un módulo de fuentes al repositorio con los siguientes comandos, a partir de una cuenta de usuario en la misma máquina que el repositorio
CVS:
Comprueba el acceso local al repositorio CVS desde la misma cuenta de usuario con el siguiente comando:
cvs co cvstest
Comprueba el acceso al repositorio CVS desde una máquina remota usando una cuenta de usuario que tenga acceso ssh al servidor CVS con los
siguientes comandos:
Nota: Sustituye [servername] con la dirección IP o el nombre de la máquina donde está el repositorio CVS. Se te preguntará la
contraseña de la cuenta ssh antes de que el cvs checkout pueda continuar.
CVS puede configurarse para permitir acceso anónimo en modo sólo lectura, usando el método :pserver:, ejecutando los siguientes comandos como
root:
Ejecuta killall −HUP inetd para leer los cambios en el fichero inetd.conf.
Requeridas 188
Más Allá de Linux From Scratch
wait = no
user = root
passenv = PATH
server = /usr/bin/cvs
server_args = −f −−allow−root=/cvsroot pserver
}
EOF
Ejecuta killall −HUP xinetd para leer los cambios en el fichero xinetd.conf.
La comprobación del acceso anónimo al nuevo repositorio requiere una cuenta en otra máquina que pueda conectar con el servidor CVS a través de la
red. No es necesaria una cuenta en el repositorio CVS. Para comprobar el acceso anónimo al repositorio CVS, entra en otra máquina como usuario sin
privilegios y ejecuta el siguiente comando:
chmod 1777 /cvsroot : Permisos de bit pegajoso (sticky bit) para CVSROOT.
export CVSROOT=/cvsroot : Especifica el nuevo CVSROOT para todos los comandos cvs.
cvs import −m "repository test" cvstest vendortag releasetag : Todos los módulos de código fuente deben importarse al repositorio con el comando
cvs import al repositorio CVS antes de usarlos. La opción −m especifica una entrada descriptiva inicial para el nuevo módulo. El parámetro "cvstest" es
el nombre utilizado para el módulo en todos los comandos cvs posteriores. Los parámetros "vendortag" y "releasetag" son usados para una posterior
identificación de cada módulo CVS y son obligatorios tanto si se usan como si no.
(grep anonymous /etc/passwd || useradd anonymous −s /bin/false) : Comprueba si existe el usuario anonymous y lo crea si no lo encuentra.
echo anonymous: > /cvsroot/CVSROOT/passwd : Añade el usuario anonymous al fichero de contraseñas de CVS, que no es utilizado para nada más
en esta configuración.
echo anonymous > /cvsroot/CVSROOT/readers : Añade el usuario anonymous al fichero de lectores de CVS, una lista de los usuarios que tienen
acceso en modo de sólo lectura al repositorio.
DHCP−3.0pl2
Introducción a DHCP
El paquete DHCP contiene tanto el programa cliente como el servidor para DHCP. dhclient (el cliente) es útil para conectar tu computadora a una red
que utilice DHCP para asignar las direcciones de red. dhcpd (el servidor) es útil para asignar direcciones de red en tu red privada.
Instalación de DHCP
Nota: Debes tener el soporte para Packet Socket compilado dentro del núcleo y el soporte para Socket Filtering compilado
dentro del núcleo o como módulo.
./configure &&
make &&
make LIBDIR=/usr/lib INCDIR=/usr/include install
LIBDIR=/usr/lib INCDIR=/usr/include : Este comando instala las librerías y los ficheros de cabecera en /usr en lugar de /usr/local.
Configuración de DHCP
Ficheros de configuración
/etc/dhclient.conf
Puedes encontrar información sobre la configuración del cliente DHCP en el Capítulo 14.
Ten en cuenta que sólo querrás iniciar el servidor DHCP si quieres suministrar direcciones LAN a tu red. El cliente DHCP no necesita que se utilice
este guión. Ten también en cuenta que este guión está hecho para la interfaz eth1, por lo que puede que necesites modificarlo para la configuración de
tu hardware. Con esto en mente, puedes crear el guión DHCP de init.d usando los siguientes comandos.
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando el Servidor DHCP..."
loadproc dhcpd −q eth1
;;
stop)
echo "Parando el servidor DHCP..."
killproc dhcpd
;;
reload)
echo "Recargando el Servidor DHCP..."
reloadproc dhcpd
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc dhcpd
;;
*)
echo "Uso: $0 {start|stop|reload|restart|status}"
exit 1
;;
esac
# Fin $rc_base/init.d/dhcp
EOF
chmod 755 /etc/rc.d/init.d/dhcp
El fichero de estado debe existir en el arranque. El siguiente comando satisfará este requisito:
touch /var/state/dhcp/dhcpd.leases
Los siguientes comandos crearán un fichero de configuración base para el servidor DHCP. Hay varias opciones que puede que quieras añadir
(información que es devuelta al cliente DHCP) y que están recogidas en la página de manual de dhcp.conf.
Contenido
Descripciones
dhclient
dhcpd
dhcpd implementa las peticiones de dirección de red mediante el Protocolo de Configuración Dinámica del Anfitrión (DHCP) y el Protocolo de
Arranque−Asignación de Internet (BOOTP).
dhcrelay
dhcrelay proporciona un método para aceptar peticiones DHCP y BOOTP en una subred sin servidor DHCP y reenviarlas a un servidor DHCP en otra
subred.
Leafnode−1.9.43
Introducción a Leafnode
Leafnode es un servidor NNTP diseñado para suministrar una cola local de USENET en redes pequeñas.
Dependencias de Leafnode
Requerida
pcre−4.3
Instalación de Leafnode
−−sysconfdir=/etc/news : leafnode lee sus datos de configuración de un fichero llamado config, que se creará en /etc/news para evitar
conflictos potenciales con otros paquetes.
Contenido 191
Más Allá de Linux From Scratch
make update : Crea un fichero /etc/news/config.example inicial, que debe renombrarse como /etc/news/config.
Configuración de Leafnode
Ficheros de configuración
Leafnode puede configurarse para utilizar inetd añadiendo una entrada al fichero /etc/inetd.conf con el siguiente comando:
Alternativamente, Leafnode puede configurarse para usar xinetd añadiendo una entrada al fichero /etc/xinetd.conf con el siguiente comando:
El fichero /etc/news/config debe editarse para indicar el nombre del servidor NNTP. Copia el fichero de configuración de ejemplo a
/etc/news/config y guarda el original como referencia:
cp /etc/news/config.example /etc/news/config
Cambia la entrada
server =
La variable de entorno NNTPSERVER debe establecerse a 127.0.0.1 para evitar que los clientes lean las noticias procedentes del alimentador de
entrada. Para ello, añade lo siguiente a /etc/profile o $HOME/.bash_profile :
export NNTPSERVER=127.0.0.1
Contenido
El paquete Leafnode contiene leafnode−version, leafnode, applyfilter, texpire, checkgroups, fetchnews y newsq.
Descripciones
leafnode−version
leafnode
applyfilter
texpire
checkgroups
fetchnews
fetchnews envía los artículos publicados y recibe nuevos articulos de un servidor de entrada de noticias.
newsq
OpenSSH−3.7.1p2
Introducción a OpenSSH
El paquete OpenSSH contiene clientes ssh y el demonio sshd. Es útil para encriptar todo el tráfico que se envía a la red.
Dependencias de OpenSSH
Requerida
OpenSSL−0.9.7c
Opcionales
X11−ssh−askpass y Linux−PAM−0.77
Instalación de OpenSSH
OpenSSH se ejecuta como dos procesos cuando conecta con otro ordenador. El primer proceso es un proceso con privilegios y controla la asignación
de los mismos cuando sean necesarios. El segundo proceso se comunica con la red. Son necesarios pasos adicionales en la instalación para establecer el
entorno adecuado, lo que se realiza con los siguientes comandos:
−−with−md5−passwords : Se necesita esto si hiciste los cambios recomendados por la receta shadowpasswd_plus de LFS en tu servidor SSH cuando
instalaste el Entorno de Contraseñas Ocultas (Shadow Password Suite) o si accedes a un servidor SSH que autentifica mediante contraseñas de usuario
encriptadas con md5.
−−libexecdir=/usr/sbin : OpenSSHSSH pone los programas llamados por otros programas en /usr/libexec. sftp−server es una utilidad de sshd y
ssh−askpass es una utilidad de ssh−add que se instala como enlace a X11−ssh−askpass. Ambas deberían estar en /usr/sbin y no en
/usr/libexec.
Configuración de OpenSSH
checkgroups 193
Más Allá de Linux From Scratch
Ficheros de configuración
/etc/ssh/ssh_config, /etc/ssh/sshd_config
No son necesarios cambios en estos ficheros. Sin embargo, puede que quieras mirarlos para hacer los cambios apropiados según la seguridad de tu
sistema. Puedes encontrar información sobre la configuración en las páginas de manual de sshd, ssh y ssh−agent.
Advierte que sólo querrás iniciar el servidor sshd si quieres ser capaz de acceder por ssh dentro de tu máquina. El cliente ssh no necesita que se utilice
este guión. Dicho esto, si quieres lanzar el demonio ssh, puedes crear el guión del demonio OpenSSH para init.d con los siguientes comandos:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando el Servidor SSH..."
loadproc /usr/sbin/sshd
;;
stop)
echo "Parando el Servidor SSH..."
killproc /usr/sbin/sshd
;;
reload)
echo "Recargando el Servidor SSH..."
reloadproc /usr/sbin/sshd
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc /usr/sbin/sshd
;;
*)
echo "Uso: $0 {start|stop|reload|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/sshd
EOF
chmod 755 /etc/rc.d/init.d/sshd
Crea los enlaces simbólicos a este fichero en los directorios apropiados de rc.d con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/sshd ../rc0.d/K30sshd &&
ln −sf ../init.d/sshd ../rc1.d/K30sshd &&
ln −sf ../init.d/sshd ../rc2.d/K30sshd &&
ln −sf ../init.d/sshd ../rc3.d/S30sshd &&
ln −sf ../init.d/sshd ../rc4.d/S30sshd &&
ln −sf ../init.d/sshd ../rc5.d/S30sshd &&
ln −sf ../init.d/sshd ../rc6.d/K30sshd
Contenido
El paquete OpenSSH contiene ssh, sshd, ssh−agent, ssh−add, sftp, scp, ssh−keygen, sftp−server y ssh−keyscan.
Descripciones
ssh
sshd
ssh−agent
ssh−add
sftp
Programa del tipo FTP que trabaja sobre protocolos SSH1 y SSH2.
scp
ssh−keygen
sftp−server
ssh−keyscan
rsync−2.5.6
Introducción a rsync
El paquete rsync contiene la utilidad rsync. Es útil para sincronizar grandes archivos de ficheros por la red
Instalación de rsync
Por razones de seguridad, se recomienda ejecutar el servidor rsync como un usuario y grupo sin privilegios.
ssh 195
Más Allá de Linux From Scratch
Configuración de rsync
Ficheros de configuración
/etc/rsyncd.conf
Esta es una configuración simple de solo descarga. Mira la página de manual de rsyncd para opciones adicionales (por ejemplo, autenticación de
usuarios).
[localhost]
path = /home/rsync
comment = Modulo rsync por defecto
read only = yes
list = yes
uid = rsyncd
gid = rsyncd
EOF
Advierte que solo querrás iniciar el servidor rsync si quieres proporcionar un archivo rsync en tu máquina. El cliente rsync no necesita usar este guión.
Dicho esto, si quieres ejecutar el demonio rsync, el guión del demonio rsync para init.d puede crearse usando los siguientes comandos:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando el servidor RSYNC..."
loadproc /usr/bin/rsync −−daemon −−compress
;;
stop)
echo "Parando el servidor RSYNC..."
killproc /usr/bin/rsync
;;
reload)
echo "Recargando el servidor RSYNC..."
reloadproc /usr/bin/rsync
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc /usr/bin/rsync
;;
*)
echo "Uso: $0 {start|stop|reload|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/rsyncd
EOF
chmod 755 /etc/rc.d/init.d/rsyncd
Crea los enlaces simbólicos a este fichero en los directorios de rc.d apropiados con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/rsyncd ../rc0.d/K30rsyncd &&
ln −sf ../init.d/rsyncd ../rc1.d/K30rsyncd &&
ln −sf ../init.d/rsyncd ../rc2.d/K30rsyncd &&
ln −sf ../init.d/rsyncd ../rc3.d/S30rsyncd &&
ln −sf ../init.d/rsyncd ../rc4.d/S30rsyncd &&
ln −sf ../init.d/rsyncd ../rc5.d/S30rsyncd &&
ln −sf ../init.d/rsyncd ../rc6.d/K30rsyncd
Contenido
Descripción
rsync
rsync es un sustituto para rcp (y scp) que tiene muchas mas características. Utiliza el "algoritmo rsync" que proporciona un método muy rápido para
sincronizar ficheros remotos. Lo hace enviando solo las diferencias en los ficheros a través del enlace, sin necesidad de que ambos grupos de ficheros
estén presentes de antemano en uno de los extremos del enlace.
OpenLDAP−2.1.22
Introducción a OpenLDAP
El paquete OpenLDAP proporciona una implementación en código abierto del Protocolo Ligero de Acceso a Directorios.
Dependencias de OpenLDAP
Requerida
Berkeley DB−4.1.25
Opcionales
Instalación de OpenLDAP
−−sysconfdir=/etc : Establece la ruta al fichero de configuración para evitar el directorio por defecto /usr/etc.
−−enable−ldbm : Construye slapd usando como interfaz primaria de bases de datos Berkeley DB o GNU Database Manager.
Contenido 197
Más Allá de Linux From Scratch
Configuración de OpenLDAP
Ficheros de configuración
/etc/openldap/*
La única configuración que necesita OpenLDAP es ejecutar ldconfig. El servidor LDAP se puede arrancar con /usr/sbin/slapd, como se describe en la
página de manual de slapd(8). Puedes verificar que LDAP se está ejecutando con ps aux y puedes comprobar el acceso al servidor LDAP con el
siguiente comando:
# extended LDIF
#
# LDAPv3
# base <> with scope base
# filter: (objectclass=*)
# requesting: namingContexts
#
#
dn:
namingContexts: dc=my−domain,dc=com
# search result
search: 2
result: 0 Success
# numResponses: 2
# numEntries: 1
Utilizar GDBM
Para usar GDBM como controlador de bases de datos, debes cambiar en /etc/openldap/slapd.conf la entrada "database" de "bdb" a "ldbm".
Puedes usar ambos creando una sección adicional para bases de datos en /etc/openldap/slapd.conf.
Se necesita una configuración importante de OpenLDAP para usar las opciones de seguridad. El manual OpenLDAP 2.1 Administrator's Guide es un
buen sitio para empezar los ajustes del control de acceso, ejecutarlo como un usuario diferente a root y establecer un entorno chroot.
Se puede agregar información a la base de datos de LDAP mediante ldapadd. Hoy otros programas que pueden usar la base de datos. Para más
información mira la página del manual correspondiente.
Por defecto, el soporte para LDAPv2 está desactivado en el fichero slapd.conf. Una vez que la base de datos esté correctamente configurada y
Mozilla esté configurado para usar el directorio, puedes añadir allow bind_v2 al fichero slapd.conf.
Contenido
El paquete OpenLDAP contiene ldapadd, ldapcompare, ldapdelete, ldapmodify, ldapmodrdn, ldappasswd, ldapsearch, ldapwhoami, slapadd,
slapcat, slapd, slapindex, slappasswd, slurpd, liblber y libldap.
Descripciones
ldapadd
ldapcompare
ldapcompare abre una conexión a un servidor LDAP, enlaza y hace una comparación usando los parámetros especificados.
ldapdelete
ldapdelete abre una conexión a un servidor LDAP, enlaza y borra una o mas entradas.
ldapmodify
ldapmodrdn
ldapmodrdn abre una conexión a un servidor LDAP, enlaza y modifica el RDN de las entradas.
ldappasswd
ldapsearch
ldapsearch abre una conexión a un servidor LDAP, enlaza y hace una búsqueda usando los parámetros especificados.
ldapwhoami
ldapwhoami abre una conexión a un servidor LDAP, enlaza y realiza una operación whoami.
slapadd
slapadd se usa para añadir entradas especificadas en el formato Intercambio de Directorio de LDAP (LDIF) en una base de datos slapd.
slapcat
slapcat Se usa para generar una salida LDAP LDIF basada en el contenido de una base de datos slapd.
slapd
slapindex
slapindex se usa para regenerar índices slapd basados en el contenido actual de una base de datos.
slappasswd
slurpd
liblber y libldap
Estas librerías dan soporte a los programas LDAP y suministran funcionalidad a otros programas que interactuan con LDAP.
Samba−2.2.8a
Introducción a Samba
ldapcompare 199
Más Allá de Linux From Scratch
Instalación de Samba
cd source &&
mkdir −p /etc/samba/private &&
mkdir −p /var/cache/samba &&
./configure \
−−prefix=/usr \
−−sysconfdir=/etc \
−−localstatedir=/var \
−−with−piddir=/var/run \
−−with−fhs \
−−with−smbmount &&
make &&
make install &&
mkdir −p /etc/samba/private
mkdir −p /var/cache/samba
−−prefix=/usr : Establece el prefijo para casi todas las rutas de los ficheros a /usr.
−−sysconfdir=/etc : Establece el directorio de los ficheros de configuración para evitar que se use el directorio por defecto, que es /usr/etc.
−−localstatedir=/var : Establece el directorio para datos variables para evitar que se use el directorio por defecto, que es /usr/var.
−−with−fhs : Asigna todas las otras rutas de los ficheros de modo que sean compatibles con la norma FHS.
−−with−smbmount : Ordena la creación de un programa que usará el comando mount para que montar volúmenes remotos SMB compartidos
(windows) sea tan sencillo como montar sistemas de ficheros NFS remotos.
rm −rf /usr/private : Elimina un directorio creado erróneamente por source/scripts/installbin.sh en la fase make install.
Configuración de Samba
Configuraremos un servidor Samba (SAMBABOX) para actuar como controlador primario de dominio, así como configuraremos un cliente del
dominio que ejecute Windows 2000 Server (WIN2KBOX) y actúe como servidor miembro del dominio. Se darán instrucciones detalladas para añadir
WIN2KBOX al dominio, debido a los pasos extra necesarios. Se pueden encontrar instrucciones para añadir clientes Windows 95/98/XP en la
documentación recién instalada, apuntando un navegador web a:
file:///usr/share/samba/swat/using_samba/ch03_01.html#ch03−55770.
Ficheros de configuración
/etc/samba/smb.conf, /etc/rc.d/init.d/samba
/etc/rc.d/init.d/samba start
Tenemos que añadir la cuenta root de SAMBABOX a la lista de usuarios de Samba para unir WIN2KBOX al dominio DOMAIN01:
smbpasswd −a root
Una vez ejecutado Samba y añadido root a la lista de usuarios de Samba, la primera máquina que uniremos a DOMAIN01 será WIN2KBOX, la
máquina Windows 2000 Server para la que hemos creado la cuenta de máquina de confianza. En WIN2KBOX:
Antes de entrar en WIN2KBOX, crearemos una nueva cuenta de usuario con los siguientes comandos:
Entrar en DOMAIN01.
Ahora iniciaremos la sesión en el dominio, con nuestro usuario recién creado, de esta forma:
}
EOF
La Herramienta de Administración Web de Samba, SWAT, puede lanzarse con el siguiente comando en SAMBABOX:
lynx http://localhost:901
Nota: Asegúrate que inetd está ejecutándose, y ejecuta killall −HUP inetd antes de inciar SWAT.
cat > /etc/samba/smb.conf << "EOF" : Crea un fichero de configuración por defecto de Samba. Esta configuración permitirá a Samba actuar como
Controlador Primario de Dominio para una red basada en Microsoft Windows. Si no deseas esto, se incluye un fichero simple smb.conf predefinido
con la distribución de Samba. Mira el fichero samba2.2.8a/examples/smb.conf.default. La configuración como Controlador Primario de
Dominio (PDC) es ligeramente más complicada que la configuración de un servidor ordinario, por lo que aquí se muestran las instrucciones para la
configuración de un PDC.
cat > /etc/rc.d/init.d/samba << "EOF" : Crea el guión de arranque de Samba, utilizado para iniciar y parar automáticamente Samba durante el
arranque y cierre del sistema.
: Este comando crea una cuenta de máquina de confianza, necesaria sólo para que los servidores Windows 2000/NT se autentifiquen a nuestro nuevo
PDC. No son necesarias cuentas de máquinas de confianza para clientes Win95/98.
echo "swat 901/tcp" >> /etc/services : Registra el programa swat para usar el puerto 901.
echo "swat stream tcp nowait.400 root /usr/sbin/swat swat" >> /etc/inetd.conf : Indica a inetd dónde encontrar y cómo ejecutar swat.
ln −s /etc/rc.d/init.d/samba /etc/rc.d/rc3.d/S600samba etc : Crean los guiones de arranque de Samba, usados para iniciar y parar automáticamente
Samba durante el arranque y cierre del sistema.
Contenido
El paquete Samba contiene make_smbcodepage, make_unicodemap, mount.smbfs, nmbd, nmblookup, rpcclient, smbcacls, smbclient,
smbcontrol, smbd, smbpasswd, smbspool, smbstatus, swat, testparm, testprns, wbinfo y winbindd.
Descripciones
make_smbcodepage
make_smbcodepage convierte descripciones de texto de páginas de código en ficheros binarios de páginas de código y viceversa.
make_unicodemap
make_unicodemap convierte ficheros de mapa de texto Unicode a binario, para utilizarlo en el mapeado de caracteres a Unicode de 16 bits.
mount.smbfs
mount.smbfs proporciona a /bin/mount una forma de montar unidades compartidas windows (o samba).
nmbd
nmblookup
rpcclient
rpcclient se usa para ejecutar las funciones MS−RPC del lado cliente.
smbcacls
smbclient
smbcontrol
smbcontrol se usa para controlar la ejecución de los demonios smbd, nmbd y winbindd.
smbd
smbpasswd
smbspool
smbstatus
swat
testparm
testprns
wbinfo
winbindd
xinetd−2.3.12
Introducción a xinetd
xinetd es el eXtended InterNET services Daemon (Demonio extendido de servicios de Internet), un sustituto seguro para inetd.
Instalación de xinetd
smbcacls 204
Más Allá de Linux From Scratch
Configuración de xinetd
Ficheros de configuración
/etc/xinetd.conf
cp /etc/xinetd.conf /etc/xinetd.conf.bak
Asegura que las ruta para todos los demonios sean /usr/sbin, en lugar de la ruta por defecto /usr/etc:
El formato de /etc/xinetd.conf está documentado en la página de manual de xinetd.conf. Puedes encontrar mas información en
http://www.xinetd.org.
/etc/rc.d/init.d/xinetd start
La comprobación del fichero /var/log/daemon.log puede resultar entretenida. Este fichero puede contener entradas similares a las siguientes:
Estos errores se deben al hecho de que no tenemos instalados todavía muchos de los servidores que xinetd intenta controlar.
Contenido
Descripciones
xinetd
itox
itox es una utilidad usada para convertir ficheros inetd.conf al formato xinetd.conf.
xconv.pl
xconv.pl es un guión de Perl usado para convertir ficheros inetd.conf al formato xinetd.conf, similar a itox.
Contenido 206
VII. Servidores de Contenidos
Índice
24. Bases de Datos
25. Servir la Web
Berkeley DB−4.1.25
Introducción a Berkeley DB
El paquete Berkeley DB contiene programas y utilidades usadas por muchos otros programas para funciones relacionadas con bases de datos.
Instalación de Berkeley DB
cd build_unix &&
../dist/configure −−prefix=/usr \
−−enable−compat185 \
−−enable−cxx &&
make &&
make docdir=/usr/share/doc/db−4.1.25 install
Nota: Si deseas activar soporte Java en Berkeley DB−4.1.25, añade −−enable−java a las opciones de configure. Necesitas el
soporte Java si piensas utilizar la versión instalada de Berkeley DB para compilar OpenOffice.
cd build_unix && ../dist/configure −−prefix=/usr −−enable−compat185 : Esto reemplaza el comando ./configure normal, pues Berkeley DB
incluye varios directorios de construcción para diferentes plataformas.
Configuración de Berkeley DB
Si recompilas Perl despues de instalar Berkeley DB−4.1.25 necesitarás aplicar el parche perl−5.8.0−db−4.1.patch disponible en
http://downloads.linuxfromscratch.org/blfs−patches.
Contenido
El paquete Berkeley DB contiene db_archive, db_checkpoint, db_deadlock, db_dump, db_load, db_printlog, db_recover, db_stat, db_upgrade y
db_verify.
Descripciones
db_archive
db_checkpoint
db_deadlock
db_dump
db_dump convierte ficheros de bases de datos a un formato de fichero "plano" legible por db_load.
db_load
db_load se usa para crear ficheros de bases de datos a partir de ficheros "planos" creados con db_dump.
db_printlog
db_printlog convierte ficheros de registro de bases de datos a texto legible por humanos.
db_recover
db_recover se usa para restaurar una base de datos a un estado consistente despues de un fallo.
db_stat
db_upgrade
db_upgrade se usa para actualizar ficheros de bases de datos a una nueva versión de Berkeley DB.
db_verify
Berkeley DB−3.3.11
Introducción a Berkeley DB−3.3.11
Instalación de Berkeley DB
cd build_unix &&
../dist/configure −−prefix=/opt/db−3.3 −−enable−compat185 &&
make &&
make docdir=/opt/db−3.3/doc/Berkeley−DB install &&
cd /opt/db−3.3/lib/ &&
rm −f libdb.so &&
for i in $(ls); do mv $i /usr/lib; ln −sf /usr/lib/$i; done &&
cd /opt/db−3.3/include/ &&
sed 's/^DB185/DB/' db_185.h > db_185.h.new &&
mv db_185.h.new db_185.h &&
ln −nsf /opt/db−3.3/include /usr/include/db3
sed 's/^DB185/DB/' /usr/include/db_185.h > /usr/include/db_185.h.new : Cambia el puntero de la base de datos de DB185 a DB.
Contenido
El paquete Berkeley DB contiene db_archive, db_checkpoint, db_deadlock, db_dump, db_load, db_printlog, db_recover, db_stat, db_upgrade y
db_verify.
db_dump 209
Más Allá de Linux From Scratch
Descripciones
db_archive
db_checkpoint
db_deadlock
db_dump
db_dump convierte ficheros de bases de datos a un formato de fichero "plano" legible por db_load.
db_load
db_load se usa para crear ficheros de bases de datos a partir de ficheros "planos" creados con db_dump.
db_printlog
db_printlog convierte ficheros de registro de bases de datos a texto legible por humanos.
db_recover
db_recover se usa para restaurar una base de datos a un estado consistente despues de un fallo.
db_stat
db_upgrade
db_upgrade se usa para actualizar ficheros de bases de datos a una nueva versión de Berkeley DB.
db_verify
MySQL−4.0.15a
Introducción a MySQL
MySQL es un servidor de bases de datos SQL ampliamente usado y muy rápido. Es una implementación cliente/servidor que consiste en un demonio
servidor y varios programas y librerías cliente.
Dependencias de MySQL
Opcionales
Instalación de MySQL
Por razones de seguridad, ejecutar el servidor con un usuario y grupo sin privilegios es súmamente recomendable:
Descripciones 210
Más Allá de Linux From Scratch
sed −e "s%mysql−test/Makefile%%" −e "s% mysql−test%%" configure.old > configure : Este sed se usa para desactivar el conjunto de pruebas
de mysql.
Configuración de MySQL
Ficheros de configuración
/etc/my.cnf, ~/.my.cnf
Tienes varios ficheros con configuraciones predefinidas en /usr/share/mysql que puedes usar.
cp /usr/share/mysql/my−medium.cnf /etc/my.cnf
Ahora podemos crear una base de datos y cambiar el propietario al usuario y grupo sin privilegios.
mysql_install_db
chown −R mysql:mysql /var/lib/mysql
La instalación por defecto no establece una contraseña para el administrador, así que nos conectaremos y le pondremos una. Sugerimos
encarecidamente que cambies 'nueva−contraseña' por la tuya propia.
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql> EXIT;
bye
Para automatizar la ejecución de MySQL, usa los siguientes comandos para crear el guión init.d:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando el demonio MySQL..."
/usr/bin/mysqld_safe −−user=mysql 2>&1 >/dev/null &
evaluate_retval
;;
stop)
echo "Parando el demonio MySQL..."
killproc mysqld
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc /usr/sbin/mysqld
;;
*)
echo "Uso: $0 {start|stop|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/
EOF
chmod 755 /etc/rc.d/init.d/mysql
Crea los enlaces simbólicos a este fichero en los directorios rc.d adecuados con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/mysql ../rc0.d/K26mysql &&
ln −sf ../init.d/mysql ../rc1.d/K26mysql &&
ln −sf ../init.d/mysql ../rc2.d/K26mysql &&
ln −sf ../init.d/mysql ../rc3.d/S34mysql &&
ln −sf ../init.d/mysql ../rc4.d/S34mysql &&
ln −sf ../init.d/mysql ../rc5.d/S34mysql &&
ln −sf ../init.d/mysql ../rc6.d/K26mysql
Contenido
El paquete MySQL contiene comp_err, isamchk, isamlog, msql2mysql, my_print_defaults, myisamchk, myisamlog, myisampack,
mysql, mysql_config, mysql_convert_table_format, mysql_explain_log, mysql_find_rows, mysql_fix_extensions,
mysql_fix_privilege_tables, mysql_install, mysql_install_db, mysql_secure_installation, mysql_setpermission, mysql_tableinfo,
mysql_waitpid, mysql_zap, mysqlacess,mysqladmin, mysqlbinlog, mysqlbug, mysqlcheck, mysqld, mysqld_multi, mysqld_safe,
mysqldump, mysqldumpslow, mysqlhotcopy, mysqlimport, mysqlmanager−pwgen, mysqlmanagerc, mysqlshow, mysqltest,
pack_isam, perror, replace, resolve_stack_dump, resolveip, libdbug, libheap, libmerge, libmyisam, libmyisammrg,
libmysqlclient, libmystrings, libmysys, libnisam y libvio.
Descripción
Un listado del paquete sería demasiado largo. Sugerimos, en su lugar, consultar los detalles completos en la documentación de MySQL.
Ciertos programas de soporte de MySQL pueden necesitar que instales los módulos DBI de Perl para funcionar correctamente.
PostgreSQL−7.3.4
Introducción a PostgreSQL
PostgreSQL es un sistema avanzado de administración de bases de datos objeto−relacionales (ORDBMS) derivado del sistema de administración de
bases de datos Postgres de Berkeley
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp8.us.postgresql.org/pub/pgsql/source/v7.3.4/postgresql−7.3.4.tar.gz
• Tamaño del paquete: 11 MB
Contenido 212
Más Allá de Linux From Scratch
Dependencias de PostgreSQL
Opcionales
Instalación de PostgreSQL
useradd −d /var/pgsql/data postgres : Crea un usuario sin privilegios para lanzar el servidor de bases de datos. Ejecutar el servidor como root es
peligroso, y por otro lado, simplemente no funcionará.
su − postgres −c '/usr/bin/initdb −D /var/pgsql/data' : Inicializa el espacio de tablas de las bases de datos. Este comando no debe ejecutarse como
root.
su − postgres −c '/usr/bin/postmaster −D /var/pgsql/data > /var/pgsql/data/logfile 2>&1 &' : Inicia el servidor de bases de datos. Este comando
debe ejecutarse también por el usuario postgres.
createdb test, create table t1 , insert into t1 values..., select * from t1 : Crea una base de datos, le añade una tabla, inserta varias filas en la tabla y las
selecciona para comprobar que la instalación funciona correctamente.
Configuración de PostgreSQL
Ficheros de configuración
La variable de entorno PGDATA se usa para distinguir un grupo de bases de datos de otro al establecer su valor al directorio que contiene el grupo
deseado. Los tres ficheros de configuración se encuentran en cada directorio PGDATA/. Los detalles sobre el formato de los ficheros y las opciones que
pueden usarse se encuentran en file:///usr/share/doc/postgresql/html/index.html.
# Inicio de $rc_base/init.d/postgresql
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando el demonio PostgreSQL..."
su − postgres −c '/usr/bin/pg_ctl start −W −D /var/pgsql/data \
−l /var/pgsql/data/logfile −o "−i" '
evaluate_retval
;;
stop)
echo "Parando el demonio PostgreSQL..."
/usr/bin/pg_ctl stop −m smart −D /var/pgsql/data
evaluate_retval
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
/usr/bin/pg_ctl status −D /var/pgsql/data
;;
*)
echo "Uso: $0 {start|stop|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/
EOF
chmod 755 /etc/rc.d/init.d/postgresql
Crea los enlaces simbólicos a este fichero en los directorios pertinentes de rc.d con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/postgresql ../rc0.d/K26postgresql &&
ln −sf ../init.d/postgresql ../rc1.d/K26postgresql &&
ln −sf ../init.d/postgresql ../rc2.d/K26postgresql &&
ln −sf ../init.d/postgresql ../rc3.d/S34postgresql &&
ln −sf ../init.d/postgresql ../rc4.d/S34postgresql &&
ln −sf ../init.d/postgresql ../rc5.d/S34postgresql &&
ln −sf ../init.d/postgresql ../rc6.d/K26postgresql
Contenido
El paquete PostgreSQL contiene clusterdb, createdb, createlang, createuser, dropdb, droplang, dropuser, ecpg, initdb, initlocation, ipcclean,
pg_config, pg_controldata, pg_ctl, pg_dump, pg_dumpall, pg_encoding, pg_id, pg_resetxlog, pg_restore, postgres, postmaster, psql,
vacuumdb, libecpg, libpq y varios módulos de conjuntos de caracteres (charsets).
Descripciones
clusterdb
clusterdb es una utilidad para reordenar las tablas de una base de datos PostgreSQL.
createdb
createlang
Contenido 214
Más Allá de Linux From Scratch
createuser
dropdb
droplang
dropuser
ecpg
initdb
initlocation
ipcclean
ipcclean elimina la memoria compartida y los semáforos dejados por un servidor de bases de datos abortado.
pg_config
pg_controldata
pg_controldata devuelve información inicializada por initdb, como la versión del catálogo y el locale del servidor.
pg_ctl
pg_dump
pg_dump vuelca los datos y metadatos de una base de datos en guiones que son usados para regenerar la base de datos.
pg_dumpall
pg_resetxlog
pg_resetxlog borra el fichero de registro y opcionalmente pone a cero algunos campos del fichero pg_control.
pg_restore
pg_restore crea bases de datos a partir de los ficheros de volcado creados por pg_dump.
postgres
postmaster
createuser 215
Más Allá de Linux From Scratch
psql
vacuumdb
psql 216
Capítulo 25. Servir la Web
Este capítulo incluye aplicaciones que responden a peticiones originadas en Internet. Específicamente cubre las peticiones HTTP y las peticiones FTP.
Apache−2.0.47
Introducción a Apache
El paquete Apache contiene un servidor HTTP de código abierto. Es útil para crear sitios web en la intranet local o sirviendo enormes operaciones web.
Descarga adicional
Dependencias de Apache
Opcionales
Instalación de Apache
Por cuestiones de seguridad, se recomienda encarecídamente ejecutar el servidor con usuario y grupo sin privilegios.
El siguiente parche definirá la estructura de los directorios de destino y, entre ellos, el directorio de construcción en /usr/lib/apache/build.
Esto permitirá que los módulos añadidos a Apache sean configurados sin errores. Aplica el parche:
./configure −−enable−layout=LFS \
−−enable−mods−shared=all &&
make &&
make install &&
chown root:root /usr/sbin/{apxs,apachectl,dbmmanage,envvars−std,envvars} &&
chown −R root:root /usr/{include,lib}/apache &&
chown −R root:root /var/www &&
chown −R root:root /usr/share/man
−−enable−mods−shared=all: Queremos que los módulos se compilen y usen como Objetos Dinámicos Compartidos (DSOs) para que se puedan
incluir y excluir del servidor usando directivas de configuración en tiempo de ejecución.
Configuración de Apache
Ficheros de configuración
/etc/apache/*
El fichero principal de configuración se llama httpd.conf. Modifícalo para ejecutar el servidor como un usuario dedicado:
Mira en http://httpd.apache.org/docs−2.0/configuring.html las instrucciones detalladas para personalizar tu servidor HTTP Apache.
Para automatizar la ejecución de Apache, utiliza el siguiente comando para crear el guión de init.d:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando el demonio Apache..."
/usr/sbin/apachectl −k start
evaluate_retval
;;
stop)
echo "Parando el demonio Apache..."
/usr/sbin/apachectl −k stop
evaluate_retval
;;
restart)
echo "Reiniciando el demonio Apache..."
/usr/sbin/apachectl −k restart
evaluate_retval
;;
status)
statusproc /usr/sbin/httpd
;;
*)
echo "Uso: $0 {start|stop|restart|status}"
exit 1
;;
esac
EOF
chmod 755 /etc/rc.d/init.d/apache
Crea los enlaces simbólicos a este fichero en los directorios apropiados de rc.d con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/apache ../rc0.d/K28apache &&
ln −sf ../init.d/apache ../rc1.d/K28apache &&
ln −sf ../init.d/apache ../rc2.d/K28apache &&
ln −sf ../init.d/apache ../rc3.d/S32apache &&
ln −sf ../init.d/apache ../rc4.d/S32apache &&
ln −sf ../init.d/apache ../rc5.d/S32apache &&
ln −sf ../init.d/apache ../rc6.d/K28apache
Contenido
El paquete Apache contiene ab, apachectl, apr−config, apu−config, apxs, checkgid, dbmmanage, htdbm, htdigest, htpasswd, httpd, instdso.sh,
logresolve, rotatelogs, libapr, libaprutil y varios módulos.
Descripciones
ab
apachectl
apachectl es una interfaz para el servidor HTTP Apache diseñada para facilitar al administrador el control del funcionamiento del demonio httpd de
Apache.
apxs
apxs es una herramienta para construir e instalar módulos de extensión para el servidor HTTP Apache.
dbmmanage
dbmmanage se usa para crear y actualizar los ficheros de formato DBM usados para guardar usuarios y contraseñas para autenticación básica de
usuarios HTTP.
Contenido 218
Más Allá de Linux From Scratch
htdigest
htdigest se usa para crear y actualizar los ficheros planos usados para guardar usuarios, reino y contraseña para la autenticación resumida de usuarios
HTTP.
htpasswd
htpasswd se usa para crear y almacenar los ficheros planos usados para guardar los usuarios y contraseñas para la autenticación básica de usuarios
HTTP.
httpd
instdso.sh
logresolve
logresolve es un programa para resolver direcciones IP en los ficheros de registro de acceso de Apache.
rotatelogs
rotatelogs es un programa simple para usar junto con la característica de fichero de registro por tuberia de Apache.
PHP−4.3.3
Introducción a PHP
PHP es el Preprocesador de Hipertexto PHP. Usado principalmente en sitios web dinámicos, permite que el código de programación se incluya
directamente en el código HTML.
Dependencias de PHP
Requeridas
OpenSSL−0.9.7c, bc−1.06, cURL−7.10.7, Berkeley DB−4.1.25, libjpeg−6b, libpng−1.2.5, FreeType−2.1.5, MySQL−4.0.15a y Apache−2.0.47
Opcionales
Instalación de PHP
Nota: PHP tiene muchas opciones de configuración que activarán el soporte para ciertas cosas. Puedes usar ./configure −−help
para ver una lista completa de las opciones disponibles. Así mismo, es muy recomendable usar el sitio web de PHP, pues su
documentación en línea es muy buena.
htdigest 219
Más Allá de Linux From Scratch
Configuración de PHP
Ficheros de configuración
/etc/php.ini, /etc/pear.conf
Para activar el soporte de PHP en el servidor web Apache, debes añadir una nueva directiva AddType en el fichero httpd.conf:
Igualmente, puede ser útil añadir una entrada para index.php en la directiva DirectoryIndex del fichero httpd.conf.
ProFTPD−1.2.8p
Introducción a ProFTPD
El paquete ProFTPD contiene un demonio FTP seguro y altamente configurable. Sirve para proporcionar acceso a grandes cantidades de ficheros en
una red.
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.proftpd.org/distrib/source/proftpd−1.2.8p.tar.bz2
• Tamaño del paquete: 729 KB
• Estimación del espacio necesario en disco: 6.3 MB
• Tiempo estimado de construcción: 0.26 SBU
Dependencias de ProFTPD
Opcional
Linux−PAM−0.77
Instalación de ProFTPD
Por razones de seguridad, se recomienda ejecutar ProFTPD con usuario y grupo sin privilegios.
install_user=proftpd install_group=proftpd \
./configure −−prefix=/usr −−sysconfdir=/etc \
−−localstatedir=/var &&
make &&
make install
−−sysconfigdir=/etc : Esta opción evita que los ficheros de configuración se copien en /usr/etc.
−−localstatedir=/var : Esto hace que se utilice /var en vez de /usr/var para los ficheros de bloqueo (lock) y registro.
Configuración de ProFTPD
Ficheros de configuración
/etc/proftpd.conf
Esta es un ejemplo de configuración simple que sólo permite descargas. Revisa la documentación de ProFTPD en /usr/share/doc/proftpd y
consulta su página en Internet http://www.proftpd.net/ para ver más ejemplos de configuración.
# Una configuración básica con acceso anónimo, sin directorios para subir ficheros.
<Anonymous ~proftpd>
User proftpd
Group proftpd
# Queremos que los clientes puedan acceder como usuario "anonymous" o "proftpd"
UserAlias anonymous proftpd
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando el servidor FTP..."
loadproc /usr/sbin/proftpd
;;
stop)
echo "Deteniendo el servidor FTP..."
killproc /usr/sbin/proftpd
;;
reload)
echo "Recargando el servidor FTP..."
reloadproc /usr/sbin/proftpd
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc /usr/sbin/proftpd
;;
*)
echo "Uso: $0 {start|stop|reload|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/proftpd
EOF
chmod 755 /etc/rc.d/init.d/proftpd
Crea los enlaces simbólicos a este fichero en los directorios rc.d adecuados con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/proftpd ../rc0.d/K50proftpd &&
ln −sf ../init.d/proftpd ../rc1.d/K50proftpd &&
ln −sf ../init.d/proftpd ../rc2.d/K50proftpd &&
ln −sf ../init.d/proftpd ../rc3.d/S50proftpd &&
ln −sf ../init.d/proftpd ../rc4.d/S50proftpd &&
ln −sf ../init.d/proftpd ../rc5.d/S50proftpd &&
ln −sf ../init.d/proftpd ../rc6.d/K50proftpd
Contenidos
Descripciones
ftpcount
ftpshut
ftptop
ftpwho
ftpwho muestra información sobre los procesos actuales para cada sesión.
proftpd
Contenidos 222
VIII. X + Administradores de Ventanas
Índice
26. Entorno X Window
27. Librerías X
28. Administradores de Ventanas
XFree86−4.3.0.1
Introducción a XFree86
XFree86 es una implementación en código abierto y de libre distribución del Sistema de Ventanas X. XFree86 proporciona una interfaz cliente/servidor
entre el hardware (ratón, teclado y vídeo) y el entorno de escritorio, mientras que también proporciona la infraestructura para la creación de ventanas y
una interfaz de aplicaciones estandarizada (API).
Dependencias de XFree86
Requerida
libpng−1.2.5.
Recomendadas
Los siguientes paquetes se incluyen en la distribución de XFree86, sin embargo, se actualizan más seguido que el paquete XFree86 y son muy
recomendables: expat−1.95.6, FreeType−2.1.5 y Fontconfig−2.2.1
Nota: Si eliges no instalar estos paquetes separados, deberás modificar el fichero host.def para hacer que se construyan junto
con XFree86.
• X430src−1.tgz
• X430src−2.tgz
• X430src−3.tgz
• X430src−4.tgz
• X430src−5.tgz
• X430src−6.tgz
• X430src−7.tgz
Los tres primeros paquetes son los programas de XFreee86, el cuarto y el quinto son fuentes, el sexto es la documentación normal y el séptimo es la
documentación lista para consultar. También hay otros dos paquetes, doctools−1.3.1.tgz que contiene programas para regenerar la
documentación y utils−1.1.0.tgz que contiene GNU TAR y zlib que ya están instalados en un sistema LFS.
Para comprobar la integridad de los paquetes, descarga el fichero SUMS.md5sum. Luego haz:
md5sum −c SUMS.md5sum
Las únicas diferencias que deberías ver son los ficheros README, doctools−1.3.1.tgz y utils−1.1.0.tgz si no los descargaste.
El subdirectorio fixes también tiene un SUMS.md5sum. Advierte que tiene el mismo nombre que el de las fuentes principales, por lo que debes
renombrarlo si lo descargas. De todas formas, puedes simplemente examinarlo y usarlo para comprobar el parche:
md5sum 4.3.0−4.3.0.1.diff.gz
Tras desempaquetar los ficheros X430src−?.tgz y descomprimir el fichero diff, cambia al directorio xc y ejecuta:
Instalación de XFree86
Si tienes un Intel P6 (Pentium Pro, Pentium II y superiores) es recomendable que compiles el soporte MTRR (Registros del Rango del Tipo de
Memoria) dentro del núcleo. El núcleo puede mapear CPUs Cyrix y AMD en la interfaz MTRR, por lo que seleccionar esta opción también es útil para
estos procesadores. Esta opción se encuentra en el menú "Processor type and features" ("Tipo de procesador y características"). Puede incrementar las
prestaciones de las operaciones de escritura de imágenes 2.5 veces o más en tarjetas de vídeo PCI o AGP.
En la sección "Character Devices" ("Dispositivos de Caracteres"), activa el soporte para AGP y selecciona el soporte del chipset de tu placa base. Si no
conoces el chipset puedes seleccionar todos los tipos a expensas de un tamaño mayor del núcleo. Normalmente puedes determinar el chipset de tu placa
base mediante:
cat /proc/pci
En la sección "Character Devices", desactiva Direct Rendering Manager ("Administrador de Representación Directa") a menos que tengas una tarjeta
de vídeo con soporte para Direct Rendering Infrastructure (DRI, Infraestructura de representación Directa). Encontrarás una lista completa de las
tarjetas de vídeo con soporte DRI en la sección Status de http://dri.sourceforge.net. Por el momento, entre las tarjetas soportadas se incluyen las de 3dfx
(Voodoo, Banshee), 3Dlabs, ATI (Rage Pro, Rage 128, Radeon 7X00, Radeon 2), Intel (i810, i815) y Matrox (G200, G400, G450). Adicionalmente,
NVidia provee sus propios controladores binarios de código cerrado (propietarios). Si activas DRI aquí, asegúrate de seleccionar la tarjeta (o tarjetas)
de vídeo para la que quieras soporte como módulo.
Nota: Si construyes XFree86 en un entorno chroot, asegúrate de que la versión del núcleo del sistema base y del sistema destino
es la misma. Esto es especialmente importante si activas el soporte para DRI como módulo, tal y como se ha indicado antes.
Crear host.def
Aunque XFree86 compilará sin un fichero host.def, se recomienda el siguiente fichero para personalizar la instalación. Sitúate dentro del directorio
xc.
Nota: El fichero host.def usa la sintaxis de C, no es un típico fichero de configuración. Si realizas algún cambio, asegúrate de
abrir y cerrar correctamente los caracteres de comentario (/* y */). La mayoría de las entradas en el fichero de ejemplo están
comentadas y muestran los valores por defecto.
/* Si estás seguro de que sólo quieres los controladores para una o unas pocas
/*
#define DefaultFontPath $(FONTDIR)/misc/,$(FONTDIR)/75dpi/,\
$(FONTDIR)/100dpi/,$(FONTDIR)/Type1,$(FONTDIR)/local,\
$(FONTDIR)/TrueType,$(FONTDIR)/CID,$(FONTDIR)/Speedo
*/
/* #define BuildCyrillicFonts NO */
/* #define BuildArabicFonts NO */
/* #define BuildISO8859_6Fonts NO */
/* #define BuildGreekFonts NO */
/* #define BuildISO8859_7Fonts NO */
/* #define BuildHebrewFonts NO */
/* #define BuildISO8859_8Fonts NO */
/* #define BuildKOI8_RFonts NO */
/* #define BuildJapaneseFonts NO */
/* #define BuildJISX0201Fonts NO */
/* #define BuildKoreanFonts NO */
/* #define BuildChineseFonts NO */
EOF
Edita el fichero según tu hardware y preferencias.
Comandos de construcción
Si tienes una tarjeta de vídeo con soporte DRI y activaste los módulos DRI del núcleo como se explica más arriba, necesitas actualizar los módulos del
núcleo para asegurarte que sean compatibles con la versión actual de XFree86. Para esto, haz lo siguiente:
cd programs/Xserver/hw/xfree86/os−support/linux/drm/kernel &&
make CC=/opt/gcc−2.95.3/bin/gcc −f Makefile.linux &&
mkdir −p /lib/modules/`uname −r`/kernel/drivers/char/drm/ &&
cp gamma.o radeon.o sis.o r128.o i810.o i830.o mga.o tdfx.o \
/lib/modules/`uname −r`/kernel/drivers/char/drm/ &&
depmod −a
Aviso
Si recompilas o actualizas el núcleo, deberás volver a copiar los módulos controladores a la librería de módulos del núcleo y ejecutar depmod.
Nota: Si construiste el soporte AGP como módulo al compilar el núcleo, quizás quieras añadir una línea al fichero
/etc/modules.conf para asegurarte que se cargue el módulo agpgart. Por ejemplo, la versión AGP de la tarjeta de vídeo
Radeon utilizará el controlador radeon.o. Este necesitará tener la línea
WORLDOPTS="" make World 2>&1 | tee xfree−compile.log: Este comando ejecuta múltiples makefiles para reconstruir por completo el sistema.
WORLDOPTS="" desactiva el comportamiento por defecto de continuar si se produce un error. 2>&1 redirige los mensajes de error a la misma
localización que la salida normal. El comando tee permite visualizar la salida mientras se registran los resultados en un fichero.
Nota: Para reconstruir XFree86, un comando aparte que se puede usar, si sólo se han hecho cambios menores en las fuentes, es
make Everything. Este no elimina automáticamente los ficheros generados y sólo reconstruye aquellos ficheros o programas
que están anticuados.
ln −sf /usr/X11R6/bin /usr/bin/X11, ln −sf /usr/X11R6/lib/X11 /usr/lib/X11 y ln −sf /usr/X11R6/include/X11 /usr/include/X11 : Estos comandos
están presentes para permitir que otros paquetes (incorrectos) se construyan contra XFree86. Hacemos esto aunque el Estándar de la Jerarquía del
Sistema de Ficheros (FHS) dice: "En general, el software no debe instalarse o administrarse mediante los enlaces simbólicos anteriores. Están pensados
para que solamente los utilicen los usuarios."
make CC=/opt/gcc−2.95.3/bin/gcc −f Makefile.linux: Esto construye los módulos del núcleo compatibles con XFree86 usando el mismo compilador
que se usó para compilar el núcleo.
cp gamma.o radeon.o sis.o r128.o i810.o i830.o mga.o tdfx.o /lib/modules/`uname −r`/kernel/drivers/char/drm/: Pone los módulos del núcleo
donde este pueda encontrarlos. Sólo necesitas copiar el módulo correspondiente a tu tarjeta de vídeo.
Configuración de XFree86
ldconfig
Añade /usr/X11R6/bin a tu variable de entorno PATH en .bash_profile. La sentencia debe ser similar a PATH=$PATH:/usr/X11R6/bin y
debe colocarse antes de la sentencia export PATH.
Ejecuta
source ~/.bash_profile
Activa tu ratón
cd /dev
ln −s psaux mouse
Ajusta el enlace simbólico de la forma necesaria para otros tipos de ratón. Por ejemplo, un ratón serie en el primer puerto serie debe enlazarse a ttyS0.
cd ~
XFree86 −configure
La pantalla se pondrá negra y puede que oigas algunos clics del monitor. Este comando creará un fichero, XF86Config.new, en tu directorio
personal.
Edita XF86Config.new para afinar tu sistema. Los detalles del fichero se encuentran en la página de manual, man XF86Config. Algunas cosas que
puedes querer hacer:
• Sección "Files". Cambiar el orden de búsqueda de las rutas de fuentes. Puede que quieras poner las fuentes de 100dpi delante de las fuentes
de 75dpi si tu sistema normalmente se aproxima a los 100 puntos por pulgada. Puede que quieras eliminar algunos directorios de fuentes por
completo.
• Sección "Monitor". Especifica los valores VertRefresh y HorizSync si el sistema no detecta automáticamente el monitor y los valores
correspondientes.
• Sección "InputDevice". Puede que quieras cambiar la velocidad de autorrepetición del teclado añadiendo Option "Autorepeat" "250 30".
• Sección "Device". Puedes querer ajustar alguna de las opciones disponibles para tu controlador de vídeo. La descripción de los parámetros
del controlador se encuentra en la página de manual del mismo.
• Sección "Screen". Añade una sentencia DefaultDepth similar a: DefaultDepth 16. En la subsección para tu profundidad por defecto añade
una línea de modos similar a: Modes "1280x1024" "1024x768". El primer modo listado será, normalmente, la resolución de inicio.
Sólo obtendrás un fondo de pantalla gris con un puntero de ratón en forma de X, pero esto confirma que el sistema funciona. Ciérralo con
Control−Alt−Retroceso. Si el sistema no funciona, revisa /var/log/XFree86.0.log para ver qué ha ido mal.
mv ~/XF86Config.new /etc/X11/XF86Config
Crea .xinitrc
Esto proporciona una pantalla inicial con una xterm y un reloj, manejados por un administrador de ventanas simple, el Tab Window Manager. Para los
detalles sobre twm, mira su página de manual.
startx
Contenido
El paquete XFree86 contiene el Sistema de Ventanas X para Linux (y otros sistemas operativos). Incluye el servidor X, fuentes, xterm, un
administrador de ventanas simple (twm), varias utilidades, controladores de salida de vídeo y varios controladores de entrada incluidos el ratón y el
teclado.
XFree86 también contiene librerías y ficheros de cabecera para el desarrollo de programas para las X.
Contenido 228
Más Allá de Linux From Scratch
Descripciones
Nota: La siguiente lista de programas no está completa. La lista completa está en /usr/X11R6/bin. Para información
adicional sobre estos programas mira en las respectivas páginas de manual.
XFree86
xf86config
xf86config es un programa interactivo para generar un fichero XF86Config para su uso con los servidores X de XFree86.
xf86cfg
xf86cfg es una herramienta para configurar XFree86 que puede usarse tanto para escribir el fichero de configuración inicial, como para personalizar la
configuración actual.
startx
xinit
twm
xterm
xwininfo
x11perf
xlsfonts
xvidtune
xload
xcalc
xclock y oclock
Relojes para X.
xmodmap
xmodmap es una utilidad para modificar los mapas del teclado y de los botones del ratón en las X.
Componentes de XFree86
Descripciones 229
Más Allá de Linux From Scratch
DRI es un marco de trabajo que permite que los programas accedan a los dispositivos gráficos de una manera eficiente y segura. Se instala por defecto
con XFree86 si tienes una tarjeta de vídeo soportada. Para verificar si DRI se instaló adecuadamente busca en el fichero
/var/log/XFree86.0.log alguna sentencia como esta:
También puedes ejecutar el programa glxgears. Este programa muestra una ventana con tres engranajes rodando. En la consola xterm se mostrará la
cantidad de cuadros dibujados cada cinco segundos, siendo este un banco de pruebas razonable. La ventana se puede redimensionar, y la cantidad de
cuadros dibujados depende mucho del tamaño de la misma.
El soporte para fuentes TrueType está incluido en XFree86. Debes seguir los siguientes pasos para disponer de las fuentes.
• Establecer un directorio para las fuentes y mover todas las fuentes TrueType que quieras a ese directorio.
• Crear los ficheros fonts.scale y fonts.dir en el directorio de las fuentes TrueType.
• Asegurarse que el fichero XF86Config cargue el módulo TrueType.
• Asegurarse que FontPath en el fichero XF86Config contiene el directorio de fuentes TrueType.
Al construir XFree86 como se indica arriba, se crea automáticamente un directorio de fuentes TrueType: /usr/X11R6/lib/X11/fonts/TTF.
Este ya contiene algunas fuentes TrueType y está configurado correctamente. Si este directorio te satisface, copia en él todas las fuentes TrueType que
desees. Si no, crea un nuevo directorio, preferentemente dentro de /usr/X11R6/lib/X11/fonts/ y pon ahí tus fuentes TrueType.
mkfontscale &&
mkfontdir
Section "Module"
...
Load "freetype"
...
EndSection
Section "Files"
...
FontPath "/usr/X11R6/lib/X11/fonts/[DirectorioTruetype]/"
...
EndSection
Finalmente, para actualizar todos los ficheros de caché de fuentes especificados en /etc/fonts/fonts.conf, ejecuta
fc−cache
Ahora, XFree86 podrá usar las fuentes TrueType en cuanto sea reiniciado. Puedes comprobar que las fuentes están disponibles con el programa
xlsfonts o con xfontsel.
Nota: Deberías volver a ejecutar mkfontscale y mkfontdir cada vez que que agregues o borres fuentes TrueType. Lo mismo
para fc−cache cada vez que agregues o borres cualquier tipo de fuente.
En esta versión de XFree86, se ha informado que los mapas de teclado no latinos no incluyen las configuraciones latinas, como sucedía antes. Para
configurar un teclado que acepte entradas latinas y no latinas, cambia la opción XkbLayout del controlador de teclado en la sección InputDevice del
fichero XF86Config. Por ejemplo:
Section "InputDevice"
Identifier "Keyboard0"
Driver "Keyboard"
Option "XkbModel" "pc105"
Option "XkbLayout" "en_US,ru"
Option "XkbOptions" "grp:switch,grp:alt_shift_toggle,grp_led:scroll"
EndSection
En este ejemplo, puedes usar la combinación Alt−Shift para cambiar entre mapas de teclado y usar el LED de Bloqueo de Desplazamiento (Scroll
Lock) para indicar cuando se encuentra activo el segundo mapa.
Configuración de XDM
xdm proporciona una entrada gráfica al sistema y generalmente se configura en /etc/inittab. Casi toda la información que necesitas para
personalizar xdm la encontrarás en su página de manual. Para ejecutar xdm en el arranque de la máquina, cambia el nivel de ejecución por defecto
(initdefault) al 5 y agrega estas líneas a /etc/inittab:
Hay muchas opciones de XFree86 y de los clientes X que puedes modificar por medio de los recursos. Típicamente, los recursos se configuran en el
fichero ~/.Xresources.
El formato del fichero ~/.Xresources consiste en una lista de especificaciones de la siguiente forma
objeto.subobjeto[.subobjeto...].atributo: valor
Normalmente, los componentes de una especificación de recursos están vinculados por enlaces (bindings), pudiendo ser firmes, representados por un
punto (.), o relajados, representados por un asterisco (*). Un enlace firme indica que los componentes a cada lado del punto deben estar directamente
uno al lado del otro, como se define en una implementación específica. Un asterisco es un caracter comodín que quiere decir que cualquier número de
niveles en una jerarquía definida puede estar entre dichos componentes. Por ejemplo, XFree86 nos ofrece dos nuevos punteros: un reloj rojo (redglass)
y uno blanco (whiteglass). Para usar uno de estos recursos, debes añadir una línea como esta:
Xcursor.theme: whiteglass
Sin embargo, puedes especificar el fondo de pantalla para todos los clientes con:
*background: blue
Las variables de recurso más específicas prevalecen sobre nombres menos específicos.
Encontrarás las definiciones de los recursos en las páginas de manual de cada cliente en particular.
Para cargar los recursos se debe llamar al programa xrdb con los parámetros adecuados. Normalmente, la primera vez que cargues los recursos usarás:
La instrucción xrdb suele ubicarse en ~/.xinitrc o en ~/.xsession. Para obtener más información, consulta la página de manual de xrdb.
FreeType−2.1.5
Introducción a FreeType2
El paquete FreeType2 contiene una librería que permite a XFree86 representar correctamente las fuentes TrueType.
Descarga adicional
Instalación de FreeType2
sed ... include/freetype/config/ftoption.h: Activamos el intérprete de código en bytes de TrueType antes de empezar a construir la librería.
Contenido
Descripción
Librerías FreeType2
Fontconfig−2.2.1
Introducción a Fontconfig
El paquete Fontconfig es una librería para configurar y personalizar el acceso a las fuentes tipográficas.
Nota: El sistema de numeración de Fontconfig es inusual. Las versiones beta del paquete se nombran agregándoles un 9x tras el
número de liberación (release). Esto significa que 2.2.90 es una versión beta y la versión estable más actual se nombra de la
forma 2.2.1
Dependencias de Fontconfig
Requeridas
FreeType−2.1.5 y expat−1.95.6
Instalación de Fontconfig
Configuración de Fontconfig
El fichero de configuración de Fontconfig es /etc/fonts/fonts.conf. Generalmente no querrás editar este fichero. Para agregar un directorio de
fuentes nuevo a la configuración, actualiza el fichero /etc/fonts/local.conf con tu información local. Los directorios de fuentes por defecto
en Fontconfig son:
• /usr/share/fonts
• ~/.fonts
Como aún no hemos construido XFree86, agrega los siguientes directorios al fichero /etc/fonts/local.conf:
• <dir>/usr/X11R6/lib/X11/fonts/TTF</dir>
• <dir>/usr/X11R6/lib/X11/fonts/Type1</dir>
• <dir>/usr/X11R6/lib/X11/fonts/truetype</dir>
El programa Fontconfig buscará automáticamente las fuentes necesarias en dichos directorios y en todos sus subdirectorios.
Nota: Las X también incluyen una versión interna (y vieja) de Fontconfig y, a menos que la desactives explícitamente al
construir XFree86, también se crea esta versión, dejándonos con dos librerías ligeramente incompatibles en el sistema. Se
recomienda que sólo instales una versión.
Contenido
Descripciones
fc−cache
fc−list
Qt−3.2.1
Introducción a Qt
El paquete Qt contiene una librería de interfaz gráfica (GUI) en C++. Es útil para crear o ejecutar aplicaciones gráficas que estén enlazadas
dinámicamente a la librería Qt.
Dependencias de qt
Requeridas
Instalación de Qt
bash
export QTDIR=$PWD &&
export LD_LIBRARY_PATH=$QTDIR/lib &&
export PATH=$QTDIR/bin:$PATH &&
make &&
make install &&
exit
Nota: El tiempo de compilación de Qt es bastante largo. Si quieres ahorrar algo de tiempo y no quieres los tutoriales y ejemplos,
cambia en lo anterior la primera línea de make a:
make sub−tools
bash: Este comando abre un subintérprete de comandos para preservar los cambios del entorno.
export QTDIR=$PWD: Este comando define el lugar en el que se encuentra el directorio raíz de Qt.
export LD_LIBRARY_PATH=$QTDIR/lib: Este comando establece la localización de las librerías para el proceso de construcción.
export PATH=$QTDIR/bin:$PATH: Este comando permite al proceso de construcción encontrar los ejecutables de soporte.
−qt−gif: Este comando añade a las librerías el soporte para ficheros gif.
−system−libpng −system−libmng −system−zlib −system−libjpeg: Este comando fuerza a la librería para que use las librerías compartidas que hay
en tu sistema, en vez de crear su propio grupo de librerías de soporte para estas funciones.
−no−g++−exceptions: Este comando desactiva el código para las excepciones generado por el compilador de C++.
ln −sfn /opt/qt−3.2.1 /opt/qt: Este comando normaliza la localización de las librerías Qt a la entrada en ld.so.conf descrita más abajo.
ln −s /opt/qt/lib/libqt−mt.so /opt/qt/lib/libqt.so: Este comando permite a los guiones configure encontrar una instalación funcional de Qt.
cp −r doc/man /opt/qt/doc: Este comando instala el directorio man, ya que no lo hace make install.
cp −r examples /opt/qt/doc: Este comando instala el directorio examples (ejemplos), ya que no lo hace make install.
exit: Con este comando se regresa al intérprete de comandos original y se eliminan las variables de entorno establecidas anteriormente.
Configuración de Qt
Como muchas librerías, no necesita configuración, salvo que el directorio /opt/qt/lib debe aparecer en /etc/ld.so.conf para que ldd pueda
encontrar las librerías compartidas. El siguiente comando lo añadirá si no aparece:
/opt/qt/lib
Dependencias de qt 234
Más Allá de Linux From Scratch
# Fin de la adición de qt
EOF
ldconfig
Necesitas añadir la ruta a las páginas de manual de Qt en el fichero man.conf. Puedes hacerlo con el siguiente comando:
MANPATH /opt/qt/doc/man
Contenido
Descripción
Librerías Qt
Las librerías QT/X11 contienen las APIs necesarias para usar los programas de KDE.
GTK+−1.2.10
Introducción a GTK+
El paquete GTK+ contiene las librerías GTK+. Son útiles para crear interfaces gráficas de usuario para las aplicaciones.
Dependencias de GTK+
Requeridas
Instalación de GTK+
−−with−xinput=xfree: Esta opción de configuración es necesaria para usar dispositivos de entrada alternativos.
Contenido
Descripción
Librerías GTK+
Las librerías GTK+ proporcionan la API para implementar interfaces gráficas de usuario.
Contenido 235
Más Allá de Linux From Scratch
Pango−1.2.5
Introducción a Pango
El paquete Pango contiene la librería libpango. Es útil para calcular la disposición y representación del texto.
Dependencias de Pango
Requeridas
GLib−2.2.3 y FreeType−2.1.5
Opcionales
Instalación de Pango
Para que Pango encuentre xft2, la variable PKG_CONFIG_PATH debe incluir el directorio /usr/X11R6/lib/pkgconfig. Este es un buen
momento para añadirlo si no lo has hecho ya. Encontrarás instrucciones específicas para modificar esta variable en la sección de configuración de
pkgconfig−0.15.0.
−−sysconfdir=/etc: Esta opción instala los ficheros de configuración en /etc en lugar de en /usr/etc.
Contenido
Descripción
Librerías Pango
Las librerías Pango contienen esquemas de rutinas de procesamiento de bajo nivel, un controlador de alto nivel para esquematizar bloques enteros de
texto y rutinas de asistencia para edición de texto internacionalizado.
ATK−1.2.4
Introducción a ATK
El paquete ATK contiene las librerías ATK, que sirven para poner a disposición de todas las aplicaciones GTK2 las soluciones de accesibilidad.
Pango−1.2.5 236
Más Allá de Linux From Scratch
Dependencias de ATK
Requerida
GLib−2.2.3
Opcionales
Instalación de ATK
Contenido
Descripción
Librerías ATK
Las librerías ATK contienen la API usada por las tecnologías de accesibilidad, que permiten interactuar con el escritorio y los programas.
GTK+−2.2.4
Introducción a GTK+
El paquete GTK+ contiene las librerías GTK+. Son útiles para crear interfaces gráficas de usuario para las aplicaciones.
Dependencias de GTK+
Requeridas
Opcionales
Instalación de GTK+
Contenido
Descripción
Librerías GTK+
Las librerías GTK+ proporcionan la API para implementar interfaces gráficas de usuario.
LessTif−0.93.46
Introducción a LessTif
Dependencias de LessTif
Requeridas
XFree86−4.3.0.1
Instalación de LessTif
./configure −−prefix=/usr \
−−enable−build−20 \
−−enable−build−21 \
−−disable−debug \
−−enable−production \
−−disable−build−tests \
−−with−xdnd &&
make &&
make install
−−enable−build−20: Construye una versión de las librerías LessTif compatible con Motif 2.0.
Configuración de LessTif
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Comprobar LessTif
Se recomienda comprobar la instalación de LessTif con el banco de pruebas que se encuentra en lesstif−0.93.46/test. No es necesario instalar
Contenido 238
Más Allá de Linux From Scratch
ninguno de los binarios resultantes para validar la instalación. Los siguientes comandos, ejecutados desde el directorio de las fuentes, serán suficiente:
cd test &&
./configure &&
make
Contenido
Descripción
Librerías LessTif
Las librerías LessTif son librerías para el Sistema de Ventanas X compatibles a nivel de código fuente con OSF/Motif(R).
startup−notification−0.5
Introducción a startup−notification
El paquete startup−notification contiene las librerías startup−notification. Son útiles para crear una forma consistente de notificar al usuario, a
través del puntero del ratón, que la aplicación se está cargando.
Dependencias de startup−notification
Requerida
XFree86−4.3.0.1
Instalación de startup−notification
Contenido
Descripción
Librerías startup−notification
Las librerías startup−notification proporcionan las funciones necesarias para que las aplicaciones se comuniquen con el sistema del puntero
del ratón y le indiquen al usuario que el programa se está cargando.
Contenido 239
Capítulo 28. Administradores de Ventanas
Los Administradores de Ventanas y los Entornos de Escritorio son las interfaces de usuario primarias en el Sistema de Ventanas X. Un Administrador
de Ventanas es un programa que controla el aspecto de las ventanas y proporciona los métodos mediante los que el usuario puede interactuar con ellas.
Un Entorno de Escritorio suministra una interfaz más completa para el sistema operativo, y proporciona una gama de utilidades y aplicaciones
integradas.
Hay disponibles muchos Administradores de Ventanas. Algunos de los más conocidos son fvwm2, Window Maker, AfterStep, Enlightenment, Sawfish,
y Blackbox.
Los Entornos de Escritorio disponibles para Linux son GNOME, KDE y XFce.
Elegir un Administrador de Ventanas o un Entorno de Escritorio es algo muy subjetivo. La elección depende del aspecto y comportamiento de los
paquetes, los recursos (RAM, espacio en disco) necesarios y las utilidades incluidas. Una página web que muestra un buen resumen de lo que hay
disponible, capturas de pantalla y sus respectivas características es Administradores de Ventanas para X.
En este capítulo encontrarás las instrucciones de instalación para varios Administradores de Ventanas y un Entorno de Escritorio ligero. Más adelante
en el libro, KDE y GNOME tienen sus propios apartados.
sawfish−1.3
Introducción a sawfish
El paquete sawfish contiene un administrador de ventanas. Es útil para organizar y mostrar ventanas, en las que toda la decoración de las mismas es
configurable y toda la política de interfaz de usuario se controla mediante un lenguaje de extensión.
Dependencias de sawfish
Requeridas
Opcional
libglade−2.0.1
Instalación de sawfish
−−with−audiofile: Este comando indica a sawfish que use libaudiofile para manipular el sonido.
−−with−esd: Este comando indica a sawfish que use el Demonio de Sonido Enlightened.
Configuración de sawfish
EOF
Contenido
Descripción
sawfish
sawfish es un administrador de ventanas extensible que usa un lenguaje de guiones basado en Lisp.
Fluxbox−0.1.14
Introducción a Fluxbox
Descarga adicional
Dependencias de Fluxbox
Requerida
XFree86−4.3.0.1
Instalación de Fluxbox
−−enable−kde: Esta opción activa la capacidad de Fluxbox que permite que los íconos de la barra de KDE se coloquen en la rejilla.
−−disable−nls: Esta opción desactiva la capacidad de Fluxbox para soportar lenguajes internacionales. Es un modificador opcional para evitar un
problema de compilación si no instalaste todas las locales.
Configuración de Fluxbox
Ficheros de configuración
Contenido 241
Más Allá de Linux From Scratch
cp /usr/share/fluxbox/menu ~/.fluxbox/menu
Los elementos del menú se añaden editando ~/.fluxbox/menu. La sintaxis se explica en la página de manual de fluxbox.
Contenido
Descripciones
fluxbox
bsetbg
bsetbg es una utilidad que establece la imagen del fondo de pantalla. Necesita display, Esetroot, wmsetbg, xv, qiv o xsri para funcionar.
bsetroot
Metacity−2.4.55
Introducción a Metacity
El paquete Metacity contiene un administrador de ventanas. Es útil para organizar y mostrar las ventanas.
Dependencias de Metacity
Requeridas
Opcionales
startup−notification−0.5 y GConf−2.2.1
Instalación de Metacity
Configuración de Metacity
Contenido
Contenido 242
Más Allá de Linux From Scratch
Descripción
metacity
XFce−4.0.0
Introducción a XFce
Dependencias de XFce
Requeridas
Opcionales
Instalación de XFce
Ahora XFce se distribuye como un fichero TAR con los paquetes base y los de módulos. Estas instrucciones sólo cubren los paquetes mínimos para
poder ejecutar la aplicación. El resto de los módulos siguen el mismo patrón de instalación, que pronto se volverá obvio.
cd src &&
tar −xzvf libxfce4util−4.0.0.tar.gz &&
cd libxfce4util−4.0.0 &&
./configure −−prefix=/usr &&
make &&
make install &&
cd .. &&
tar −xzvf libxfcegui4−4.0.0.tar.gz &&
cd libxfcegui4−4.0.0 &&
./configure −−prefix=/usr &&
make &&
make install &&
cd .. &&
tar −xzvf libxfce4mcs−4.0.0.tar.gz &&
cd libxfce4mcs−4.0.0 &&
./configure −−prefix=/usr −−sysconfdir=/etc &&
make &&
make install &&
cd .. &&
tar −xzvf xfce−mcs−manager−4.0.0.tar.gz &&
cd xfce−mcs−manager−4.0.0 &&
./configure −−prefix=/usr &&
make &&
make install &&
cd .. &&
tar −xzvf xfwm4−4.0.0.tar.gz &&
cd xfwm4r−4.0.0 &&
./configure −−prefix=/usr &&
make &&
make install &&
cd .. &&
tar −xzvf xfdesktop−4.0.0.tar.gz &&
cd xfdesktop−4.0.0 &&
./configure −−prefix=/usr −−sysconfdir=/etc &&
make &&
make install &&
cd .. &&
tar −xzvf xfce4−panel−4.0.0.tar.gz &&
cd xfce4−panel−4.0.0 &&
Descripción 243
Más Allá de Linux From Scratch
Los módulos que no instalamos son: dbh−1.0.15 (requerido por xffm), gtk−xfce−engine−2.1.6, xfce−mcs−plugins, xfce4−iconbox, xfce4−mixer,
xfce4−systray, sxfce4−themes, xfce4−toys, xfce4−trigger−launcher, xffm, xffm−icons, xfprint y xfwm4−themes.
Configuración de XFce
Ficheros de configuración
~/.xinitrc
Contenido
El paquete XFce contiene xfce−mcs−manager, xfce4−about, xfce−setting−show, xfce4−panel, xfdesktop, xfhelp4, xflock4, xfmountdev4, xfrun4,
xfsamba4, xftaskbar4, xfterm4, xftrash4, xftree4, xfwm4 y las librerías libxfce4mcs, libxfce4util y libxfcegui4.
Descripciones
xfce−mce−manager
xfce4−about
xfce−setting−show
xfce4−panel
xfce4−panel es el administrador del panel de XFce. Contiene el lanzador, un reloj, un alerta de correo nuevo, un cambiador de escritorios y un
separador.
xfdesktop
xfhelp4
xfhelp4 es un guión que lanza un paginador HTML que muestra la documentación en línea.
xflock4
xflock4 es un guión que bloquea la pantalla actual durante las operaciones de arrastrar y soltar.
xfmountdev4
xfmountdev4 monta un dispositivo en el punto de montaje especificado y lanza xftree4, luego desmonta el dispositivo cuando xftree4 termina.
xfrun4
xfsamba4
xftaskbar4
xfterm4
xfterm4 es un pequeño envoltorio (wrapper) de terminal para usar como acción de arrastrar y soltar para el panel frontal de XFce.
xftrash4
xftrash4 es un pequeño guión para usar como acción de arrastrar y soltar para el panel frontal de XFce.
xftree4
xfwm4
xfrun4 245
IX. KDE
Dividimos las instrucciones de KDE en dos partes. Primero, los paquetes base que necesitas para que el resto de KDE funcione. En segundo lugar, los
paquetes adicionales que aportan funcionalidad en varias áreas (multimedia, gráficos, etc).
Mientras desarrollábamos las instrucciones de compilación e instalación de KDE, examinamos las opciones para configure, y los parámetros aquí
presentados son, posiblemente, con los que compile más correctamente. En cada uno de los paquetes, otra opción que puede añadirse a configure es
−−enable−final. Esta opción acelera el proceso de compilación, pero requiere mucha memoria. Si tienes menos de 256 MB de RAM, esta opción puede
provocar accesos a la memoria de intercambio (swapping), ralentizando significativamente la compilación.
KDE también tiene muchos paquetes de internacionalización del tipo: kde−i18n−xx−3.1.4.tar.bz2 donde xx son de dos a cinco letras que
indican el código del país correspondiente. No cubrimos aquí la instalación de estos paquetes.
Cada paquete de KDE comprende varios componentes. Por defecto se instalan la mayoría de ellos. Si quieres excluir un componente específico, la
manera oficial de hacerlo es establecer la variable DO_NOT_COMPILE. Esto es de ayuda cuando hay problemas al compilar algún componente en
particular.
DO_NOT_COMPILE="componente1 componente2" \
./configure −−prefix=/opt/kde...
Los paquetes base de KDE también hacen uso de esta variable, pero no se recomienda omitir componentes de dichos paquetes, ya que puede resultar
una instalación de KDE incompleta.
Nota: KDE es un conjunto de paquetes grande y complicado. En ocasiones, los usuarios encontrarán correcciones que no se han
incluido todavía en el KDE oficial. Si tienes un problema con una aplicación concreta, mira los parches que hay en
http://www.linuxfromscratch.org/patches/downloads/kde*. Los parches actuales tendrán el número de
versión, 3.1.4, como parte de su nombre.
Índice
29. Paquetes Base de KDE
30. Paquetes KDE Adicionales
El Sintetizador Analógico en Tiempo Real (aRts) proporciona el soporte de sonido para KDE y suministra las librerías necesarias para kdelibs.
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/arts−1.1.4.tar.bz2
• Tamaño del paquete: 963 KB
• Estimación del espacio necesario en disco: 42.5 MB
• Tiempo estimado de construcción: 2.52 SBU
Dependencias de aRts
Requerida
Qt−3.2.1
Recomendadas
Opcionales
Instalación de aRts
Antes de que empieces a compilar, asegúrate que esté definida la variable de entorno QTDIR:
export QTDIR=/opt/qt
Nota: Otra opción de configure es −−enable−final. Esta opción puede acelerar el proceso de construcción, pero requiere mucha
memoria. Si tienes menos de 256MB de RAM esta opción puede provocar accesos a la memoria de intercambio (swapping) y
ralentizar sustancialmente la compilación.
−−prefix=/opt/kde−3.1.4 : Esta opción le indica al proceso que instale el paquete en /opt/kde−3.1.4. Colocamos aRts aquí debido a que este
paquete es necesario antes de instalar KDE.
−−disable−debug : Esta opción hace que el sistema sea compilado sin símbolos de depuración.
ln −sfn /opt/kde−3.1.4 /opt/kde : Esta opción crea un enlace para acceder a KDE. Si aparece una nueva versión de KDE, el nuevo sistema puede
construirse cambiando la ruta de −−prefix y reajustando a continuación el enlace.
Configuración de aRts
El directorio de librerías /opt/kde/lib debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. El siguiente
comando lo añadirá si no aparece:
/opt/kde/lib
kdelibs−3.1.4
Introducción a kdelibs
Este paquete incluye las librerías principales para el desarrollo y ejecución de programas para KDE, así como también los ficheros de
internacionalización de estas librerías, documentación variada en formato HTML, módulos de temas y pruebas de regresión.
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdelibs−3.1.4.tar.bz2
• Tamaño del paquete: 10 MB
• Estimación del espacio necesario en disco: 193 MB
• Tiempo estimado de construcción: 35.34 SBU
Dependencias de kdelibs
Requeridas
aRts−1.1.4
Recomendadas
Opcionales
Instalación de kdelibs
−−disable−debug : Esta opción hace que el sistema se compile sin código de depuración.
−−with−alsa : Esta opción indica que se busque y se use Alsa como soporte de sonido.
−−enable−fast−malloc=full : Esta opción le indica a los programas de KDE que usen un esquema interno de asignación de memoria optimizado para
KDE.
Contenido
kdebase−3.1.4
Introducción a kdebase
kdebase es el segundo paquete obligatorio (junto con kdelibs) para el Entorno de Escritorio K. Proporciona varias aplicaciones, ficheros de
infraestructura y librerías.
kdelibs−3.1.4 249
Más Allá de Linux From Scratch
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdebase−3.1.4.tar.bz2
• Tamaño del paquete: 14 MB
• Estimación del espacio necesario en disco: 196 MB
• Tiempo estimado de construcción: 28.22 SBU
Dependencias de kdebase
Recomendadas
Opcionales
LAME−3.93.1 y Linux−PAM−0.77
Instalación de kdebase
−−disable−lametest : Ni busca ni incluye el soporte para lame, que proporciona codificación MP3. Omite esta opción si has instalado lame.
Contenido
Programas principales incluidos en kdebase: kdesktop, kaddressbook, kappfinder, kcontrol, kdeprint, kdm, kfind, khelpcenter, khotkeys, kicker,
klipper, kmenuedit, konqueror, konsole, kscreensaver y ktip
Descripciones
kdesktop
kdesktop es el programa que maneja los íconos del escritorio, los menús emergentes y el sistema de salvapantallas.
kaddressbook
kappfinder
kcontrol
kdeprint
kdm
kfind
khelpcenter
khotkeys
kicker
klipper
kmenuedit
konqueror
konsole
kscreensaver
ktip
export PATH=$PATH:/opt/kde/bin
ldconfig
startx
kfind 251
Capítulo 30. Paquetes KDE Adicionales
kdemultimedia−3.1.4
Introducción a kdemultimedia
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdemultimedia−3.1.4.tar.bz2
• Tamaño del paquete: 5.7 MB
• Estimación del espacio necesario en disco: 88 MB
• Tiempo estimado de construcción: 11.47 SBU
Dependencias de kdemultimedia
Requerida
kdebase−3.1.4
Instalación de kdemultimedia
sed −i −e 's/strings −ansi/strings/' kaudiocreator/Makefile : Elimina −ansi de los parámetros de gcc para evitar una cabecera rota del núcleo. El
fichero roto es asm/byteorder.h, donde un parámetro es usado, pero no definido, cuando se especifica −ansi.
sed −i −e 's/strings −ansi/strings/' kioslave/audiocd/Makefile : Elimina −ansi de los parámetros de gcc para evitar una cabecera rota del núcleo.
sed −i −e 's/−ansi//' kscd/libwm/Makefile : Elimina −ansi de los parámetros de gcc para evitar una cabecera rota del núcleo.
Configuración de kdemultimedia
No se necesita ninguna configuración explícita para el paquete kdemultimedia. Sin embargo, Kscd necesita encontrar el dispositivo de CD. Por defecto
es /dev/cdrom, que puede que no exista en tu sistema. La forma más sencilla es crear un enlace simbólico al dispositivo de CD (por ejemplo,
/dev/hdc, /dev/scd0, etc):
cd /dev &&
ln −s "Dispositivo CD" /dev/cdrom
Contenido
El paquete KDE Multimedia incluye kaboodle, noatun, timidity, kmidi, kmix, kscd y aktion.
Descripciones
kaboodle
noatun
timidity
kmidi
kmix
kscd
aktion
kdenetwork−3.1.4
Introducción a kdenetwork
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdenetwork−3.1.4.tar.bz2
• Tamaño del paquete: 4.8 MB
• Estimación del espacio necesario en disco: 86 MB
• Tiempo estimado de construcción: 8.20 SBU
Dependencias de kdenetwork
Requerida
kdebase−3.1.4
Instalación de kdenetwork
Configuración de kdenetwork
No se necesita ninguna configuración explícita para el paquete kdenetwork. Sin embargo, los paquetes individuales necesitan ajustarse con la
información del usuario.
Contenido
El paquete KDE Network incluye kmail, knewsticker, knode, kppp, ksirc, kit y korn.
Descripciones
kmail
knewsticker
timidity 253
Más Allá de Linux From Scratch
knode
kppp
ksirc
kit
korn
kdegraphics−3.1.4
Introducción a kdegraphics
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdegraphics−3.1.4.tar.bz2
• Tamaño del paquete: 4.4 MB
• Estimación del espacio necesario en disco: 49 MB
• Tiempo estimado de construcción: 9.23 SBU
Dependencias de kdegraphics
Requeridas
kdebase−3.1.4 y which−2.14
Opcionales
Imlib−1.9.14 y SANE−1.0.12
Instalación de kdegraphics
Contenido
El paquete KDE Graphics incluye kcoloredit, kdvi, kfax, kfract, kghostview, kiconedit, kooka, kpaint, kruler, ksnapshot, kuickshow y kview.
Descripciones
kcoloredit
kdvi
kfax
knode 254
Más Allá de Linux From Scratch
kfract
kghostview
kiconedit
kooka
kpaint
kruler
ksnapshot
kuickshow
kview
kdepim−3.1.4
Introducción a kdepim
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdepim−3.1.4.tar.bz2
• Tamaño del paquete: 3.1 MB
• Estimación del espacio necesario en disco: 55 MB
• Tiempo estimado de construcción: 7.03 SBU
Dependencias de kdepim
Requerida
kdebase−3.1.4
Opcional
pilot−link
Instalación de kdepim
kfract 255
Más Allá de Linux From Scratch
Contenido
El paquete KDE PIM incluye kalarm, kandy, karm, knotes, korganizer, kpilot y libical.
Descripciones
kalarm
kandy
karm
knotes
korganizer
kpilot
libical
kdeadmin−3.1.4
Introducción a kdeadmin
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdeadmin−3.1.4.tar.bz2
• Tamaño del paquete: 1.5 MB
• Estimación del espacio necesario en disco: 44 MB
• Tiempo estimado de construcción: 2.53 SBU
Dependencias de kdeadmin
Requerida
kdebase−3.1.4
Opcionales
RPM y Linux−PAM−0.77
Instalación de kdeadmin
Contenido 256
Más Allá de Linux From Scratch
Contenido
Descripciones
kpackage
kcron
kuser
kwuftpd
ksysv
kdegames−3.1.4
Introducción a kdegames
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdegames−3.1.4.tar.bz2
• Tamaño del paquete: 8.1 MB
• Estimación del espacio necesario en disco: 92 MB
• Tiempo estimado de construcción: 7.86 SBU
Dependencias de kdegames
Requerida
kdebase−3.1.4
Instalación de kdegames
Contenido
El paquete KDE Games incluye kasteroids, kbounce, kfouleggs, ksirtet, ksmiletris, ksnakerace, kspaceduel, ktron, kbackgammon, kbattleship,
kblakbox, kmahjongg, kreversi, kwin4, kenolaba, shisensho, kpoker, lieutnant, patience, katomic, kjumpingcube, kmines, ksokoban,
kolorlines, konquest y samegame.
kdeutils−3.1.4
Introducción a kdeutils
Contenido 257
Más Allá de Linux From Scratch
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdeutils−3.1.4.tar.bz2
• Tamaño del paquete: 1.3 MB
• Estimación del espacio necesario en disco: 31 MB
• Tiempo estimado de construcción: 3.76 SBU
Dependencias de kdeutils
Requerida
kdebase−3.1.4
Instalación de kdeutils
Contenido
El paquete KDE Utils incluye kcalc, charselectapplet, arc, kdepasswd, kdf, kedit, kfloppy, khexeditor, kjots, kljtool, klpq y ktimer.
Descripciones
kcalc
charselectapplet
arc
kdepasswd
kdf
kedit
kfloppy
khexeditor
kjots
kljtool
klpq
ktimer
kdeedu−3.1.4
Introducción a kdeedu
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdeedu−3.1.4.tar.bz2
• Tamaño del paquete: 19 MB
• Estimación del espacio necesario en disco: 105 MB
• Tiempo estimado de construcción: 4.65 SBU
Dependencias de kdeedu
Requerida
kdebase−3.1.4
Instalación de kdeedu
Contenido
El paquete KDE Edu incluye keduca, kgeo, klettres, kstars, ktouch y kvoctrain.
Descripciones
keduca
kgeo
klettres
kstars
ktouch
kvoctrain
kdeartwork−3.1.4
klpq 259
Más Allá de Linux From Scratch
Introducción a kdeartwork
kdeartwork contiene temas de escritorio, salvapantallas, sonidos, fondos de escritorio y estilos de controles (widgets) adicionales para KDE.
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdeartwork−3.1.4.tar.bz2
• Tamaño del paquete: 13 MB
• Estimación del espacio necesario en disco: 61 MB
• Tiempo estimado de construcción: 1.13 SBU
Dependencias de kdeartwork
Requerida
kdebase−3.1.4
Instalación de kdeartwork
Contenido
Descripción
kscreensaver
kdetoys−3.1.4
Introducción a kdetoys
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdetoys−3.1.4.tar.bz2
• Tamaño del paquete: 1.8 MB
• Estimación del espacio necesario en disco: 18 MB
• Tiempo estimado de construcción: 1.51 SBU
Dependencias de kdetoys
Requerida
kdebase−3.1.4
Instalación de kdetoys
Contenido
El paquete KDE Toys incluye amor, kaphorism, kmoon, kodo, kteatime y ktux.
Descripciones
amor
kaphorism
kaphorism − Aforismos.
kmoon
kodo
kteatime
ktux
kdeaddons−3.1.4
Introducción a kdeaddons
kdeaddons contiene módulos (plugins) y guiones adicionales para algunas aplicaciones de KDE.
• Descarga (HTTP):
• Descarga (FTP): ftp://ftp.kde.org/pub/kde/stable/3.1.4/src/kdeaddons−3.1.4.tar.bz2
• Tamaño del paquete: 1.0 MB
• Estimación del espacio necesario en disco: 26 MB
• Tiempo estimado de construcción: 4.85 SBU
Dependencias de kdeaddons
Recomendadas
kdemultimedia−3.1.4 y kdenetwork−3.1.4
Instalación de kdeaddons
Contenido
El paquete KDE Addons proporciona módulos para konqueror y noatun, subprogramas (applets) para kicker y guiones para knewsticker.
Descripciones 261
X. GNOME
X. GNOME 262
Introducción a GNOME
Este capítulo describe cómo instalar un entorno de escritorio GNOME−2.2 completo y las librerías de GNOME 1.4 necesarias para ejecutar las
aplicaciones de GNOME 1.4 incluídas en este libro. El orden de las páginas está pensado para seguir el orden de construcción definido por el equipo de
desarrollo de GNOME, que se puede ver en las notas de la versión, con dos excepciones. Si un paquete se encuentra en la lista de construcción, pero no
está en este capítulo, es porque ha sido instalado en otra parte del libro.
La instalación de GNOME−2.2 es una árdua tarea y nos gustaría ver que la completas con la menor tensión posible. Uno de nuestros primeros objetivos
en esta instalación es proteger los programas que ya tengas instalados, especialmente si estás probando GNOME en tu máquina. Los paquetes de
GNOME−2.2 usan la opción −−prefix= de configure, así que la usaremos junto a una variable de entorno (GNOME_PREFIX) para que la instalación
sea más flexible.
Si quieres que GNOME sea tu escritorio, te recomendamos que lo instales con −−prefix=/usr. Si no estás seguro de que vayas a quedarte con GNOME,
te recomendamos que lo instales con −−prefix=/opt/gnome−2.2. En la página de preinstalación se explica cómo establecer la variable de entorno y las
modificaciones adicionales que necesita la segunda opción.
Si eliges la segunda opción, eliminar GNOME−2.2 es tan fácil como deshacer las modificaciones de la página de preinstalación y ejecutar el siguiente
comando:
rm /opt/gnome−2.2 −r
Si tu sistema está construido por completo siguiendo las instrucciones del LFS y del BLFS, tienes muchas posibilidades de poder usar GNOME−2.2
después de tu primera instalación. Si eres el típico usuario de LFS y has modificado las instrucciones, debes tener estas modificaciones en cuenta para
futuras instalaciones. No tendrás problemas en integrar GNOME−2.2 en tu propia configuración, pero tendrás instalados de 28 a 33 paquetes antes de
que puedas hacerle alguna prueba a GNOME (asumiendo que tu administrador de ventanas está instalado y comprobado). Podemos anticipar que
reconstruirás GNOME al menos una vez para hacer reajustes a tu configuración.
Si vas a construir un entorno de escritorio GNOME, deberías instalar sólo las librerías del capítulo GNOME 1.4 y todas las dependencias mostradas en
dichas páginas, esten o no etiquetadas. Los paquetes de GNOME sin páginas se instalan simplemente con:
Estas instrucciones están simplificadas para facilitar la eliminación de GNOME 1.4 del sistema BLFS cuando ya no sea necesario. Dichas instrucciones
pueden ser refinadas más adelante para cumplir con los estándares de BLFS en cuanto a la ubicación de los ficheros, específicamente
/opt/gnome/etc por /etc y /opt/gnome/var por /var. Deberías considerar usar la receta de GNOME 1.4, disponible en
http://www.linuxfromscratch.org/hints/ si no tienes interés en GNOME−2.2.
Dependencias de GNOME−2.2:
Requeridas
Opcionales
Índice
31. Librerías GNOME
32. GNOME base
33. Paquetes adicionales de GNOME
34. Otros Paquetes de GNOME
35. Configuración de GNOME
36. Librerías de GNOME 1.4
export GNOME_PREFIX=/usr
export GNOME_PREFIX=/opt/gnome−2.2
export PATH=$PATH:/opt/gnome−2.2/bin
export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/opt/gnome−2.2/lib/pkgconfig
export GNOME_LIBCONFIG_PATH=/usr/lib
/opt/gnome−2.2/lib
MANPATH /opt/gnome−2.2/man
GTK−Doc−1.0
Introducción a GTK−Doc
El paquete GTK−Doc contiene un documentador de código. Es útil para extraer del código los comentarios con un formato especial para crear la
documentación de las API. Este paquete es opcional. Si no se instala, los paquetes no generarán la documentación. Esto no significa que te quedes sin
ninguna documentación. Si GTK−Doc no está disponible, el proceso de instalación copiará en tu sistema la documentación preconstruida.
Dependencias de GTK−Doc
Requeridas
OpenJade−1.3.2, libxslt−1.0.33, DocBook XML DTD−4.2, DocBook SGML DTD−3.1, DocBook SGML DTD−4.2 y DocBook DSSSL
Stylesheets−1.78
Instalación de GTK−Doc
Contenido
Descripción
Todos ellos son guiones de Perl usados por los guiones Makefile para generar la documentación de los paquetes.
linc−1.0.3
Introducción a linc
El paquete linc contiene una librería que facilita la tarea de escribir servidores y clientes de red. Es usada por ORBit para manejar la transmisión y
recepción de mensajes.
Dependencias de linc
Requeridas
GLib−2.2.3 y OpenSSL−0.9.7c
Opcionales
Instalación de linc
−−disable−gtk−doc : Este comando evita que se reconstruya la documentación de las API durante la ejecución de make.
Contenido
Descripción
Librerías liblinc
Las librerías liblinc proporcionan las funciones que se encargan de la iniciación y mantenimiento de la conexión y los detalles de varios transportes
(IPv4, conexiones de dominio UNIX, IPv6 e IrDA).
libIDL−0.8.2
Introducción a libIDL
El paquete libIDL contiene librerías para ficheros de Lenguaje de Definición de Interfaz. Es una especificación para definir interfaces portables.
Contenido 265
Más Allá de Linux From Scratch
Dependencias de libIDL
Requerida
GLib−2.2.3
Instalación de libIDL
Contenido
Descripción
Librerías libIDL
Las librerías libIDL proporcionan funciones para crear y mentener árboles de ficheros IDL (Interface Definition Language, Lenguaje de Definición
de Interfaz) de CORBA.
ORBit2−2.6.2
Introducción a ORBit2
El paquete ORBit2 contiene un Ejecutor de Peticiones de Objetos (Object Request Broker) CORBA de alto rendimiento. Esto permite a los programas
hacer peticiones y recibir respuestas de otros programas.
Dependencias de ORBit2
Requeridas
Instalación de ORBit2
ldconfig &&
./configure −−prefix=$GNOME_PREFIX &&
make &&
make install
Contenido
Descripciones
libORBit−2
libORBitCosNaming
intltool−0.26
Introducción a intltool
El paquete intltool contiene una herramienta de internacionalización. Sirve para extraer cadenas traducibles de ficheros fuente, reunir las cadenas
extraidas con mensajes procedentes de ficheros fuente tradicionales (<directorio de fuentes>/<paquete>/po) y combinar la traducciones
en ficheros XML, .desktop y OAF.
Instalación de intltool
Contenido
Descripciones
intltoolize
intltool−update
intltool−extract
intltool−extract genera ficheros de cabecera que pueden ser leídos con gettext.
intltool−merge
intltool−prepare
intltool−prepare actualiza los ficheros pot y los combina con ficheros de traducción.
intltool−unicodify
Bonobo Activation−2.2.2
Descripciones 267
Más Allá de Linux From Scratch
El paquete Bonobo Activation contiene las librerías libbonobo−activation. Es el nuevo Marco de Activación de Objetos (OAF) para GNOME.
Requerida
ORBit2−2.6.2
Opcionales
−−libexecdir=$GNOME_PREFIX/sbin : Este comando pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−disable−gtk−doc : Este comando evita que se reconstruya la documentación durante la ejecución de make.
Contenido
Descripción
libbonobo−activation
libbonobo−2.2.3
Introducción a libbonobo
El paquete libbonobo contiene las librerías libbonobo. Es un sistema componente y compositor de documentos para GNOME.
Dependencias de libbonobo
Requeridas
Opcionales
Instalación de libbonobo
Contenido
Descripción
Librerías libbonobo
Las librerías libbonobo son un conjunto de interfaces CORBA independientes del lenguaje y del sistema para la creación de componentes
reutilizables y composición de documentos.
GConf−2.2.1
Introducción a GConf
Dependencias de GConf
Requeridas
ORBit2−2.6.2 y GTK+−2.2.4
Opcionales
Instalación de GConf
−−libexecdir=$GNOME_PREFIX/sbin : Este comando pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc. Esta
instalación controla todas las instalaciones futuras de esquemas. Los cambios en la localización, incluida la eliminación de esta opción, deben ser
consistentes.
−−disable−gtk−doc : Este comando evita que se reconstruya la documentación durante la ejecución de make.
Requeridas 269
Más Allá de Linux From Scratch
Contenido
Descripción
Librerías libgconf
Las librerías libgconf suministran las funciones necesarias para mantener la base de datos de configuración.
El paquete GNOME MIME Data contiene el conjunto base de tipos de ficheros y aplicaciones para GNOME.
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripciones
icons
application−registry
mime−info
El paquete GNOME Virtual File System contiene librerías del sistema de ficheros virtual. Es uno de los cimientos para el administrador de ficheros
Nautilus.
Contenido 270
Más Allá de Linux From Scratch
Requeridas
Opcionales
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−disable−gtk−doc : Este comando evita que se reconstruya la documentación durante la ejecución de make.
Contenido
Descripción
Librerías libgnomevfs
libgnome−2.2.3
Introducción a libgnome
Dependencias de libgnome
Requeridas
EsounD−0.2.30, Audio File−0.2.3, ORBit2−2.6.2, GConf−2.2.1, Bonobo Activation−2.2.2 y GNOME Virtual File System−2.2.5
Opcionales
Instalación de libgnome
−−libexecdir=$GNOME_PREFIX/sbin : Esta opción pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
−−sysconfdir=/etc/gnome : Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−disable−gtk−doc : Esta opción evita que se reconstruya la documentación durante la ejecución de make.
Contenido
Descripción
Librerías libgnome
libart_lgpl−2.3.11
Introducción a to libart_lgpl
El paquete libart_lgpl contiene las librerías libart. Son útiles para gráficos 2D de alto rendimiento.
Instalación de libart_lgpl
Contenido
Descripción
Librerías libart_lgpl
libart_lgpl es usado por libgnomecanvas como motor de representación de imágenes con suavizado de bordes.
libglade−2.0.1
Introducción a libglade
El paquete libglade contiene las librerías libglade. Es útil para cargar ficheros de interfaz Glade en un programa en tiempo de ejecución.
Dependencias de libglade
Requeridas
libxml2−2.5.11 y GTK+−2.2.4
Opcionales
Instalación de libglade
−−enable−gtk−doc : Este comando puede ser añadido para reconstruir la documentación en HTML.
Contenido
Descripción
Librerías libglade
Las librerías libglade contienen las funciones necesarias para cargar ficheros de interfaz de Glade.
libgnomecanvas−2.2.1
Introducción a libgnomecanvas
Dependencias de libgnomecanvas
Requerida
libglade−2.0.1
Opcionales
Instalación de libgnomecanvas
−−disable−gtk−doc : Esta opción evitará que se reconstruya la documentación de la API durante la ejecución de make.
Contenido
Descripción
Librerías libgnomecanvas
libbonoboui−2.2.2
Introducción a libbonoboui
Dependencias de libbonoboui
Requeridas
Opcionales
Instalación de libbonoboui
Contenido
Descripción
Librerías libbonoboui
El paquete GNOME Icon Theme contiene un surtido de iconos escalables y no escalables en diferentes tamaños y temas.
Contenido 274
Más Allá de Linux From Scratch
Contenido
libgnomeui−2.2.2
Introducción a libgnomeui
Dependencias de libgnomeui
Requeridas
Opcionales
Instalación de libgnomeui
−−libexecdir=$GNOME_PREFIX/sbin : Esta opción pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
−−disable−gtk−doc : Esta opción evita que se reconstruya la documentación durante la ejecución de make.
Contenido
Descripción
Librerías libgnomeui
libwnck−2.2.2
Introducción a libwnck
Dependencias libwnck
Requeridas
GTK+−2.2.4 y startup−notification−0.5
Instalación de libwnck
Contenido
Descripción
Librerías libwnck
Las librerías libwnck contiene funciones para escribir paginadores y listas de tareas.
GTK Engines−2.2.0
Introducción a GTK Engines
Requeridas
GTK+−2.2.4
Contenido
Descripciones
Librerías engine
Ficheros de temas
Requerida
GTK+−2.2.4
Contenido
GNOME Themes−2.2.2
Introducción a GNOME Themes
Requerida
Contenido
ScrollKeeper−0.3.12
Introducción a ScrollKeeper
El paquete ScrollKeeper contiene un sistema de catalogación de documentos. Sirve para manejar metadatos de documentos y proporciona una API para
ayudar a los navegadores a encontrar, ordenar y buscar en el catálogo de documentos.
Dependencias de ScrollKeeper
Requeridas
Instalación de ScrollKeeper
Configuración de ScrollKeeper
Ficheros de configuración
/etc/scrollkeeper.conf
Los ficheros de configuración establecen en la variable OMF_DIR la localización de todos los directorios omf del sistema. Esto se estableció en el
comando configure, por lo que no es necesario realizar ninguna acción hasta que se cree otro fichero OMF.
Contenido
Descripciones
Librerías scrollkeeper
Las librerías libscrollkeeper suministran la API necesaria para ayudar a los navegadores a interactuar con documentación escrita para usar
ScrollKeeper.
Contenido 278
Más Allá de Linux From Scratch
Son guiones utilizados para realizar la instalación, construcción, captura y actualización de ficheros de tabla de contenidos.
VTE−0.10.29
Introducción a VTE
El paquete VTE contiene una implementación del fichero termcap para los emuladores de terminales.
Dependencias de VTE
Requeridas
Python−2.3.2 y GTK+−2.2.4
Opcionales
Instalación de VTE
−−libexecdir=/usr/sbin : Este comando pone los ejecutables del sistema en /usr/sbin en vez de en /usr/libexec.
−−disable−gtk−doc : Este comando evita que se construya la documentación, ya que en este momento los directorios están vacíos y de no agregar esta
opción el comando make causaría erores.
Contenido
Descripciones
Librerías vte
Las librerías libvte proporcionan las funciones necesarias para implementar un "fichero termcap" para los emuladores de terminales.
vte
gnome−pty−helper
libgtop−2.0.2
Introducción a libgtop
Dependencias de libgtop
Requerida
GLib−2.2.3
Instalación de libgtop
Contenido
Descripción
Librerías libgtop
Las librerías libgtop contienen funciones que permiten el acceso a los datos de rendimiento del sistema.
GAIL−1.2.2
Introducción a GAIL
Dependencias de GAIL
Requeridas
GTK+−2.2.4 y libgnomecanvas−2.2.1
Opcionales
Instalación de GAIL
Contenido
Descripción
Librerías libgailutil
Las librerías libgailutil contienen las funciones que resuelven los problemas de accesibilidad de forma consistente en GNOME.
AT SPI−1.1.9
Introducción a AT SPI
El paquete AT SPI contiene el Interfaz de Proveedores de Servicio de Tecnologías de Accesibilidad. Esto es útil para redireccionar los eventos del
interfaz de usuario a aplicaciones accesibles y tecnologías adaptativas de accesibilidad.
Descarga adicional
Dependencias de AT SPI
Requeridas
GAIL−1.2.2 y libbonobo−2.2.3
Opcionales
Instalación de AT SPI
−−libexecdir=$GNOME_PREFIX/sbin : Este comando pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
−−disable−gtk−doc : Este comando evita que se reconstruya la documentación durante la ejecución de make.
Contenido
Descripciones
Librerías libcspi
Librerías libspi
Descripción 281
Más Allá de Linux From Scratch
at−spi−registryd
at−spi−registryd es el demonio de registro que permite la comunicación entre el UI (interfaz de usuario) y los dispositivos de asistencia.
libgail−gnome−1.0.2
Introducción a libgail−gnome
Dependencias de libgail−gnome
Requeridas
libgnomeui−2.2.2 y AT SPI−1.1.9
Instalación de libgail−gnome
Contenido
Descripción
Librerías libgail−gnome
librsvg−2.2.5
Introducción a librsvg
Dependencias de librsvg
Requeridas
Opcionales
at−spi−registryd 282
Más Allá de Linux From Scratch
Instalación de librsvg
Contenido
Descripción
Librerías librsvg
Las librerías librsvg proporcionan las funciones para representar Gráficos Vectoriales Escalables (SVG).
EEL−2.2.4
Introducción a EEL
El paquete EEL contiene la Libreria de Extensión Eazel. Es una colección de módulos y extensiones para la plataforma GNOME.
Dependencias de EEL
Requeridas
libgnomeui−2.2.2 y GAIL−1.2.2
Instalación de EEL
Contenido
Descripción
Librerías libeel
Las librerías libeel son una colección de acoples desarrollados por el proyecto Nautilus.
libgtkhtml−2.2.4
Introducción a libgtkhtml
Dependencias delibgtkhtml
Requeridas
Instalación de libgtkhtml
Contenido
Descripción
Librerías libgtkhtml
Las librerías libgtkhtml contienen las funciones necesarias para representar y/o editar HTML.
libgsf−1.8.2
Introducción a libgsf
El paquete libgsf contiene las librerías libgsf. Estas son útiles proporcionando una capa de abstracción extensible de entrada/salida para formatos de
archivos estructurados.
Dependencias de libgsf
Requeridas
Opcionales
Instalación de libgsf
−−disable−gtk−doc : Este comando evita que se reconstruya la documentación durante la ejecución de make.
Contenido
GAL−1.99.9
Introducción a GAL
El paquete GAL contiene funciones de librerías provenientes de Evolution. GAL es la abreviatura de Librerías para Aplicaciones de GNOME.
Instalación de GAL
Contenido
libgnomeprint−2.2.1.3
Introducción a libgnomeprint
Dependencias de libgnomeprint
Requeridas
libbonobo−2.2.3 y libart_lgpl−2.3.11
Opcionales
Instalación de libgnomeprint
−−sysconfdir=/etc/gnome : Esta opción pone los ficheros de configuración en /etc/gnome en lugar de en $GNOME_PREFIX/etc.
Contenido
GAL−1.99.9 285
Más Allá de Linux From Scratch
Descripción
Librerías libgnomeprint
libgnomeprintui−2.2.1.3
Introducción a libgnomeprintui
Dependencias de libgnomeprintui
Requeridas
libgnomeprint−2.2.1.3 y libgnomeui−2.2.2
Instalación de libgnomeprintui
Contenido
Descripción
Librerías libgnomeprintui
Las librerías libgnomeprintui son la parte GUI de la implementación de la Arquitectura de Impresión de GNOME.
GtkHTML−3.0.8
Introducción a GtkHTML
El paquete GtkHTML contiene un motor ligero para la interpretación/impresión/edición de código HTML. Por el momento esta es una aplicación
especifíca de Evolution.
Dependencias de GtkHTML
Descripción 286
Más Allá de Linux From Scratch
Requeridas
libgnomeprintui−2.2.1.3 y GAL−1.99.9
Opcional
libsoup−1.99.23
Instalación de GtkHTML
Contenido
Descripcion
Librerías libgtkhtml
Las librerías libgtkhtml proveen las funciones necesarias para la visualización de HTML dentro de las aplicaciones.
Requeridas 287
Capítulo 32. GNOME base
Esta sección contiene los elementos necesarios del entorno GNOME para tener un escritorio funcional.
GNOME Desktop−2.2.2
Introducción a GNOME Desktop
El paquete GNOME Desktop contiene los ficheros .desktop de GNOME, el programa gnome−about, las páginas de manual y los ficheros gráficos e
iconos básicos de GNOME.
Requeridas
libgnomeui−2.2.2 y ScrollKeeper−0.3.12
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripciones
Librerías libgnome−desktop
Las librerías libgnome−desktop contienen las API que están siendo probadas para su inclusión en libgnome o libgnomeui.
gnome−about
GNOME Panel−2.2.2.2
Introducción a GNOME Panel
El paquete GNOME Panel contiene el menú y los subprogramas (applets) del sistema.
Requeridas
libgnomeui−2.2.2 y ScrollKeeper−0.3.12
Opcionales
−−libexecdir=$GNOME_PREFIX/sbin : Esta opción pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
−−sysconfdir=/etc/gnome : Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−disable−gtk−doc : Esta opción evita que que se construya de nuevo la documentación durante el comando make.
Contenido
El paquete GNOME Panel contiene las librerías libpanel−applet−2 y los subprogramas (applets).
Descripciones
Librerías libpanel−applet
Las librerías libpanel−applet permiten el desarrollo de pequeñas aplicaciones, llamadas applets, que pueden ser incrustadas en el panel.
Subprogramas
Los subprogramas incluidos son Cambiador de Espacios de Trabajo , Lista de Ventanas, Monitor de Correo, Reloj y 'Wanda el Pez'.
GNOME Session−2.2.2
Introducción a GNOME Session
Requerida
libgnomeui−2.2.2
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripciones
gnome−session
Utilidades de sesión
Las utilidades de sesión incluyen un programa de configuración y otras utilidades relacionadas con la gestión de la sesión.
manager proxy
manager proxy maneja la gestión básica de la sesión para aplicaciones que no soportan XSM.
Control Center−2.2.2
Introducción a Control Center
Requeridas
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripciones
gnome−control−center
gnome−settings−daemon
Contenido 291
Capítulo 33. Paquetes adicionales de GNOME
Estos paquetes son modulares y añaden aplicaciones de escritorio al entorno GNOME. Siéntete libre de instalarlos si lo deseas o si los necesitas.
GNOME Terminal−2.2.2
Introducción a GNOME Terminal
El paquete GNOME Terminal contiene la consola, que es útil para ejecutar programas desde la línea de comandos.
Requeridas
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripción
gnome−terminal
Requeridas
libgnomeui−2.2.2 y startup−notification−0.5
Nota: make install necesitará acceder a $GNOME_PREFIX/bin. Si los cambios previos a la instalación los hiciste sólo para tu
cuenta de usuario, deberás ajustar tu PATH antes de ejecutar make install.
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripción
gnome−system−monitor
GNOME Applets−2.2.2
Introducción a GNOME Applets
El paquete GNOME Applets contiene pequeñas aplicaciones que normalmente se ejecutan en segundo plano y muestran su salida en el panel de gnome.
Requeridas
−−libexecdir=$GNOME_PREFIX/sbin: Este comando pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
Requeridas 293
Más Allá de Linux From Scratch
−−sysconfdir=/etc/gnome: Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
El paquete GNOME Applets contiene los subprogramas battstat, cdplayer, charpick, drivemount, geyes, gkb, gtik2, gweather, mini−commander,
mixer, modemlights y multiload.
Descripción
Subprogramas (applets)
GNOME Utilities−2.2.3
Introducción a GNOME Utilities
El paquete GNOME Utilities contiene una colección de pequeñas aplicaciones diseñadas para hacerte la vida un poco más facil.
Requerida
libgnomeui−2.2.2
−−libexecdir=$GNOME_PREFIX/sbin : Este comando pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−with−pam−prefix=/etc/pam.d : Este comando pone los ficheros de PAM en /etc/pam.d en vez de en /etc/gnome.
Contenido
Descripciones
gnome−system−log
gnome−character−map
Contenido 294
Más Allá de Linux From Scratch
gnome−calculator
gnome−calculator es una calculadora simple y científica que incluye funciones aritméticas, trigonométricas y logarítmicas.
gnome−search−tool
gnome−search−tool permite buscar ficheros en tu sistema usando condiciones de búsqueda simples y avanzadas.
gnome−dictionary
archive−generator
archive−generator crea archivos a partir de colecciones de ficheros y directorios usando el compresor gzip.
gfloppy
gdialog
GNOME Games−2.2.1
Introducción a GNOME Games
Requerida
libgnomeui−2.2.2
Opcional
Guile−1.6.4
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
El paquete GNOME Games contiene aisleriot, freecell, gataxx, glines, gnect, gnibbles, gnobots2, gnome−stones, gnome−xbill, gnometris,
gnomine, gnotravex, gnotski, gtali, iagno, mahjongg y same−gnome.
gnome−calculator 295
Más Allá de Linux From Scratch
Nautilus−2.2.4
Introducción a Nautilus
Dependencias de Nautilus
Requerida
libgnomeui−2.2.2
Opcional
medusa
Instalación de Nautilus
−−sysconfdir=/etc/gnome : Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−libexecdir=$GNOME_PREFIX/sbin : Esta opción pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
Contenido
Descripciones
nautilus
Librerías de nautilus
Las librerías libnautilus proporcionan las funciones que necesita el administrador de ficheros.
Yelp−2.2.3
Introducción a Yelp
El paquete Yelp contiene el visualizador de la ayuda, que sirve para ver ficheros de ayuda.
Nautilus−2.2.4 296
Más Allá de Linux From Scratch
Dependencias de Yelp
Requeridas
libgnomeui−2.2.2
Instalación de Yelp
−−libexecdir=$GNOME_PREFIX/sbin : Esta opción pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
Contenido
Descripción
yelp
bug−buddy−2.2.106
Introducción a bug−buddy
El paquete bug−buddy contiene una herramienta gráfica de notificación de errores. Esta herramienta puede extraer información de depuración de un
fichero core o de una aplicación que ha fallado.
Dependencias de bug−buddy
Requerida
libgnomeui−2.2.2
Instalación de bug−buddy
Contenido
Descripción
bug−buddy
gedit−2.2.2
Introducción a gedit
El paquete gedit contiene un editor de texto UTF−8 ligero para el escritorio GNOME.
Dependencias de gedit
Requerida
libgnomeui−2.2.2
Instalación de gedit
−−sysconfdir=/etc/gnome : Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripción
gedit
EOG−2.2.2
Introducción a EOG
El paquete EOG contiene "Los Ojos de GNOME". Este programa sirve para ver y catalogar ficheros de imágenes.
Descripción 298
Más Allá de Linux From Scratch
Dependencias de EOG
Requeridas
libgnomeui−2.2.2 y libgnomeprint−2.2.1.3
Instalación de EOG
−−libexecdir=$GNOME_PREFIX/sbin: Esta opción pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
−−sysconfdir=/etc/gnome: Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripción
eog
eog es un visor de imagenes rápido y funcional, así como un programa de catálogo de imagenes.
GStreamer−0.6.2
Introducción a GStreamer
El paquete GStreamer contiene un conjunto de funciones base para manipular flujos multimedia. Sirve como interfaz para los CODECs binarios.
Dependencias de GStreamer
Requerida
libgnomeui−2.2.2
Instalación de GStreamer
Contenido
gst−plugins−0.6.2
Introducción a gst−plugins
Dependencias de gst−plugins
Requerida
GStreamer−0.6.2
Opcionales
video4linux2, AAlib−1.4rc5, ALSA−0.9.6, aRts−1.1.4, Avifile−0.7.38, libdvdread−0.9.4, FFmpeg−0.4.7, FLAC−1.1.0, LAME−3.93.1, libdv−0.99,
libFAME−0.9.0, libmad−0.15.0b, OpenQuicktime−1.0 y SDL−1.2.6
Instalación de gst−plugins
Contenido
GNOME Media−2.2.2
Introducción a GNOME Media
Requeridas
libgnomeui−2.2.2 y GStreamer−0.6.2
Contenido 300
Más Allá de Linux From Scratch
make install
−−sysconfdir=/etc/gnome : Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−libexecdir=$GNOME_PREFIX/sbin : Esta opción pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
Contenido
Descripciones
gnome−sound−recorder
gnome−cd
gnome−volume−control
vumeter
Nautilus Media−0.2.2
Introducción a Nautilus Media
El paquete Nautilus Media contiene aplicaciones multimedia de GNOME usadas por nautilus.
Requeridas
libgnomeui−2.2.2 y GStreamer−0.6.2
−−sysconfdir=/etc/gnome : Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−libexecdir=/opt/gnome2/sbin : Esta opción pone los ejecutables del sistema en $GNOME_PREFIX/sbin en vez de en
$GNOME_PREFIX/libexec.
Contenido
Descripción
nautilus−audio−view
Requeridas
ScrollKeeper−0.3.12
Contenido
Descripción
Ficheros OMF
Los ficheros OMF contienen la documentación para los usuarios, que incluye introducciones y ayuda de los paquetes básicos.
Contenido 302
Capítulo 34. Otros Paquetes de GNOME
Esta sección contiene otros paquetes de GNOME.
GConf Editor−0.4.1
Introducción a GCconf Editor
El paquete GConf Editor contiene un editor con interfaz gráfica para la base de datos de configuración de GConf.
Requerida
GConf−2.2.1
Contenido
Descripción
gconf−editor
GDM−2.4.1.4
Introducción a GDM
El paquete GDM contiene el demonio de administración de pantalla de GNOME. Es útil para permitir un acceso configurable al sistema en modo
gráfico.
Dependencias de GDM
Requeridas
librsvg−2.2.5 y libgnome−2.2.3
Opcionales
Linux−PAM−0.77 y tcpwrappers−7.6
Instalación de GDM
−−sysconfdir=/etc/gnome : Este comando pone los ficheros de configuración en /etc/gnome en vez de en /opt/gnome2/etc.
−−with−pam−prefix=/etc : Este comando pone los ficheros de configuración de PAM en /etc/pam.d en vez de en /etc/gnome.
Configuración de GDM
Ficheros de configuración
/opt/gnome2/gdm.conf, /opt/gnome2/gnomerc
Los ficheros de configuración de PAM de GDM contienen módulos que no se encuentran en una instalación de BLFS. Los siguientes comandos
reemplazarán esos ficheros:
Para automatizar la ejecución de gdm, usa el siguiente comando para crear el guión en init.d si usas la variable GNOME_PREFIX=/opt/gnome−2.2.
Puedes eliminar la ruta completa si tu variable es GNOME_PREFIX=/usr.
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando GDM..."
loadproc /opt/gnome−2.2/bin/gdm
;;
stop)
echo "Parando GDM..."
if [ −f /var/run/gdm.pid ]; then
loadproc /opt/gnome−2.2/sbin/gdm−stop
fi
;;
reload)
echo "Recargando GDM..."
reloadproc /opt/gnome−2.2/sbin/gdm−safe−restart
;;
restart)
echo "Reiniciando GDM..."
loadproc /opt/gnome−2.2/sbin/gdm−restart
;;
*)
echo "Uso: $0 {start|stop|reload|restart}"
exit 1
;;
esac
# Fin de $rc_base/init.d/gdm
EOF
chmod 755 /etc/rc.d/init.d/gdm
Crea los enlaces simbólicos a este fichero en los directorios rc.d con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/gdm ../rc0.d/K05gdm &&
ln −sf ../init.d/gdm ../rc1.d/K05gdm &&
ln −sf ../init.d/gdm ../rc2.d/K05gdm &&
ln −sf ../init.d/gdm ../rc3.d/K05gdm &&
ln −sf ../init.d/gdm ../rc4.d/K05gdm &&
ln −sf ../init.d/gdm ../rc5.d/S95gdm &&
ln −sf ../init.d/gdm ../rc6.d/K05gdm
Para arrancar automáticamente en modo gráfico, edita /etc/inittab de modo que la línea que contiene
id:3:initdefault:
cambie a
id:5:initdefault:
Contenido
El paquete GDM contiene gdm, gdm−binary, gdmXnestchooser, gdmchooser, gdmflexiserver, gdmgreeter, gdmlogin, gdmmktemp,
gdmphotosetup, gdmsetup, gdmthemetester, gdm−restart, gdm−safe−restart, gdm−stop, gdmaskpass, gdmconfig y gdmopen.
Descripciones
gdm
gdm es un guión de envoltorio para ejecutar el binario GDM, el indicador de ingreso al sistema configurable basado en GNOME.
gdmchooser
gdmchooser es una aplicación para seleccionar servidores con XDMCP activado en la red local.
gdmsetup
gdm−restart y gdm−safe−restart
gdm−restart envía la señal HUP y gdm−safe−restart envía la señal USR al demonio para que se reinicie. Se usan después de editar el fichero de
configuración.
gdmconfig
gdmconfig es una aplicación para administrar la configuración del grupo de aplicaciones de GDM al completo. Maneja el aspecto, la seguridad
XDMCP, el selector de GDM y más.
Contenido 305
Capítulo 35. Configuración de GNOME
Este capítulo hace de GNOME el escritorio de tu elección cuando ejecutes statrx
ldconfig
export PATH=$PATH:/opt/gnome/bin
export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/opt/gnome/lib/pkgconfig
export GNOME_LIBCONFIG_PATH=/usr/lib
/opt/gnome/lib
MANPATH /opt/gnome/man
ORBit−0.5.17
Introducción a ORBit
El paquete ORBit contiene un Ejecutor de Peticiones de Objetos (Object Request Broker) CORBA de alto rendimiento. Esto permite a los programas
hacer peticiones y recibir respuestas de otros programas .
Dependencias de ORBit
Requeridas
popt−1.7 y GLib−1.2.10
Instalación de ORBit
Contenido
El paquete ORBit contiene las librerías libIDL, libIIOP, libORBit, libORBitCosNaming y libORBitutil.
Descripciones
libIDL
libIIOP
libORBit
libORBitCosNaming
libORBitutil
OAF−0.6.10
Introducción a OAF
Dependencias de OAF
Requeridas
ORBit−0.5.17 y libxml−1.8.17
Opcional
GTK−Doc−1.0
Instalación de OAF
ldconfig &&
./configure −−prefix=/opt/gnome −−disable−gtk−doc &&
make &&
make install
Contenido
Descripción
Librerías liboaf
GNOME Libraries−1.4.2
Introducción a GNOME Libraries
El paquete GNOME Libraries contiene las librerías GNOME. Son los cimientos del escritorio y de las aplicaciones GNOME.
libIDL 308
Más Allá de Linux From Scratch
Requeridas
Opcionales
Ficheros de configuración
Contenido
El paquete GNOME Libraries contiene las librerías libgnome, libgnomeui, libgnomesupport, libart_lgpl, libgtk−xmhtml,
libgnorbagtk y libzvt.
Descripción
libgnome
libgnomeui
libgnomesupport
libart_lgpl
libgtk−xmhtml
libgnorbagtk
libzvt
Requeridas
Opcionales
El comando make intenta abrir un terminal X durante la compilación, por lo que durante este proceso debe haber un servidor X en funcionamiento.
Contenido
Descripción
Librerías libgdk_pixbuf
libgdk_pixbuf contiene las librerías GTK+ pixel buffer del Kit de Herramientas de GIMP
GNOME Print−0.37
Introducción a GNOME Print
Requerida
El guión configure no interpreta correctamente que libxml−1.8.17 es una versión más reciente que libxml−1.8.8. Esto puede ser solucionado
construyendo xmlConf.sh con el siguiente comando:
−−with−zlib=/usr : Configura GNOME Print para usar la librería zlib del sistema.
Contenido
Bonobo−1.0.22
Introducción a Bonobo
El paquete Bonobo contiene un conjunto de interfaces CORBA independientes del lenguaje y del sistema para crear componentes reutilizables,
controles y documentos compuestos.
Dependencias de Bonobo
Requerida
GNOME Print−0.37
Instalación de Bonobo
Contenido
GConf−1.0.9
Introducción a GConf
Dependencias de GConf
Requeridas
Opcionales
Instalación de GConf
Contenido
Descripción
Librerías libgconf
Las librerías libgconf proporcionan las funciones necesarias para mantener la base de datos de configuración.
El paquete GNOME Virtual File System contiene librerías del sistema de ficheros.
Requeridas
Opcionales
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
Contenido
Descripción
Librerías libgnomevfs
libglade−0.17
Introducción a libglade
El paquete libglade contiene librerías que permiten a las aplicaciones cargar los ficheros de interfaz de Glade en tiempo de ejecución.
Dependencias de libglade
Requeridas
libxml−1.8.17 y GTK+−1.2.10
Opcionales
Instalación de libglade
El comando make intenta ejecutar el servidor gráfico (X) durante el proceso de compilación, por lo tanto el mismo debe estar corriendo durante este
proceso.
Contenido
GAL−0.24
Introducción a GAL
El paquete GAL contiene funciones de librería procedentes de Gnumeric y Evolution. GAL es la abreviatura de Librerías para Aplicaciones de
GNOME.
Contenido 313
Más Allá de Linux From Scratch
Dependencias de GAL
Requeridas
Opcional
Instalación de GAL
Contenido
Guppi−0.40.3
Introducción a Guppi
El paquete Guppi contiene un programa de trazado de gráficos con soporte para guiones Guile y con capacidades estadísticas integradas.
Dependencias de Guppi
Requeridas
Bonobo−1.0.22 y GAL−0.24
Opcional
libglade−0.17
Instalación de Guppi
Contenido
El paquete Guppi contiene librerías de trazado de gráficos y plugins para GNOME 1.4.
libcapplet−1.5.11
Introducción a libcapplet
El paquete libcapplet contiene una librería para los subprogramas del panel de control.
Dependencias de libcapplet
Requerida
GNOME Libraries−1.4.2
Instalación de libcapplet
Contenido
El paquete libcapplet contiene una librería para los subprogramas (applets) del panel de control.
Soup−0.7.11
Introducción a Soup
El paquete Soup contiene una implementación en C de SOAP (Protocolo de Acceso a Objetos Simple).
Instalación de Soup
−−enable−apache=no: Este comando puede ser añadido para evitar la reconstrucción de Apache.
Contenido
El paquete Soup contiene las librerías SOAP, utilizadas para implementar llamadas a procedimientos remotos de XML.
libcapplet−1.5.11 315
Más Allá de Linux From Scratch
GtkHTML−1.1.7
Introducción a GtkHTML
Dependencias de GtkHTML
Requeridas
Opcional
Soup−0.7.11
Instalación de GtkHTML
Contenido
libghttp−1.0.9
Introducción a libghttp
El paquete libghttp contiene una librería cliente HTTP para GNOME 1.4.
Instalación de libghttp
GtkHTML−1.1.7 316
Más Allá de Linux From Scratch
Contenido
El paquete libghttp contiene una librería cliente HTTP para GNOME 1.4.
Contenido 317
XI. Programas para las X
Índice
37. Programas de Oficina Individuales
38. Paquetes de oficina
39. Navegadores Gráficos
40. Otros programas de Internet basados en las X
AbiWord−2.0.0
Introducción a AbiWord
El paquete AbiWord contiene un procesador de textos. Es útil para escribir informes, cartas u otros documentos formateados.
Dependencias de AbiWord
Requeridas
libglade−2.0.1 y fribidi−0.10.4
Opcionales
Instalación de AbiWord
cd abi &&
./configure −−prefix=/usr &&
make &&
make install
Contenido
Descripción
AbiWord
Gnumeric−1.2.0
Introducción a Gnumeric
El paquete Gnumeric contiene una hoja de cálculo. Es útil para análisis financiero.
Dependencias de Gnumeric
Requeridas
libgnomeprintui−2.2.1.3 y libgsf−1.8.2
Opcional
gda
Instalación de Gnumeric
−−sysconfdir=/etc/gnome: Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
Contenido
Descripción
gnumeric
GnuCash−1.8.7
Introducción a GnuCash
Dependencias de GnuCash
Requeridas
GNOME Print−0.37, libglade−0.17, Berkeley DB−3.3.11, GAL−0.24, GtkHTML−1.1.7, libghttp−1.0.9, Bonobo−1.0.22, Guppi−0.40.3, Guile−1.6.4,
slib−2d6 y gwrap−1.3.4
Instalación de GnuCash
Opcional 320
Más Allá de Linux From Scratch
Configuración de GnuCash
Nota: GnuCash debe ejecutarse una vez como root antes de usarse. Simplemente con ejecutar gnucash en un terminal X y pulsar
el botón de cancelación es suficiente. Esto debe hacerse antes de establecer cuentas como usuarios sin privilegios, debido a que
GnuCash debe crear por si mismo los catálogos de esquemas antes de poder usarlo.
Contenido
Descripción
gnucash
GIMP−1.2.5
Introducción a GIMP
El paquete GIMP contiene el Programa de Manipulación de Imágenes de GNU. Es útil para retoque fotográfico, composición y autoría de imágenes.
Descargas adicionales
Dependencias de GIMP
Requerida
GTK+−1.2.10
Opcionales
libtiff−3.6.0, libpng−1.2.5, libjpeg−6b, gimp−print, AAlib−1.4rc5, mpeg_lib−1.3.1, Python−2.3.2 y Módulos de Perl:Gtk−Perl−0.7008, PDL−2.4.0 y
Parse−RecDescent−1.94
Instalación de GIMP
−−disable−print: Esta opción es necesaria cuando gimp−print no está instalado. Si tienes instalado gimp−print, deberías eliminar esta opción.
Configuración de GIMP
Ficheros de configuración
~/.gimp−1.2
GIMP ejecuta un asistente de configuración para cada usuario en la primera invocación del programa.
Contenido
Descripciones
gimp
gimp es un programa de manipulación de imágenes. Trabaja con una variedad de formatos de imagen y proporciona una gran selección de
herramientas.
escputil
escputil es una utilidad para para realizar tareas de mantenimiento en una impresora de inyección Epson Stylus.
gimp−config
gimp−config lo usan otros programas que quieren enlazarse con las librerías de GIMP.
gimp−remote
gimp−remote es una pequeña utilidad que le indica a un GIMP en ejecución la apertura de un fichero de imagen local o remoto.
Evolution−1.4.4
Introducción a Evolution
Descargas adicionales
Dependencias de Evolution
Requeridas
Opcionales
OpenLDAP−2.1.22 y GTK−Doc−1.0
Instalación de Evolution
Nota: Evolution necesita a Berkeley DB−3.1.17. Los detalles del por qué están en el fichero README que se distribuye con el
código fuente de Evolution. Este paquete se enlaza estáticamente con dicha librería, por lo que el libro instala Berkeley
DB−3.1.17 en /opt, para poder borrarla una vez que Evolution se haya instalado.
cd build_unix &&
../dist/configure −−prefix=/opt/db−3.1.17 −−enable−compat185
&&
make &&
make install
Opcionalmente, puedes borrar la Berkeley DB−3.1.17 instalada más arriba con el siguiente comando.
rm −rf /opt/db−3.1.17
−−prefix=/opt/db−3.1.17: Esta versión de la Base de Datos de Berkeley no debería instalarse en /usr, ya que sólo la necesitamos para compilar
Evolution.
Contenido
Descripción
evolution
KOffice−1.2.93
Introducción a KOffice
Dependencias de KOffice
Requerida
kdebase−3.1.4
Descargas adicionales
koffice−i18n−xx−1.2.93.tar.bz2
donde xx es un código de dos a cinco letras que representa a un país. El tamaño de estos fichero varía desde los 0,4 MB hasta los 3,7 MB.
Instalación de KOffice
export QTDIR=/opt/qt
./configure −−prefix=/opt/kde−3.1.4 −−disable−debug &&
make &&
make install
Contenido
El paquete KOffice proporciona kword, kspread, kpresenter, kivio, kontour, krita, kugar, kplato, kchart y kformula.
kword
kspread
kpresenter
kivio
kontour
krita
kugar
kplato
kplato es una aplicación para el manejo de proyectos (en sus primeras etepas de desarrollo).
kchart
kformula
OpenOffice−1.1.0
Introducción a OpenOffice
Dependencias de OpenOffice
Requeridas
Opcionales
Descargas adicionales
Instalación de OpenOffice
Si quieres optimizar la compilación, edita solenv/inc/unxlngi4.mk y añade tus opciones de optimización a la variable CFLAGSOPT. Algunos
usuarios informaron que tuvieron problemas con −fomit−frame−pointer. Es mejor no usar ningún tipo de optimización. El comando que sigue elimina
una opción −mcpu en dicho fichero, ya que es incorrecta.
krita 325
Más Allá de Linux From Scratch
cd solenv/inc &&
cp unxlngi4.mk unxlngi4.mk.orig &&
sed −e "s:\−mcpu=pentiumpro::" \
unxlngi4.mk.orig > unxlngi4.mk &&
cd ../..
Configura openoffice con los comandos siguientes. Puedes construir sólo algunos lenguajes específicos si lo prefieres. Si un componente en particular
no se encuentra disponible en el lenguaje que elijas, estará por defecto en inglés. El siguiente comando compilará todos los lenguajes disponibles.
cd config_office/ &&
./configure −−with−lang=ALL &&
cd ..
Nota: Openoffice falla al compilar si la máscara de usuario está establecida a algo exótico. Establece la máscara a 022 si
normalmente la tienes a otra cosa.
./bootstrap &&
bash −c "source LinuxIntelEnv.Set.sh; dmake"
Si descargaste los ficheros zip con los contenidos de ayuda traducidos, deberás descomprimirlos en el directorio apropiado como se explica más abajo y
luego realizar de nuevo la instalación.
cd solver/645/unxlngi4.pro/pck &&
for i in $(ls ../../../../../helpcontent_*_unix.tgz)
do
tar −xvzf $i
done &&
cd ../../../../instsetoo &&
rm −rf unxlngi4.pro &&
cd .. &&
bash −c "source LinuxIntelEnv.Set.sh ; dmake"
Instala OpenOffice ejecutando los siguientes comandos. Estos instalarán el conjunto en idioma inglés. Para instalar una versión localizada reemplaza el
01 por el código telefónico internacional de tu país. Ten en cuenta que para instalarlo necesitarás un entorno X, aunque no haya ninguna ventana X
visible. Puedes usar Xvfb si estás compilando en una consola.
cd instsetoo/unxlngi4.pro/01/normal &&
cp install install.orig &&
sed −e "s:^oo_home=.*:oo_home=openoffice:" install.orig > install &&
./install −−prefix=/opt &&
for appl in swriter scalc sdraw simpress smath soffice spadmin
do ln −sf /opt/openoffice/program/$appl /usr/bin/$appl
done
for appl in swriter scalc sdraw simpress smath soffice; do ...: Crea enlaces para que el paquete pueda iniciarse desde la línea de comandos sin tener
que modificar el PATH actual.
Contenido
Descripciones
swriter
Procesador de textos.
simpress
Aplicación de presentaciones.
scalc
Hoja de cálculo.
sdraw
Aplicación de dibujo.
smath
spadmin
Configuración de impresión de OpenOffice. Puede que necesites ejecutarlo si tienes problemas de impresión.
simpress 327
Capítulo 39. Navegadores Gráficos
Este capítulo contiene una maravillosa selección de navegadores. Esperamos que encuentres uno que te guste o que los pruebes todos.
Mozilla−1.5
Introducción a Mozilla
Mozilla es un entorno de navegación, el hermano en código abierto de Netscape. Incluye el navegador, un editor HTML, un cliente de correo y noticias,
un cliente de calendario y un cliente de IRC.
El proyecto Mozilla hospeda también dos subproyectos qie intentan cubrir las necesidades de los usuarios que no necesitan el entorno de navegación
completo o quieren tener aplicaciones separadas para navegación y correo. Estos subproyectos son Mozilla Firebird, (un navegador independiente
basado en el código de Mozilla) y Mozilla Thunderbird, (un cliente de correo independiente basado en el código de Mozilla). Las instrucciones de
construcción para estas dos aplicaciones se exponen en esta sección en vez de ponerlas en una sección aparte, pues las instrucciones de construcción
son muy similares a las de Mozilla. Adicionalmente, debido a la similitud, sólo se nombrarán los cambios necesarios con respecto a las instrucciones
para Mozilla.
Dependencias de Mozilla
Requeridas
FreeType−2.1.5, XFree86−4.3.0.1, Zip−2.3, expat−1.95.6, ATK−1.2.4, Pango−1.2.5, pkgconfig−0.15.0, GLib−2.2.3, GTK+−2.2.4, libIDL−0.8.2,
lcms−1.11, libjpeg−6b, libmng−1.0.5, libpng−1.2.5 y which−2.14
Recomendada
Descargas adicionales
Instalación de Mozilla
Nota: Según las instituciones financieras, la siguiente modificación hace que tu navegador sea inseguro. Estás avisado. Muchos
sitios utilizan una etiqueta específica de MS−IE (autocomplete=off) para evitar que el autocompletado funcione en ciertos
formularios. Mozilla soporta ahora esta etiqueta para complacer a las instituciones financieras. Según los requisitos de dichas
instituciones, incluso rechazarán una solución donde esta sea una opción preferente. Sin embargo nuestra opinión es que esto
debería estar en manos del usuario. Para conseguir que el autocompletado se salte esta restricción, necesitamos hacer una ligera
modificación en el código.
#define WALLET_DONT_CACHE_ALL_PASSWORDS
Ahora borra o comenta la línea. Si alguien te dice que MS−IE es fácil de usar, ¡muéstrale este ejemplo!
Si piensas instalar Enigmail, extrae los paquetes ipc y engimail en el directorio extensions.
−−disable−accessibility \
−−disable−tests −−disable−debug \
−−disable−logging −−enable−reorder \
−−enable−strip −−disable−pedantic \
−−enable−cpp−rtti −−enable−extensions=all &&
make
cd extensions/ipc &&
./makemake −r &&
make &&
cd ../enigmail &&
./makemake −r &&
make &&
cd ../..
for i in components/enigmime.xpt \
components/ipc.xpt components/libenigmime.so components/enigmail.js \
components/enigmail.xpt chrome/enigmail.jar
do
install dist/bin/$i /usr/lib/mozilla−1.5/$i
done
cd /usr/lib/mozilla−1.5 &&
export LD_LIBRARY_PATH="/usr/lib/mozilla−1.5" &&
export MOZILLA_FIVE_HOME="/usr/lib/mozilla−1.5" &&
./regxpcom &&
./regchrome &&
touch `find /usr/lib/mozilla−1.5 −name *.rdf`
Opciones Adicionales
Puedes añadir cada uno de estos modificadores en la línea de configure para obtener el efecto descrito sobre la compilación de Mozilla.
−−enable−elf−dynstr−gc: Elimina las cadenas no referenciadas de los objetos compartidos ELF generados durante la construcción. Esta opción causa
un mala compilación en plataformas alpha.
−−enable−xterm−updates: Esta opción es para mostrar el comando actual en el título de la xterm durante la compilación.
−−enable−plaintext−editor−only: Desactiva el soporte para editar HTML. No uses esta opción si estás compilando los clientes de correo y noticias.
Añade la siguiente variable de entorno (La variable se llama Phoenix porque este era el nombre original del proyecto Mozilla Firebird):
export MOZ_PHOENIX="1"
Asegúrate que se le pasen las siguientes opciones al guión ./configure: −−disable−calendar y −−disable−mailnews.
Se recomienda instalarlo en un directorio aparte como −−prefix=/opt/firebird−0.7 para prevenir posibles problemas con una versión instalada de
Mozilla.
export MOZ_THUNDERBIRD="1"
Se recomienda instalarlo en un directorio aparte como −−prefix=/opt/thunderbird−0.3 para prevenir posibles problemas con una versión instalada de
Mozilla.
: Establece algunas variables que afectan a qué y cómo se construye. Los dos primeros export especifican que estamos construyendo una distribución.
El último export indica que estamos conformes con la versión LGPL de libart.
−−prefix=/usr: Anteriormente mozilla no soportaba la opción "make install". Así que el paquete se instalaba en /opt. Ahora el paquete soporta "make
install" y sigue las indicaciones del FHS para la instalación. Por tanto, el libro recomienda instalarlo en una ruta del sistema como /usr .
−−enable−toolkit−gtk2
−−with−system−zlib −−with−system−jpeg \
−−with−system−png −−with−system−mng
−−enable−xft: Activa el soporte para Xft. Necesitas fontconfig o la última versión de XFree86 para activar xft.
−−disable−jsd −−disable−accessibility \
−−disable−tests −−disable−debug \
−−disable−dtd−debug \
−−disable−logging −−enable−reorder \
−−enable−strip \
−−enable−cpp−rtti
: Varias opciones que determinan qué componentes se construyen y algunas opciones de optimización. Puedes elegir y alterar estas opciones.
Encontrarás más información sobre ellas en la ayuda del guión configure de Mozilla. No se usaron todas las opciones en las instrucciones que se dieron
más arriba.
−−enable−extensions=...: Activa las extensiones. Si quieres, puedes desactivar todas las extensiones, excepto el navegador, cambiando este
modificador por −−enable−extensions="default,−venkman,−inspector,−irc".
install −d /usr/include/mozilla−1.5/nss
cp −Lf dist/private/nss/*.h dist/public/nss/*.h \
/usr/include/mozilla−1.5/nss
ln −nsf mozilla−1.5 ...: Mozilla instala las cabeceras y librerías en directorios específicos de la versión. Esto crea enlaces simbólicos para que las
aplicaciones que dependen de Mozilla (como OpenOffice , Galeon, etc.) no necesiten saber qué versión de Mozilla hay instalada.
: Crea los registros de componentes necesarios para activar las instalaciones multiusuario.
Configuración de Mozilla
No se necesita una configuración específica, siempre que el binario mozilla se encuentre en la ruta de búsqueda del usuario. Si tienes instalado Mozilla
en una ubicación no estándar, entonces haz un enlace simbólico al binario mozilla en /usr/bin. Lo mismo para Mozilla Firebird y Mozilla
Thunderbird.
Muchas aplicaciones buscan a netscape cuando necesitan abrir un navegador. Puede que quieras hacer un enlace simbólico como el que sigue.
Para instalar los diferentes módulos (plugins) de Mozilla, consulta Mozdev's PluginDoc Project.
Contenido
El paquete Mozilla contiene mozilla. Se puede acceder a los diferentes componentes, como el editor web o el cliente de correo y noticias, desde el
menú una vez iniciado mozilla, o pasándole opciones a mozilla desde la línea de comandos.
Galeon−1.3.10
Introducción a Galeon
El paquete Galeon contiene un navegador para GNOME que utiliza el motor de representación gecko de Mozilla y presenta la interfaz más simple
posible para un navegador.
Dependencias de Galeon
Requeridas
Instalación de Galeon
La compilación debe hacerse con la misma versión del compilador y los mismos ajustes de optimización utilizados para Mozilla.
Contenido
Descripciones
galeon
galeon−config−tool
galeon−config−tool limpia los ajustes, instala y elimina esquemas y fija los permisos en la base de datos de GConf.
Konqueror−3.1.4
Konqueror es el navegador gráfico por defecto del entorno de escritorio KDE. Viene incluido y se instala con kdebase−3.1.4.
Dillo−0.7.3
Introducción a Dillo
Dillo es un navegador gráfico rápido y liviano. Aunque la versión 0.7.3 es considerada código "alfa", es estable. Dillo no soporta java ni javascript, y la
versión actual no soporta FTP, HTTPS ni marcos. Sin embargo, es muy rápido y, por tanto, útil para máquinas antiguas y lentas. Tiene soporte para
descargas y puede usar "cookies".
Dependencias de Dillo
Requerida
GTK+−1.2.10
Instalación de Dillo
Nota: Dillo no tiene un mecanismo para seleccionar el conjunto de caracteres y siempre utiliza iso8859−1. Si este conjunto de
caracteres no es el apropiado, cambia todas las apariciones de iso8859−1 por el conjunto de caracteres deseado en
src/dw_style.c.
Configuración de Dillo
Ficheros de configuración
La configuración global se realiza en el fichero /etc/dillorc. Puedes editarlo para definir un servidor proxy y la página de inicio por defecto.
Dillo guarda su configuración de usuario en los ficheros del directorio ~/.dillo. Estos ficheros se crean automáticamente al ejecutar dillo. Por
defecto Dillo desactiva el uso de cookies, para activarlas, edita el fichero ~/.dillo/cookiesrc. El fichero ~/.dillo/bookmarks.html es
creado y mantenido por Dillo, pero puedes editarlo con cualquier editor de texto o HTML.
Contenido
Descripción
dillo
dillo es un navegador gráfico para la WWW basado en GTK+ con características limitadas, pero es liviano y va rápido en máquinas lentas.
Dillo−0.7.3 332
Capítulo 40. Otros programas de Internet basados en las X
Internet no es sólo para navegar. Aquí encontrarás mas aplicaciones gráficas que se utilizan en otras áreas de la Red.
Pan−0.14.2
Introducción a Pan
El paquete Pan contiene un lector de noticias gráfico. Es útil para leer y escribir noticias, hacer seguimiento de artículos y responder por correo.
Dependencias dePan
Requeridas
Opcionales
gtkspell−2.0.4
Instalación de Pan
Contenido
Descripción
pan
Balsa−2.0.14
Introducción a Balsa
Dependencias de Balsa
Requeridas
Opcionales
Instalación de Balsa
−−sysconfdir=/etc/gnome: Esta opción pone los ficheros de configuración en /etc/gnome en vez de en $GNOME_PREFIX/etc.
−−with−ldap: Cambia la opción por defecto para incluir soporte a LDAP, si está disponible.
−−with−gpgme: Cambia la opción por defecto para incluir soporte a GPG si 'GnuPG made easy' (GnuPG hecho fácil − GPGME) está instalado.
Configuración de Balsa
Toda la configuración de Balsa se hace a través de su sistema de menús. La configuración de los buzones de correo se hace mediante el menú
Settings−>Preferences (Opciones−>Preferencias).
Contenido
Descripción
balsa
Opcionales 334
XII. Multimedia
Índice
41. Controladores y Librerías Multimedia
42. Utilidades de sonido
43. Utilidades de Vídeo
44. Utilidades para grabar CDs
ALSA−0.9.6
Lo primero que la gente tiende a preguntar sobre ALSA es por qué deberían usarlo en lugar de los controladores de sonido incluidos en el núcleo; hay
varias razones. Primero, los controladores de ALSA soportan más tarjetas de sonido que los del núcleo. En segundo lugar, la emulación OSS es, en
algunos casos, más rápida y mejor que los propios controladores OSS originales. Y por último, son varios los programas que pueden utilizar las
características ampliadas de ALSA para controlar mejor la tarjeta de sonido.
También es probable que ALSA sea el futuro del Sonido en Linux (de ahí el nombre Advanced Linux Sound Architecture (Arquitectura Avanzada de
Sonido en Linux)), y los controladores ALSA posiblemente se incluyan dentro del núcleo linux en algún punto de la serie de desarrollo 2.5, lo que
eventualmente llevará a ALSA a convertirse en el "estándar" de los controladores de sonido dentro del futuro núcleo estable 2.6.
Las siguientes cinco secciones del libro tratan sobre los cinco componentes individuales de ALSA: los controladores, las librerías, las utilidades, las
herramientas y las librerías de compatibilidad con OSS.
ALSA Driver−0.9.6
Introducción a ALSA Driver
El paquete ALSA Driver contiene los controladores de sonido ALSA. Son la siguiente generación de controladores de sonido para Linux.
Antes de instalar los controladores ALSA ten en cuenta que en la configuración de tu núcleo debes tener activado Sound Card Support
(CONFIG_SOUND), pero nada más en el menú "Sound" (con la posible excepción del soporte para el mezclador de la tarjeta de TV.) En particular, no
deberías tener activado OSS Sound Modules pues causará problemas cuando cargues los módulos del controlador ALSA.
Nota: Debido a que los controladores ALSA son módulos del núcleo, deben compilarse con el mismo compilador que se usó
para el núcleo.
CC=/opt/gcc−2.95.3/bin/gcc ./configure \
−−with−moddir=/lib/modules/`uname −r`/kernel/drivers/sound \
−−with−kernel=/lib/modules/`uname −r`/build \
−−with−sequencer=yes \
−−with−oss=yes \
−−with−isapnp=no \
−−with−cards=all &&
make &&
make install
Si es la primera vez que instalas los controladores ALSA, necesitarás crear los dispositivos en /dev usando el guión suministrado en las fuentes de
ALSA Driver:
./snddevices
−−with−sequencer=yes : Esto le indica al paquete ALSA Driver que construya los módulos del secuenciador de todas las tarjetas seleccionadas.
Mucha gente los quiere, por lo que posiblemente querrás dejarlo a "yes".
−−with−oss=yes : Esto le indica al paquete que construya los módulos de emulación OSS/Free. De nuevo, mucha gente los quiere, así que es mejor
dejarlo a "yes".
−−with−isapnp=no : La mayoria de tarjetas de sonido actuales son PCI, y por eso el soporte ISA "Plug and Play" no es necesario. Si estás usando una
tarjeta ISA, mejor que pongas "yes" aquí. Si tu tarjeta es ISA, pero no PnP, es seguro mantener el "no".
−−with−cards=all : Aquí puedes decirle al guión que contruya sólo los controladores de tu tarjeta de sonido. Para información completa sobre qué
controladores hay disponibles mira ./configure −−help. Si no estás seguro de qué chipset utiliza tu tarjeta, lee CARDS−STATUS en el árbol de fuentes
de ALSA Driver. La opción aquí utilizada construirá todos los controladores.
Ficheros de configuración
/etc/modules.conf
Para configurar los controladores de ALSA necesitas añadir algunas líneas a /etc/modules.conf:
[nombre−tarjetasonido] debe reemplazarse con el controlador corresponiente a tu tarjeta de sonido. Si tienes más de una tarjeta puedes añadir
secciones adicionales repitiendo lo anterior, pero cambiando el primer 0 por 1 en cada línea.
Después de editar /etc/modules.conf debes ejecutar depmod. Si los controladores que has compilado son para la versión del núcleo que estás
usando ahora, ejecuta simplemente
depmod.
Si estás compilando controladores para una versión del núcleo diferente al que tienes ejecutándose, necesitarás utilizar una orden similar a esta:
Contenido
El paquete ALSA Driver contiene los controladores de sonido y ficheros de cabecera de ALSA.
Descripciones
Son módulos del núcleo que proporcionan funcionalidad de audio y MIDI al sistema operativo.
Ficheros de cabecera
Se instalan en /usr/include/sound y se necesitan para compilar ciertos paquetes como ALSA Libraries.
ALSA Library−0.9.6
Introducción a ALSA Library
El paquete ALSA Library contiene la librería ALSA. Es usada por programas (incluido ALSA Utilities) que desean utilizar la interfaz de sonido de
ALSA.
Requerida
ALSA Driver−0.9.6
./configure &&
make &&
make install
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
Descripción
ALSA Utilities−0.9.6
Introducción a ALSA Utilities
El paquete ALSA Utilities contiene varias herramientas útiles para controlar tu tarjeta de sonido.
Requerida
ALSA Library−0.9.6
./configure &&
make &&
make install
Ficheros de configuración
/etc/asound.state
Probablemente la forma más fácil de almacenar los niveles de sonido del mezclador es guardarlos y recuperarlos con un guión de arranque. Se puede
hacer también agregando la línea post−install en el fichero /etc/modules.conf, pero se deja como un ejercicio para los lectores que deseen
hacerlo.
El paquete ALSA Driver instala el guión /etc/rc.d/init.d/alsasound. Aunque es posible usar este guión, contiene un montón de detalles
extraños que no son necesarios en un sistema LFS, de modo que crearemos nuestro propio guión /etc/rc.d/init.d/alsa.
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando alsa... Restaurando el volumen..."
loadproc /usr/sbin/alsactl restore
#echo " Cargando la fuente MIDI..."
#loadproc sfxload /path/to/soundfont
;;
stop)
echo "Deteniendo alsa... Guardando el volumen......"
loadproc /usr/sbin/alsactl store
#echo " Eliminando la fuente MIDI.........."
#loadproc sfxload −i
;;
restart)
$0 stop
/usr/bin/sleep 1
$0 start
;;
*)
echo "Uso: $0 {start|stop|restart}"
exit 1
;;
esac
# Fin de $rc_base/init.d/alsa
EOF
chmod 755 /etc/rc.d/init.d/alsa
cd /etc/rc.d/init.d &&
ln −sf ../init.d/alsa ../rc0.d/K35alsa &&
ln −sf ../init.d/alsa ../rc1.d/K35alsa &&
ln −sf ../init.d/alsa ../rc2.d/S40alsa &&
ln −sf ../init.d/alsa ../rc3.d/S40alsa &&
ln −sf ../init.d/alsa ../rc4.d/S40alsa &&
ln −sf ../init.d/alsa ../rc5.d/S40alsa &&
ln −sf ../init.d/alsa ../rc6.d/K35alsa
Nota que por defecto todos los canales están mudos. Puedes usar el programa alsamixer del paquete ALSA Utilities (o cualquier otro mezclador OSS)
para modificar esto.
Además, la primera vez que se ejecute, el guión se quejará de que no hay un estado definido en /etc/asound.state. Esto se puede prevenir
ejecutando los comandos siguientes despues de instalar ALSA Utilities:
Por último, las líneas que cargan sfxload están comentadas. Están aquí como ejemplo de otras cosas que puedes querer hacer en el guión de inicio.
sfxload es un paquete aparte que interesará a los usuarios de tarjetas SoundBlaster AWE y Live!. Se encarga de cargar "fuentes de sonido" (usadas
para la salida MIDI). Tal vez quieras borrar estas líneas y agregar las tuyas propias o, si tienes la tarjeta de sonido adecuada, instalar sfxload y
descomentarlas.
Contenido
El paquete ALSA Utilities package contiene aconnect, alsactl, alsamixer, amixer, aplay, arecord y aseqnet.
Descripciones
aconnect
aconnect es una utilidad para conectar y desconectar dos puertos existentes en el sistema de secuenciador de ALSA.
alsactl
alsactl se usa para el control de los ajustes avanzados de los controladores de tarjetas de sonido de ALSA.
alsamixer
alsamixer es un mezclador basado en ncurses para los controladores de tarjetas de sonido de ALSA.
amixer
amixer permite el control del mezclador mediante la línea de comandos para los controladores de tarjetas de sonido de ALSA.
aplay
aplay es un reproductor de sonidos en línea de comandos para los controladores de tarjetas de sonido de ALSA.
arecord
arecord es un grabador de sonidos en línea de comandos para los controladores de tarjetas de sonido de ALSA.
aseqnet
aseqnet es un cliente del secuenciador ALSA que envía y recibe paquetes de eventos por la red.
ALSA Tools−0.9.6
Introducción a ALSA Tools
El paquete ALSA Tools contiene herramientas avanzadas para ciertas tarjetas de sonido.
Requerida
ALSA Library−0.9.6
El paquete ALSA Tools sólo es necesario para aquellos con necesidades avanzadas para su tarjeta de sonido. Las herramientas no se compilan todas a
la vez, en vez de eso necesitas hacer cd al directorio de cada herramienta que quieras compilar y ejecutar los siguientes comandos:
./configure &&
make &&
make install
Contenido
Las herramientas disponibles en este paquete son ac3dec, as10k1, envy24control, sb16_csp y sbiload.
Contenido 340
Más Allá de Linux From Scratch
Descripciones
ac3dec
as10k1
as10k1 es un ensamblador para el chip emu10k1 DSP presente en las tarjetas de sonido Creative SB Live, PCI 512, y emu APS. Se utiliza para crear
efectos de sonido tales como fusiones, coros o reverberaciones.
envy24control
envy24control es una herramienta de control para tarjetas de sonido basadas en Envy24 (ice1712).
sb16_csp
sbiload
ALSA OSS−0.9.6
Introducción a ALSA OSS
El paquete ALSA OSS contiene la librería ALSA para compatibilidad con OSS. Es utilizada por programas que usan la interfaz de sonido OSS de
ALSA.
Requerida
ALSA Library−0.9.6
./configure &&
make &&
make install
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
El paquete ALSA OSS contiene aoss y la librería libaoss (librería ALSA de compatibilidad con OSS).
aRts−1.1.4
El Sintetizador Analógico en Tiempo Real (aRts) proporciona un software que simula un "sintetizador análogico modular" completo en tu
computadora. Crea sonidos y música usando pequeños módulos como osciladores para crear formas de onda, varios filtros, módulos para reproducir
Descripciones 341
Más Allá de Linux From Scratch
datos a través de tus altavoces, mezcladores y atenuadores (faders). Puedes configurarlo totalmente por medio de la interfaz gráfica del sistema, usando
los módulos (generadores, efectos y salida) conectados unos con otros.
aRts suministra las librerías necesarias para KDE, pero también se puede instalar como un paquete independiente. Puedes encontrar las instrucciones
para su instalación en la sección aRts−1.1.4 de las instrucciones de KDE.
Audio File−0.2.3
Introducción a Audio File
El paquete Audio File contiene las librerías audiofile y dos programas de soporte para los ficheros de sonido. Sirven para soportar formatos básicos de
ficheros de sonido.
Contenido
El paquete Audio File contiene las librerías libaudiofile, audiofile−config, sfinfo y sfconvert.
Descripciones
Librerías audiofile
La librería audiofile la utilizan los programas para soportar los formatos de audio AIFF, AIFF−comprimido, SUN/NeXT, WAV y BICS.
audiofile−config
El guión audiofile−config se utiliza durante el proceso de compilación de los programas que se enlazan con esta librería.
sfinfo
El programa sfinfo muestra el formato de un fichero de sonido, la codificación de audio, la frecuencia de muestreo y la duración para los formatos de
audio soportados por esta librería.
sfconvert
El programa sfconvert cambia el formato de ficheros de sonido, siempre que tanto el formato origen como el destino estén soportados por la librería.
EsounD−0.2.30
Introducción a EsounD
El paquete EsounD contiene el Demonio de Sonido Enlightened. Es útil para mezclar varios flujos de sonido digitalizados y reproducirlos en un único
dispositivo.
Dependencias de esound
Requerida
Audio File−0.2.3
Instalación de EsounD
−−sysconfdir=/etc : Este comando pone los ficheros de configuración en /etc en lugar de /usr/etc.
Configuración de EsounD
Ficheros de configuración
/etc/esd.conf
Las instrucciones e información sobre el fichero de configuración se encuentran en el fichero TIPS dentro del directorio de las fuentes de EsounD.
Contenido
El paquete EsounD contiene esd, esdcat, esdctl, esdloop, esdmon, esdrec, esdsample y las librerías libesd.
Descripciones
esd
esdcat
esdctl
esdloop
esdmon
esdrec
esdsample
Librerías esd
SDL−1.2.6
Introducción a SDL
La Capa Simple de DirectMedia (acortando, SDL) es una librería multiplataforma diseñada para faciltar la escritura de software multimedia, como
juegos y emuladores.
Dependencias de SDL
Opcionales
Instalación de SDL
−−disable−debug : Esta opción configura SDL para que se construya con optimizaciones agresivas.
−−enable−video−aalib : Esta opción solo se necesita si quieres construir SDL con soporte de vídeo AAlib.
Configuración de SDL
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
Descripción
La Capa Simple de DirectMedia es una API genérica que proporciona acceso a bajo nivel para audio, teclado, ratón, mando para juegos (joystick),
hardware 3D mediante OpenGL, y memoria de imagen (framebuffer) 2D sobre múltiples plataformas.
libao−0.8.3
Introducción a libao
El paquete libao contiene una librería de audio multiplataforma. Es útil para obtener sonido en una amplia variedad de plataformas. Actualmente
soporta ficheros WAV, OSS (Sistema de Sonido Abierto), ESD (Demonio de Sonido Enlighten) y ALSA (Arquitectura de Sonido Linux Avanzada).
SDL−1.2.6 344
Más Allá de Linux From Scratch
Instalación de libao
Contenido
Descripción
Librerías ao
libao suministra las funciones para los programas que desean sacar sonido en las plataformas soportadas.
libogg−1.0
Introducción a libogg
El paquete libogg contiene la estructura de ficheros Ogg. Es útil para crear (codificar) o reproducir (decodificar) un flujo de bits físico único.
Instalación de libogg
Contenido
Descripción
Librerías ogg
libogg suministra las funciones para los programas que desean leer o escribir flujos de bits en formato OGG.
libvorbis−1.0
Introducción a libvorbis
El paquete libvorbis contiene un formato de codificación de audio y música de propósito general. Es útil para crear (codificar) y reproducir
(decodificar) sonido en un formato abierto (libre de patentes).
Dependencias de libvorbis
Requerida
libogg−1.0
Instalación de libvorbis
Se sabe que libvorbis causa errores de compilación en ciertas máquinas. Si obtienes errores, prueba estas instrucciones para instalar libvorbis:
Contenido
Descripción
Librerías vorbis
NAS−1.6
Introducción a NAS
El Sistema de Audio por Red es un sistema de transporte de audio transparente a la red y basado en cliente/servidor. Puede considerarse como el
equivalente en audio de un servidor X.
Descarga adicional
Dependencias de NAS
Requerida
XFree86−4.3.0.1
Instalación de NAS
xmkmf... : Realiza la compilación de la manera estándar para compilar aplicaciones basadas en las X.
Configuración de NAS
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
libmpeg3−1.5.2
Introducción a libmpeg3
Dependencias de libmpeg3
Requerida
NASM−0.98.38
Instalación de libmpeg3
make &&
make install &&
cp i686/libmpeg3.a /usr/lib &&
cp libmpeg3.h mpeg3private.h /usr/include
cp i686/libmpeg3.a /usr/lib && cp libmpeg3.h mpeg3private.h /usr/include: Puesto que make install no copia las librerías y ficheros de cabecera a
su localización correcta, lo hacemos manualmente.
Contenido
Descripciones
libmpeg3
libmpeg3 decodifica varios estándares MPEG a datos descomprimidos listos para editar y reproducir.
mpeg3cat
mpeg3cat encadena flujos elementales o desentrelaza un flujo de programa (separa los componentes del flujo).
mpeg3dump
mpeg3toc
libmad−0.15.0b
Introducción a libmad
Instalación de libmad
Contenido
Descripción
libmad
OpenQuicktime−1.0
Introducción a OpenQuicktime
OpenQuicktime es una pequeña librería que maneja el formato de fichero Quicktime en muchas variedades de Unix. La decodificación y codificación
de audio y video se suministra mediante un mecanismo de módulos.
Descarga adicional
Dependencias de OpenQuicktime
Opcionales
GLib−1.2.10 y libjpeg−6b
Instalación de OpenQuicktime
mpeg3toc 348
Más Allá de Linux From Scratch
Contenido
Este paquete contiene la librería libopenquicktime y utilidades que te permiten manipular ficheros Quicktime.
Descripciones
libopenquicktime
dechunk
dechunk extrae marcos RGB de una película y los escribe como imágenes PPM.
make_streamable
Este programa hace que un fichero Quicktime puede tratarse como flujo.
qtdump
qtinfo
recover
Este programa recupera los JPEG y el audio PCM de una película corrupta.
libFAME−0.9.0
Introducción a libFAME
libFAME es una librería de codificación de video rápida (en tiempo real) en MPEG−1 así como MPEG−4 rectangular y de formas arbitrarias.
Instalación de libFAME
Contenido
Descripciones
libfame−config
libfame
Contenido 349
Más Allá de Linux From Scratch
Speex−1.0.1
Introducción a Speex
Speex es un formato de compresión de audio diseñado especialmente para el habla. Está bien adaptado para aplicaciones de Internet y suministra
características útiles que no se encuentran en muchos otros CODECs.
Dependencias de Speex
Recomendada
libogg−1.0
Instalación de Speex
Contenido
Descripciones
speexdec
speexenc
libspeex
id3lib−3.8.3
Introducción a id3lib
id3lib es una librería para leer, escribir y manipular etiquetas ID3v1 y ID3v2.
Instalación de id3lib
Speex−1.0.1 350
Más Allá de Linux From Scratch
Contenido
Descripciones
libid3
libid3 proporciona a los programas las funciones para la edición de etiquetas ID3v1/v2.
id3convert
id3cp
id3info
id3tag
FLAC−1.1.0
Introducción a FLAC
FLAC es un CODEC de audio similar a MP3, pero sin pérdidas, lo que significa que el audio es comprimido sin perder nada de información.
Dependencias de FLAC
Opcionales
Instalación de FLAC
./configure −−prefix=/usr
make &&
make install
Contenido
El paquete FLAC contiene flac, metaflac, libFLAC, libFLAC++, libOggFLAC, libOggFLAC++ y libxmms−flac.
Descripciones
flac
flac es una utilidad de línea de comandos para codificar, decodificar y convertir ficheros FLAC.
metaflac
metaflac es un programa para listar, añadir, eliminar o editar metadatos en uno o mas ficheros FLAC.
Contenido 351
Más Allá de Linux From Scratch
Estas librerías proporcionan las API nativas C/C++ de FLAC y Ogg FLAC para los programas que utilizan FLAC.
libxmms−flac
libdvdread−0.9.4
Introducción a libdvdread
libdvdread es una librería que proporciona una base simple para leer DVDs.
Dependencias de libdvdread
Opcional
libdvdcss−1.2.8
Instalación de libdvdread
−−with−libdvdcss : Hace falta esta opción si quieres que libdvdread sea capaz de leer DVDs encriptados con CSS.
Contenido
Descripción
libdvdread
libdvdcss−1.2.8
Introducción a libdvdcss
libdvdcss es una librería simple para acceder a un DVD como si fuese un dispositivo de bloque, sin tener que preocuparse por la desencriptación.
Instalación de libdvdcss
Contenido
Descripción
libdvdcss
libdvdcss proporciona la funcionalidad necesaria para el acceso a DVD con desencriptación CSS.
libdv−0.99
Introducción a libdv
libdv (Quasar DV) es un CODEC de software para video DV, el formato de codificación utilizado por muchas cámaras digitales.
Dependencias de libdv
Opcionales
Instalación de libdv
Contenido
Descripciones
dvconnect
dvconnect es una pequeña utilidad para enviar o capturar datos en crudo de la cámara digital .
encodedv
playdv
libdv
libdv proporciona las funciones para los programas que manejan el CODEC Quasar DV.
liba52−0.7.4
Contenido 353
Más Allá de Linux From Scratch
Introducción a liba52
liba52 es una librería libre para decodificar flujos ATSC A/52 (conocidos también como AC−3). El estándar A/52 se usa en varias aplicaciones,
incluida la televisión digital y los DVD.
Instalación de liba52
Contenido
Descripciones
a52dec
extract_a52
liba52
liba52 suministra las funciones para los programas que se ocupan de flujos ATSC A/52.
XviD−0.9.2
Introducción a XviD
Dependencias de XviD
Opcional
NASM−0.98.38
Instalación de XviD
cd build/generic &&
./configure −−prefix=/usr &&
make &&
make install &&
cp ../../src/divx4.h /usr/include
cp ../../src/divx4.h /usr/include : Este comando pone ese fichero de cabecera en la ruta de búsqueda de cabeceras, con el fin de que Xine y MPlayer
localicen este paquete.
Contenido
El paquete central de XviD contiene la librería libxvidcore y los correspondientes ficheros de cabecera. La propia librería facilita funciones para
codificar y decodificar muchos de los datos de vídeo MPEG−4.
Codificación I, P−Frame
I−Frames son cuadros de imagen, mientras que P−Frames son Patrones de Cuadros. Los Cuadros de Imagen contienen imágenes completas. P−Frames
contiene patrones de lo que cambia en la imagen, ahorrando mucho espacio.
Detección Fast Motion que puede referir un patrón con forma de diamante o cuadrado a direcciones diferentes.
inter4v mode
Incluso los movimientos halfpixel pueden codificarse. Una mejor precisión da lugar a una mejor compresión con mejor calidad.
MPEG4 es el estándar del que derivó DivX. H263 es un subconjunto de este estándar ligeramente modificado por Microsoft. La cuantización es el
mapeado de la cantidad de valores de color a números.
La cuantización puede hacerse usando matrices personalizadas, obteniendo posiblemente mejores resultados si la matriz se hace para adaptarse a los
datos de vídeo. Para el uso normal debería bastar con la matriz por defecto que viene con XviD.
La Cuantización y la Máscara de luminosidad son variables, dependiendo del material de entrada, proporcionando por tanto mejores resultados en
imágenes oscuras o con alto contraste.
xine Libraries−1−rc0a
Introducción a xine Libraries
El paquete xine Libraries contiene las librerías xine. Son útiles como interfaz para módulos externos que permiten el flujo de la información desde la
fuente a la pantalla y los altavoces.
Requeridas
Opcionales
AAlib−1.4rc5, libmng−1.0.5, GNOME Virtual File System−2.2.5, SDL−1.2.6, DirectFB−0.9.19, DXR3, FLAC−1.1.0, libFAME−0.9.0, libogg−1.0,
libvorbis−1.0, liba52−0.7.4, libmad−0.15.0b, Speex−1.0.1, Theora, FFmpeg−0.4.7 y XviD−0.9.2
Contenido
Descripciones
xine−config
xine−config proporciona información a los programas que intentan enlazarse con las librerías de xine.
Librerías libxine
mpg123−0.59r
Introducción a mpg123
El paquete mpg123 contiene un reproductor de MP3 para la consola. Dice ser el decodificador de MP3 para Unix más rápido.
Dependencias de mpg123
Requerida
Instalación de mpg123
Contenido
Descripción
mpg123
Vorbis Tools−1.0
Introducción a Vorbis Tools
El paquete Vorbis Tools contiene herramientas de línea de comandos para ficheros de sonido OGG. Es útill para codificar, reproducir o editar ficheros
usando el CODEC de Ogg.
Requeridas
Contenido
Descripciones
oggdec
oggdec es un decodificador simple para convertir ficheros Ogg Vorbis en ficheros de sonido PCM (WAV o RAW).
oggenc
oggenc es el codificador que convierte ficheros RAW, WAV o AIFF en ficheros Ogg Vorbis.
ogg123
ogginfo
vcut
vorbiscomment
vorbiscomment es un editor para cambiar la información contenida en las etiquetas de metadatos de un fichero de sonido.
XMMS−1.2.7
Introducción a XMMS
Dependencias de XMMS
Requeridas
Opcionales
Instalación de XMMS
./configure −−prefix=/usr −−enable−one−plugin−dir : Este comando nos asegura que todas los módulos (plugins) se ubiquen en
/usr/lib/xmms/Plugins.
Configuración de XMMS
Ficheros de configuración
~/.xmms/config
Cuando ejecutas xmms por primera vez, puedes configurarlo con CTRL+P. Puedes extender la funcionalidad de XMMS mediante módulos (plugins) y
pieles (skins). Los encontrarás en http://xmms.org.
Contenido
Descripciones
xmms
XMMS, que significa X Multimedia System, es un programa funcionalmente comparable con WinAMP. Su función principal es reproducir ficheros de
audio como WAV y MP3. Lo puedes extender con módulos para reproducir otros formatos de audio y vídeo. Su apariencia se puede personalizar usando
pieles al estilo de WinAMP.
xmms−config
Este guión es usado por otros programas que necesitan enlazarse con XMMS para encontrar las rutas a las librerías y ficheros de cabecera.
gnomexmms
Este es un subprograma (applet) para el entorno de escritorio GNOME que se incrusta en el panel de GNOME. Desde este subprograma puedes ejecutar
y controlar xmms.
wmxmms
wmxmms es un subprograma para el administrador de ventanas Window Maker. Desde este subprograma puedes ejecutar y controlar xmms.
LAME−3.93.1
Introducción a LAME
El paquete LAME contiene un codificador MP3. Es útil para crear ficheros de audio comprimidos.
Dependencias de LAME
Opcional
GTK+−1.2.10
Instalación de LAME
Contenido
Descripciones
lame
Librerías libmp3lame
Las librerías libmp3lame proporcionan las funciones necesarias para convertir ficheros WAV en ficheros MP3.
CDParanoia−III−9.8
Introducción a CDParanoia
El paquete CDParanoia contiene una herramienta para la extración de audio de un CD. Es útil para extraer ficheros de ondas de sonido desde CDs de
audio. Requiere una unidad de CDROM capaz de leer CDDA. Prácticamente todas las unidades que tienen soporte bajo Linux se pueden usar.
Instalación de CDParanoia
Configuración de CDParanoia
CDParanoia necesita muy poca configuración; en su página de manual se puede encontrar información al respecto.
Como con casi todas las librerías, no necesita configuración, salvo que el directorio de la librería (por ejemplo, /opt/lib o /usr/local/lib)
debe aparecer en /etc/ld.so.conf para que ldd pueda encontrar las librerías compartidas. Después de comprobar si esto es necesario, debes
ejecutar /sbin/ldconfig como root .
Contenido
Descripciones
cdparanoia
Este programa se usa para 'rippear' cd's de audio. 'Rippear' es extraer digitalmente la música de un cd de audio.
Librería libcdda
FFmpeg−0.4.7
Introducción a FFmpeg
FFmpeg es una solución para grabar, convertir y emitir audio y vídeo. Debido al pesado desarrollo, no funcionarán todas estas funciones.
Dependencias de FFmpeg
Opcionales
Instalación de FFmpeg
−−enable−shared: Esta opción es necesaria para construir las librerías compartidas libavcodec y libavformat.
Configuración de FFmpeg
Ficheros de configuración
~/.ffmpeg/ffserver−config
Contenido
Descripciones
ffmpeg
ffmpeg es una herramienta en línea de comandos para convertir ficheros de vídeo, flujos de red o la entrada de una tarjeta de TV a varios formatos de
vídeo.
ffserver
ffserver es un servidor de flujo para todo lo que ffmpeg pueda usar como entrada (ficheros, flujos, entrada de la tarjeta de TV, cámara web, etc).
ffplay
ffplay es un reproductor de medios muy simple y portable que utiliza las librerías ffmpeg y la librería SDL.
libavcodec/libavformat
libavcodec y libavformats son librerías para codificar/decodificar flujos de vídeo y meterlos en ficheros o paquetes de red. Puesto que están
bien documentadas, puedes incluirlas fácilmente en tu software, al igual que hacen otros paquetes.
Avifile−0.7.38
Introducción a Avifile
El paquete Avifile contiene un reproductor de vídeos AVI, herramientas y librerías de soporte. Es útil para ver y editar ficheros AVI.
Descarga adicional
Dependencias de Avifile
Requeridas
Qt−3.2.1 y SDL−1.2.6
Opcionales
Instalación de Avifile
./autogen.sh && ./configure && make maintainer−clean && ./autogen.sh : El autor de este paquete utiliza el antiguo autoconf que genera
problemas como hacer que configure no sea capaz de encontrar algunas librerías o crear problemas de compilación. Corregimos esto regenerando los
guiones de configuración.
Contenido
El paquete Avifile contiene aviplay, avibench, avifile−config, mmxnow−config, avirecompress, avicap, avirec, kv4lsetup, avicat, avitype y
avimake.
Descripciones
aviplay
aviplay maneja los formatos de entrada, los CODECs y los formatos de salida para mostrar ficheros de vídeo AVI en tu pantalla.
avibench
avibench realiza una medición del rendimiento de la librería Avifile para un fichero.
libavcodec/libavformat 362
Más Allá de Linux From Scratch
avifile−config
avifile−config se ejecuta mediante configure por los programas que desean enlazarse con la librería Avifile.
mmxnow−config
mmxnow−config se ejecuta mediante configure por los programas que desean enlazarse con la librería mmxnow.
avirecompress
avirecompress es un módulo que toma un fichero de entrada con un tipo de CODEC y lo convierte en un fichero de vídeo con otro CODEC.
avicap
avicap es un módulo que muestra vídeo adquirido con un dispositivo compatible con Video For Windows (vfw), como una cámara web o un
sintonizador de televisión.
avirec
kv4lsetup
kv4lsetup es una pequeña herramienta que le dice a video4linux el modo actual de vídeo.
avicat
avitype
avimake
MPlayer−1.0pre1
Introducción a MPlayer
El paquete MPlayer contiene un reproductor de audio/vídeo que es capaz de reproducir casi cualquier CODEC de audio y vídeo, y puede ser controlado
por línea de comandos o por GUI.
Descargas adicionales
Nota: Esto es lo mínimo para que funcione MPlayer. Para mas CODECs, pieles y fuentes visita la página web de MPlayer.
Dependencias de MPlayer
Requerida
GTK+−1.2.10
avifile−config 363
Más Allá de Linux From Scratch
Opcionales
Instalación de MPlayer
Si se usa FreeType la única ventaja de las fuentes prerenderizadas es que son mas rápidas. Instálalas así:
Si quieres reproducir DVD con MPlayer, necesitas hacer un enlace simbólico de tu unidad DVD a /dev/dvd:
Sustituye [dispositivo dvd] por el dispositivo apropiado, por ejemplo /dev/hdc. Si no sabes que dispositivo elegir, teclea:
Si tienes activada la emulación SCSI para las unidades, necesitarás conocer el dispositivo SCSI apropiado. Cada unidad CD/DVD−ROM es asignada
en el mismo orden que los IDE con nombres de dispositivo /dev/scd0, /dev/scd1 y así sucesivamente.
−−enable−menu : Esta opción activa el nuevo soporte de menú. Es como un OSD, pero puedes ejecutar incluso un intérprete de comandos con él.
−−enable−shared−pp : Esto activa la construcción de la librería compartida libpostproc (librería para el post−procesamiento, que incluye filtros
como sharpen).
cp etc/codecs.conf /etc/mplayer : Este comando copia el fichero codecs.conf estándar al directorio de configuración del sistema. MPlayer espera
este fichero en el arranque.
Configuración de MPlayer
Ficheros de configuración
/etc/mplayer/*, ~/.mplayer/*
Opcionales 364
Más Allá de Linux From Scratch
Si deseas utilizar una fuente FreeType, necesitas enlazar un fichero TTF a tu directorio ~/.mplayer. Por ejemplo:
en caso contrario
Configura la GUI con los siguientes comandos, ejecutados desde tu directorio con las fuentes:
La primera línea, gui = yes, hará que MPlayer arranque en modo GUI. Si quieres decidir si arranca en modo GUI o no, elimina esa línea e inicia
mplayer con −gui o como gmplayer (p.e. cuando lo arranques mediante un menú de un administrador de ventanas o mediante la línea de comandos).
Ten en cuenta que el fichero principal de configuración se llama config si se encuentra en el directorio ~/.mplayer
Contenido
Descripciones
mplayer
mplayer maneja los formatos de entrada, los CODECs y los formatos de salida para reproducir en tu sistema ficheros de vídeo, DVDs, (S)VCDs o
flujos de red que contengan información de audio y/o vídeo.
Ejemplos:
Para más información, consulta la excelente documentación incluida en el paquete, en el subdirectorio DOCS/.
gmplayer
mencoder
mencoder se usa para codificar cualquier película reproducible con MPlayer a DivX4, XviD o cualquier CODEC en libavcodec con audio
PCM/MP3/VBRMP3.
Ejemplo:
rm frameno.avi
mencoder −dvd 1 −aid 128 −ovc frameno −oac mp3lame \
−lameopts vbr=3 −o frameno.avi
El paquete xine User Interface contiene una interfaz de usuario para xine. Es útil para controlar las operaciones en tu película.
Requerida
xine Libraries−1−rc0a
Opcionales
Ficheros de configuración
~/.xine/config
El fichero anterior se crea y mantiene mediante el cuadro de diálogo de configuración de xine. La documentación sobre los ajustes de la configuración
se encuentra en /usr/share/doc/xine−ui/README.config_en.
Contenido
Descripciones
xine
xine reproduce flujos MPEG (audio y vídeo), flujos MPEG elementales (MP3), flujos de transporte MPEG, ficheros OGG, ficheros AVI, ficheros ASF,
algunos ficheros quicktime, VCDs y DVDs (sin encriptar).
xine−check
xine−check comprueba los problemas comunes de instalación del reproductor de vídeo xine.
xine−remote
xine−remote es una herramienta para conectar con un servidor de control remoto de xine.
transcode−0.6.10
Introducción a transcode
transcode es un conversor de audio/vídeo de cualquier formato a otro rápido, versátil y basado en línea de comandos.
Dependencias de transcode
Recomendadas
NASM−0.98.38 y LAME−3.93.1
Opcionales
XFree86−4.3.0.1, MPlayer−1.0pre1, ImageMagick, libdv−0.99, libdvdread−0.9.4 mjpeg tools, SDL−1.2.6, Qt−3.2.1, Avifile−0.7.38, libFAME−0.9.0,
libmpeg3−1.5.2, XviD−0.9.2, LZO−1.08, libxml2−2.5.11, liba52−0.7.4, FFmpeg−0.4.7, libmad−0.15.0b, cURL−7.10.7, libogg−1.0, libvorbis−1.0,
Theora, libjpeg−6b, GLib−1.2.10, GTK+−1.2.10, FreeType−2.1.5, libmpeg3−1.5.2 y OpenQuicktime−1.0
Instalación de transcode
Contenido
El paquete transcode contiene transcode, tccat, tcdecode, tcdemux, tcextract, tcframe, tcprobe, tcscan, avicodec, avidump, avimerge, avisplit,
avisync y módulos de entrada/filtrado/salida.
Descripciones
transcode
transcode es el interfaz de usuario del codificador. Maneja los módulos y otros programas, siendo el pegamento que une los módulos. Hay varios
ejemplos de uso bien documentados en la página web o en la documentación incluida en el paquete.
tccat
tccat concatena los ficheros de entrada usando los plugins de entrada de transcode.
tcdecode
tcdecode se usa para decodificar los ficheros de entrada a video RAW y flujos de audio PCM.
tcdemux
tcdemux desentrelaza (separa) una entrada de audio/vídeo que contiene múltiples flujos, por ejemplo ficheros VOB.
tcextract
tcextract obtiene flujos simples a partir de un fichero que contiene varios flujos.
tcframe
tcframe procesa cuadros de vídeo individuales en diferentes codificaciones de color (RGB >−< YUV o similar).
tcprobe
tcscan
avicodec
avidump
avidump vuelca un flujo de audio o vídeo de un fichero AVI determinado en la salida estándar (para conversion de AVI o extracción de flujos de
audio).
avimerge
avimerge une ficheros AVI del mismo formato. No intentes unir ficheros AVI de diferentes formatos, ya que probablemente aparecerán errores (¡un
mismo formato también significa los mismos bitrates!).
avisplit
avisync
avisync puede desplazar el audio de ficheros AVI para una mejor sincronización de la señal de datos de audio y vídeo.
Módulos de entrada/filtrado/salida
Dependiendo de las librerías externas que se usen, hay un gran número de módulos para convertir entradas de audio y vídeo a formato RAW, procesar
audio y vídeo RAW, y convertirlo a otros formatos para ser escrito en el tipo de fichero elegido. Lee la documentación.
avicodec 368
Capítulo 44. Utilidades para grabar CDs
Este capítulo contiene información sobre la grabación de CD bajo Linux. Primero tendrás que configurar tu núcleo para grabar CD. Empezaremos por
discutir cómo hacerlo, y luego veremos cómo instalar las utilidades.
• CD−Writing HOWTO
• CD−Recordable FAQ
• Handling CD−Images
Grabadora CD SCSI:
Grabadora CD IDE:
Para más información sobre estas opciones y los controladores que ellas instalan, lee The Linux 2.4 SCSI subsystem HOWTO.
Cdrtools−2.00.3
Introducción a Cdrtools
El paquete Cdrtools contiene uilidades para grabación de CD. Estas sirven para leer, crear o grabar (quemar) Discos Compactos.
Instalación de Cdrtools
DEFINSUSR=root DEFINSGRP=root : Estos comandos instalan todos los programas con propietario root.root en lugar de bin.bin como vienen por
defecto.
Contenidos
El paquete Cdrtools contiene cdrecord, cdda2wav, mkisofs, mkhybrid, readcd, scgcheck, isoinfo, isodump, isovfy, isodebug, devdump, rscsi y
librerías de soporte.
Descripciones
cdrecord
cdda2wav
mkisofs
readcd
scgcheck
Utilidades de soporte
isoinfo, isodump, isovfy, isodebug y devdump son programas para volcar y verificar imágenes ISO9660.
rscsi
Librerías de soporte
libdeflt, libedc_ecc, libfile, libhfs, libparanoia, librscg, libscg, libschily y libunls son las librerías de soporte de
este paquete.
Cdrdao−1.1.7
Introducción a Cdrdao
El paquete Cdrdao contiene utilidades para grabación de CD. Estas sirven para grabar un CD en el modo "disk−at−once" (grabación en una sola fase).
Dependencias de Cdrdao
Opcional
LAME−3.93.1
Instalación de Cdrdao
Contenido
Descripción
cdrdao
cdrdao graba CD−Rs de audio o de datos en modo "disk−at−once" (DAO) basándose en una descripción textual de los contenidos del CD.
UDFtools−1.0.0b2
Introducción a UDFtools
El paquete UDFtools contiene utilidades para crear y montar discos CD−RW con el sistema de ficheros UDF tanto para lectura como escritura. Los
sistemas de ficheros UDF se utilizan sobre CD−RW y DVD. Para más detalles sobre el estándar de ficheros UDF consulta: http://www.osta.org y
http://www.ecma−international.org.
Descargas adicionales
Aviso
Advierte que este parche puede dañar permanentemente tu dispositivo CD si es del tipo de los mencionados en
http://slashdot.org/article.pl?sid=03/10/25/1737244. No apliques el parche sin comprobar primero el artículo.
Instala el parche del núcleo ejecutando los siguientes comandos en el directorio de las fuentes del núcleo:
En la configuración del núcleo, compara tus ajustes con los listados aquí:
Block devices
Packet writing on CD/DVD media: Y or M
File Systems
UDF filesystems support (read only): Y
UDF write support (DANGEROUS) Y
Si construyes "packet writer" (escritura empaquetada) como módulo, añade lo siguiente a /etc/modules.conf:
Por último, crea en /dev los nodos de dispositivo de controladores de empaquetado. Añade un nodo para cada controlador CD−RW que quieras
soportar:
mknod /dev/pktcdvd0 b 97 0
mknod /dev/pktcdvd1 b 97 1
Instalación de UDFtools
Contenido
Descripciones
pktsetup
pktsetup se utiliza para establecer y eliminar asociaciones entre el dispositivo de empaquetado del núcleo y un dispositivo físico.
Ejemplo:
asocia el dispositivo físico /dev/scd0 con el dispositivo de empaquetado del núcleo /dev/pktcdvd0, entonces monta un CD−RW formateado a
UDF para acceso de lectura y escritura.
cdrwtool
cdrwtool facilita el manejo de dispositivos CD−RW, incluido el formateado de nuevos discos, ajustar las velocidades de lectura y escritura, etc..
Ejemplo:
cdrwtool −d /dev/scd0 −q
prepara un nuevo CD−RW para su uso y lo formatea con un sistema de ficheros UDF.
mkudffs
mkudffs se utiliza para crear nuevos sistemas de ficheros UDF. Puede usarse en discos duros y CD−R al igual que en CD−RW.
CUPS−1.1.19
Introducción a CUPS
El Sistema de Impresión Común de UNIX (CUPS) es un administrador de impresoras y una serie de utilidades asociadas. Está basado en el "Protocolo
de Impresión de Internet" y proporciona servicios de impresión a la mayoría de impresoras PostScript y de tramas.
Dependencias de CUPS
Opcionales
Instalación de CUPS
./configure &&
make &&
make install
El comportamiento por defecto de la instalación es apropiado para los sistemas LFS. Los ficheros de CUPS se situan en /usr/bin, /usr/sbin,
/var y /etc/cups.
Configuración de CUPS
La configuración de CUPS es dependiente del tipo de impresora y puede ser compleja. Generalmente, las impresoras PostScript se configuran más
fácil. Las instrucciones detalladas de configuración y uso de CUPS pueden encontrarse en http://www.cups.org/documentation.php. El Manual de
Administración y el Manual del Usuario son particularmente útiles.
Durante la instalación, CUPS creó el fichero de inicio /etc/rc.d/init.d/cups. Este fichero funciona, pero puede que quieras cambiarlo por un
fichero de inicio de LFS más convencional:
source /etc/sysconfig/rc
source $rc_functions
case $1 in
start)
echo "Iniciando el servidor de impresión CUPS..."
loadproc /usr/sbin/cupsd
;;
stop)
echo "Parando el servidor de impresión CUPS..."
killproc cupsd
;;
reload)
echo "Recargando el servidor de impresión CUPS..."
reloadproc /usr/sbin/cupsd
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc cupsd
;;
*)
echo "Uso: $0 {start|stop|reload|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/cups
EOF
Crea los enlaces simbólicos a este fichero en los directorios rc.d apropiados con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/cups ../rc0.d/K00cups &&
ln −sf ../init.d/cups ../rc2.d/S99cups &&
ln −sf ../init.d/cups ../rc3.d/S99cups &&
ln −sf ../init.d/cups ../rc5.d/S99cups
Contenido
CUPS proporciona accept, cupsaddsmb, cupsd, cupstestppd, lpadmin, lpc, lpinfo, lpmove, reject, cancel, cups−config, disable, enable, lp,
lpoptions, lppasswd, lpq, lpr, lprm, lpstat, libcups, libcupsimage y varios guiones y filtros.
lpc
lpc facilita un control limitado sobre las impresras y clases de colas suministradas por CUPS .
cupsd
accept
accept le indica al sistema de impresión que acepte trabajos de impresión para el destino indicado.
reject
reject le indica al sistema de impresión que rechace trabajos de impresión para el destino indicado.
cupsaddsmb
cupsaddsmb exporta impresoras al software SAMBA para usarlas con clientes Windows.
lpadmin
lpinfo
lpinfo lista los dispositivos disponibles o los controladores conocidos por el servidor CUPS.
lpmove
cupstestppd
lpq
Contenido 375
Más Allá de Linux From Scratch
lpr
lprm
cancel
disable
enable
lp
lpoptions
lpstat
lpstat muestra la información del estado de las clases, trabajos e impresoras actuales.
lppasswd
lppasswd añade, cambia o borra contraseñas en el fichero de resúmen de contraseñas de CUPS, passwd.md5.
cups−config
LPRng−3.8.22
Introducción a LPRng
El paquete LPRng contiene una implementación mejorada, extendida y portable del administrador de impresión LPR de Berkeley. Es útil para encolar
trabajos de impresión.
Instalación de LPRng
−−libexecdir=/usr/sbin −−sysconfdir=/etc : Estas opciones evitan el uso por defecto de /usr/libexec y /usr/etc.
lpr 376
Más Allá de Linux From Scratch
Configuración de LPRng
Ficheros de configuración
/etc/printcap
No hay un fichero genérico printcap para todas las impresoras. Un fichero printcap de ejemplo está en el directorio etc, y puede ser de utilidad.
También hay información en http://www.lprng.org y http://www.linuxprinting.org.
El guión de inicio que instala LPRng no es consistente con los guiones del BLFS, por tanto crearemos uno nuevo con los siguientes comandos:
source /etc/sysconfig/rc
source $rc_functions
case "$1" in
start)
echo "Iniciando lpd..."
loadproc /usr/sbin/lpd
;;
stop)
echo "Deteniendo lpd..."
killproc /usr/sbin/lpd
;;
reload)
echo "Reiniciando lpd..."
reloadproc /usr/sbin/lpd
;;
restart)
$0 stop
sleep 1
$0 start
;;
status)
statusproc /usr/sbin/lpd
;;
*)
echo "Uso: $0 {start|stop|reload|restart|status}"
exit 1
;;
esac
# Fin de $rc_base/init.d/lpd
EOF
chmod 755 /etc/rc.d/init.d/lpd
Crea los enlaces simbólicos al guión de inicio lprng en los directorios rc.d con los siguientes comandos:
cd /etc/rc.d/init.d &&
ln −sf ../init.d/lpd ../rc0.d/K00lprng &&
ln −sf ../init.d/lpd ../rc1.d/K00lprng &&
ln −sf ../init.d/lpd ../rc2.d/S99lprng &&
ln −sf ../init.d/lpd ../rc3.d/S99lprng &&
ln −sf ../init.d/lpd ../rc4.d/S99lprng &&
ln −sf ../init.d/lpd ../rc5.d/S99lprng &&
ln −sf ../init.d/lpd ../rc6.d/K00lprng
Contenido
El paquete LPRng contiene lp, lpq, lpr, lprm, lpstat, lpc y lpd.
Descripciones
lp
lpq
lpr
lprm
lpstat
lpc
lpd
lpd es el demonio.
AFPL Ghostscript−8.11
Introducción a Ghostscript
Ghostscript es un procesador versatil para datos PostScript con la capacidad para transformar PostScript a diferentes objetivos.
Descargas adicionales
Dependencias de Ghostscript
Opcionales
Instalación de Ghostscript
Para instalar la librería compartida libgs.so, ejecuta también los siguientes comandos:
make so &&
make soinstall
Descripciones 378
Más Allá de Linux From Scratch
Nota: La librería compartida depende de GTK+−1.2.10. Sólo la usan programas externos como GSview−4.4.
−−sysconfdir=/etc/gs : Esta opción instala los datos de configuración en /etc/gs en lugar de en /usr/etc.
Contenido
Ghostscript incluye un gran número de filtros para transformar ficheros PostScript/PDF en uno y otro sentido. Por favor, consulta la documentación en
HTML o ejecuta man gs.
ESP Ghostscript−7.07.1rc2
Introducción a Ghostscript
Ghostscript es un procesador versatil para datos PostScript con la capacidad para transformar PostScript a diferentes objetivos. ESP Ghostscript es una
versión personalizada de GNU Ghostscript que incluye un guión de configuración ampliado, el controlador de tramas CUPS para soportar
controladores de impresoras de tramas CUPS y parches y controladores adicionales prodecedentes de varios distribuidores Linux.
Descargas adicionales
Dependencias de Ghostscript
Opcionales
Instalación de Ghostscript
Si quieres usar el controlador OMNI extrae el archivo de las fuentes en el directorio de Ghostscript:
En caso contrario, debes añadir la opción −−without−omni al guión configure si piensas instalar la librería compartida.
Para instalar la librería compartida libgs.so necesitarás GTK+−1.2.10. Adicionalmente, si desempaquetaste los controladores OMNI entonces debes
instalar GLib−1.2.10 y crear estos enlaces simbólicos:
make so &&
make soinstall
rm /usr/include/g{lib,module,libconfig}.h
Nota: La librería compartida solo es usada por programas externos como GSview−4.4.
Para terminar la instalación, desempàqueta todas las fuentes que has cargado en /usr/share/ghostscript.
Contenido
Ghostscript viene con muchos filtros para procesar ficheros PostScript/PDF en uno y otro sentido. Consulta la documentación HTML o prueba con
man gs. ESP Ghostscript tambien suministra pstoraster.
pstoraster
pstoraster permite que CUPS filtre su salida hacia impresoras no PostScript. Se construye e instala solo si encuentra CUPS−1.1.19.
SANE−1.0.12
Introducción a SANE
SANE es una abreviatura de Scanner Access Now Easy (Acceso Fácil al Escáner). Desgraciadamente, el acceso al escáner no es fácil ya que cada
vendedor tiene sus propios protocolos. El único protocolo conocido que debería traer algo de unidad a este caos es el interfaz TWAIN, pero es
demasiado impreciso para permitir un entorno de escaneado estable. Por tanto, SANE viene con su propio protocolo, de modo que no se utilizarán los
controladores del vendedor.
SANE se divide en controladores e interfaces. Los controladores acceden a los escáneres soportados. Las interfaces permiten al usuario acceder a los
controladores.
Dependencias de SANE
Opcionales
Instalación de SANE
Para acceder a tu escáner, probablemente necesitarás los controladores del núcleo. Un escáner SCSI necesitará los controladores SCSI, un escáner de
puerto paralelo necesita soporte para dicho puerto (deberías usar modos EPP mejorados) y un escáner USB necesitará el módulo para escáner USB y
emulación SCSI. Asegúrate de que tienes los dispositivos necesarios para acceder a los controladores.
−−sysconfdir=/etc: Esta opción instala los ficheros de configuración en /etc/sane.d en vez de /usr/etc/sane.d.
Contenido
Controladores:
Interfaces:
XSane−0.91
Introducción a XSane
XSane es otro interfaz para SANE−1.0.12. Comparado con xscanimage, tiene características adicionales para mejorar la calidad de la imagen.
Dependencias de XSane
Requeridas
Instalación de XSane
Contenido
XSane viene con un interfaz gráfico, y (si GIMP−1.2.5 está instalado) un módulo para GIMP con características avanzadas. Por favor, consulta la
documentación para más información.
GOCR−0.37
Introducción a GOCR
El paquete GOCR contiene un pequeño programa OCR (Reconocimiento de Objetos de Caracteres). Es útil para leer texto a partir de un fichero gráfico
de entrada. Funciona sin entrenamiento, pero necesitas un gráfico de alta calidad para conseguir buenos resultados.
GOCR puede usarse como utilidad de consola, pero también hay una interfaz GTK en las fuentes del paquete.
Dependencias de GOCR
Opcionales
Interfaces: 382
Más Allá de Linux From Scratch
Instalación de GOCR
cd frontend/gnome &&
./configure −−prefix=/usr &&
make &&
make install
make help
make doc
make examples
Contenido
Descripciones
gocr
gocr es un programa que imprime en la salida estándar todo el texto que puede leer de cualquier fichero gráfico de entrada.
gtk−ocr
SGML Common−0.6.3
Introducción a SGML Common
El paquete SGML Common contiene install−catalog. Es útil para crear y mantener catálogos SGML centralizados.
Configuración de SGML−common
Ficheros de configuración
/etc/sgml/sgml.conf
Contenido
El paquete SGML Common contiene install−catalog, sgmlwhich, ficheros de entidades SGML y ficheros de entidades XML.
Descripciones
install−catalog
install−catalog crea un catálogo centralizado que mantiene referencias a los catálogos existentes en el árbol de directorios /usr/share/sgml.
sgmlwhich
Los ficheros de entidades SGML contienen las entidades básicas de caracteres definidas con entradas SDATA.
Los ficheros de entidades XML contienen las entidades básicas de caracteres definidas mediante una representación hexadecimal del número del
carácter Unicode.
El paquete DocBook SGML DTD contiene definiciones de tipos de documentos para la verificación de ficheros de datos SGML contra el conjunto de
reglas de DocBook. Son útiles para estructurar libros y documentación de programas conforme a un estándar que te permite utilizar transformaciones
ya escritas para dicho estándar.
Requeridas
cp docbook.cat docbook.cat.orig
sed −e '/ISO 8879/d' docbook.cat.orig > docbook.cat
cp docbook.cat docbook.cat.orig
sed −e '/gml/d' docbook.cat.orig > docbook.cat
cp docbook.cat docbook.cat.orig
sed −e 's|DTDDECL "−//OASIS//DTD Docbook V3.1//EN"|SGMLDECL|g' \
docbook.cat.orig > docbook.cat
Este comando sustituye la entrada de catálogo DTDDECL, que no está soportada por las herramientas SGML de Linux, por la entrada de catálogo
SGMLDECL.
Ficheros de configuración
/etc/sgml/catalog
Para usar solo la versión 3.x mas actual de DocBook SGML DTD se necesita lo siguiente:
Contenido
Descripciones
Ficheros DTD
Los ficheros DTD contienen una definición de tipo de documento que describe los tipos de elementos y las listas de atributos que pueden ser usados en
los ficheros SGML correspondientes.
Ficheros MOD
Los ficheros MOD contienen componentes de la definición de tipo de documento que se incluyen en ficheros DTD.
El paquete DocBook SGML DTD contiene definiciones de tipos de documentos para la verificación de ficheros de datos SGML contra el conjunto de
reglas de DocBook. Son útiles para estructurar libros y documentación de programas conforme a un estándar que te permite utilizar transformaciones
ya escritas para dicho estándar.
Requeridas
cp docbook.cat docbook.cat.orig
sed −e '/ISO 8879/d' docbook.cat.orig > docbook.cat
cp docbook.cat docbook.cat.orig
sed −e '/gml/d' docbook.cat.orig > docbook.cat
Ficheros de configuración
/etc/sgml/catalog
Para usar sólo la versión 4.x más actual de DocBook SGML DTD se necesita lo siguiente:
Contenido
Descripciones
Ficheros DTD
Los ficheros DTD contienen una definición de tipo de documento que describe los tipos de elementos y las listas de atributos que pueden ser usados en
los ficheros SGML correspondientes.
Ficheros MOD
Los ficheros MOD contienen componentes de la definición de tipo de documento que se incluyen en ficheros DTD.
OpenSP−1.5
Introducción a OpenSP
El paquete OpenSP contiene una librería en C++ para el uso de ficheros SGML/XML. Es útil para validar, procesar y manipular documentos en SGML
o XML.
Dependencias de OpenSP
Requerida
SGML Common−0.6.3
Instalación de OpenSP
Este parche elimina algunos molestos mensajes que pueden aparecer mientras ejecuta openjade.
Truco para actualizaciones: Elimina las anteriores entradas en el catálogo, antes de hacer una actualización, mediante:
install−catalog −−remove
/etc/sgml/OpenSP−{versión}.cat \
/usr/share/sgml/OpenSP−{versión}/catalog &&
install−catalog −−remove /etc/sgml/sgml−docbook.cat \
/etc/sgml/OpenSP−{versión}.cat
make pkgdatadir=/usr/share/sgml/OpenSP−1.5 : Esto cambia el valor de la variable pkgdatadir en el fichero Makefile de /usr/share/OpenSP a
/usr/share/sgml/OpenSP−1.5.
Contenido
Descripciones
onsgmls
ospam
osx
ospcat
ospcat imprime los identificadores efectivos del sistema encontrados en los catálogos.
ospent
OpenJade−1.3.2
Introducción a OpenJade
El paquete OpenJade contiene una herramienta DSSSL. Es útil para transformar SGML y XML a RTF, TeX, SGML y XML.
Dependencias de OpenJade
Requerida
OpenSP−1.5
Instalación de OpenJade
: Estos comandos crean los equivalentes en Jade de los ejecutables y librerías de OpenJade.
osx 389
Más Allá de Linux From Scratch
Configuración de OpenJade
Contenido
Descripción
openjade
El paquete DocBook DSSSL Stylesheets contiene las hojas de estilo DSSSL. Son utilizadas por OpenJade y otras herramientas para transformar
ficheros SGML y XML de DocBook.
Requerida
SGML Common−0.6.3
La siguiente configuración es necesaria para poder utilizar OpenJade en la conversión del libro BLFS de XML a HTML:
Si deseas comprobar Docbook XML DTD, DocBook DSSSL Stylesheets y OpenJade con el libro BLFS, utiliza el siguiente comando. Los comandos
están escritos para una copia local del repositorio CVS en tu directorio personal, con salida al directorio de trabajo actual, así que haz las
modificaciones necesarias para tu configuración.
Si tienes éxito debes obtener un libro BLFS en HTML con el mismo formato que el presentado en la página web.
Contenido
Descripción
collateindex.pl
collateindex.pl es un guión de Perl que crea un índice DocBook a partir de los datos de índice "en crudo".
El paquete DocBook XML DTD−4.2 contiene definiciones de tipos de documentos para la verificación de ficheros de datos XML contra los conjuntos
de reglas de DocBook. Son útiles para crear libros y documentación de programas conformes a un estándar que te permite utilizar transformaciones ya
escritas para dicho estándar.
Requeridas
libxml2−2.5.11 y UnZip−5.50
/etc/xml/docbook &&
xmlcatalog −−noout −−add "delegatePublic" \
"−//OASIS//ENTITIES DocBook XML" \
"file:///etc/xml/docbook" /etc/xml/catalog &&
xmlcatalog −−noout −−add "delegatePublic" \
"−//OASIS//DTD DocBook XML" \
"file:///etc/xml/docbook" /etc/xml/catalog &&
xmlcatalog −−noout −−add "delegateSystem" \
"http://www.oasis−open.org/docbook/" \
"file:///etc/xml/docbook" /etc/xml/catalog &&
xmlcatalog −−noout −−add "delegateURI" \
"http://www.oasis−open.org/docbook/" \
"file:///etc/xml/docbook" /etc/xml/catalog
Ficheros de configuración
/etc/xml/catalog, /etc/xml/docbook
El guión de instalación de arriba crea los ficheros y actualiza el catálogo. Necesitamos crear entradas adicionales para procesar el libro BLFS:
Para poder instalar ScrollKeeper o utilizar DocBook XML DTD V4.2 cuando V4.1.2 es solicitada por el Identificador del Sistema, crea las siguientes
entradas:
Contenido
El paquete DocBook XML DTD contiene ficheros DTD, ficheros MOD y ficheros ENT.
Descripciones
Ficheros DTD
Los ficheros DTD contienen una definición de tipo de documento que describe los tipos de elementos y las listas de atributos que pueden usarse en los
ficheros XML correspondientes.
Ficheros MOD
Los ficheros MOD contienen componentes de la definición de tipo de documento que son incluidos en los ficheros DTD.
Ficheros ENT
Los ficheros ENT contienen listas de entidades de nombres de caracteres permitidos en HTML.
El paquete DocBook XSL Stylesheets contiene hojas de estilo XSL. Son útiles para realizar transformaciones en ficheros XML de DocBook.
Requerida
libxslt−1.0.33
Ficheros de configuración
/etc/xml/catalog
Si quieres probar DocBook XML DTD y DocBook XSL Stylesheets con el libro BLFS, usa el siguiente comando. Este comando está escrito para una
copia local del repositorio CVS en tu directorio personal, con la salida dirigida al directorio actual, de modo que haz las modificaciones oportunas,
según tus necesidades.
Si todo va bien, deberías tener un fichero index.html que mostrará el libro BFLS en un navegador en una única página. Estará formateado mediante
la hoja de estilos XSL Stylesheets, de modo que no se corresponderá con el libro BLFS publicado en la web, que está formateado mediante DocBook
DSSSL Stylesheets.
Contenido
El paquete DocBook XSL Stylesheets contiene hojas de estilo XSL para HTML y FO.
Contenido 395
Capítulo 49. PostScript
Este capítulo incluye aplicaciones para crear, manipular o ver ficheros PostScript y ver ficheros en Formato Portable de Documento, PDF.
a2ps−4.13b
Introducción a a2ps
a2ps es un filtro utilizado básicamente en segundo plano, principalmente por guiones de impresión, para convertir casi todo tipo de formato de entrada
a salida PostScript. El nombre de la aplicación se amplía apropiadamente a "all to PostScript" (todo a PostScript).
Descarga adicional
Instalación de a2ps
cd contrib &&
cp Makefile.in Makefile.in.orig &&
sed −e "s:emacs::" Makefile.in.orig > Makefile.in &&
cd .. &&
cp configure{,.orig} &&
sed −e 's|/usr/local/share/ghostscript|/usr/share/ghostscript|g' \
configure.orig > configure
./configure −−prefix=/usr \
−−sysconfdir=/etc/a2ps −−localstatedir=/var \
−−with−medium=letter &&
make &&
make install
cd contrib &&
cp Makefile.in Makefile.in.orig &&
sed −e "s:emacs::" Makefile.in.orig > Makefile.in &&
cd .. &&
Estos comandos evitan que se compilen e instalen los ficheros de guiones para Emacs. Si instalaste Emacs en vez de Vi como tu editor principal,
querrás omitir estas instrucciones.
cp configure{,.orig} &&
sed −e 's|/usr/local/share/ghostscript|/usr/share/ghostscript|g' \
configure.orig > configure
Estos comandos modifican los guiones de configuración para que busquen la fuentes de Ghostscript en la ubicación en la que fueron instaladas según
las instrucciones de BLFS.
−−with−medium=letter : Esta opción cambia el tamaño del papel por defecto de A4 a letter. Las instalaciones que utilicen A4 deberían eliminar esta
opción.
Configuración de a2ps
Ficheros de configuración
/etc/a2ps/a2ps.cfg, /etc/a2ps/a2ps−site.cfg
Se puede encontrar información sobre la configuración de a2ps en los comentarios incluidos en los ficheros anteriores, y también ejecutando info a2ps.
Contenido
Descripción
a2ps
a2ps es un filtro, utilizado principalmente por guiones de impresión, que convierte la entrada estándar o ficheros soportados a PostScript.
enscript−1.6.1
Introducción a enscript
Instalación de enscript
−−sysconfdir=/etc/enscript : Esta opción pone los ficheros de configuración en /etc/enscript en vez de en /usr/etc.
−−localstatedir=/var : Esta opción establece el directorio para los datos en tiempo de ejecución en /var en vez de /usr/var.
Contenido
Descripción
enscript
enscript es un filtro, usado principalmente por guiones de impresión, que convierte ficheros ASCII a PostScript.
PSUtils−p17
Introducción a PSUtils
Instalación de PSUtils
cat ... | sed ... : Este comando crea un Makefile que instala el programa en el prefijo /usr en vez del prefijo /usr/local.
Contenido
El paquete PSUtils contiene psbook, psselect, pstops, psnup, psresize, epsffit, getafm, showchar, fixdlsrps, fixfmps, fixmacps, fixpsditps,
fixpspps, fixscribeps, fixtpps, fixwfwps, fixwpps, fixwwps, extractres, includeres y psmerge.
Descripciones
psbook
psselect
pstops
psnup
psresize
epsffit
Guiones
El resto de comandos son guiones que realizan las funciones específicas descritas en sus respectivas páginas de manual.
GSview−4.4
Introducción a GSview
Descarga adicional
Dependencias de GSview
Requeridas
Instalación de GSview
GSview usa netscape para navegar por la ayuda en línea. BLFS no instala Netscape, pero tiene otros navegadores para elegir. Simplemente edita
srcunx/gvxreg.c usando el siguiente guión sed sustituyendo [browser] por el nombre del ejecutable de tu navegador:
sed 's|GSVIEW_ROOT=/usr/local|GSVIEW_ROOT=/usr|' : Este comando cambia el directorio de instalación por defecto a /usr.
Configuración de GSview
Ficheros de configuración
/etc/gsview/*
Contenido
Descripciones
epstool
epstool es una herramienta para extraer previsualizaciones de mapas de bits de ficheros EPS.
gsview
gsview−help
Xpdf−2.02pl1
Introducción a Xpdf
Xpdf es un visor para el Formato Portable de Documento (PDF) libre de Adobe, que es rápido, pequeño y viene con algunas utilidades en línea de
comandos.
Dependencias de Xpdf
Requeridas
XFree86−4.3.0.1 y LessTif−0.93.46
Requeridas 399
Más Allá de Linux From Scratch
Opcionales
Instalación de Xpdf
−−enable−a4−paper : Debes añadir esta opción para establecer DIN A4 como formato de papel estándar.
Configuración de Xpdf
En el directorio etc encontrarás un fichero xpdfrc que puedes copiar a ~/.xpdfrc o tomarlo como ejemplo para escribir tu propio fichero de
configuración.
fontDir /usr/X11R6/lib/X11/fonts/truetype
psFile "|lpr"
psPaperSize letter
textEOL unix
t1libControl low
freetypeControl low
Descripciones
xpdf
pdftops
pdftotext
pdftopbm
Opcionales 400
Más Allá de Linux From Scratch
TeX−2.0.2
Introducción a TeX
TeX es un paquete para composición tipográfica, capaz de crear documentos en múltiples formatos. El paquete opcional texmfsrc contiene el código
fuente de los ficheros contenidos en el paquete texmf, incluidas las fuentes de docstrip.
Instalación de TeX
TeX se instala a partir del directorio de las fuentes (normalmente /usr/src) y las instrucciones para desempaquetarlo se incluyen a continuación, en
lugar de la habitual asunción de que ya tienes desempaquetado el paquete. El directorio de las fuentes debe contener los dos paquetes requeridos y, si lo
deseas, el paquete opcional.
−−with−x=no: Esta opción evitará cualquier dependencia sobre XFree86. TeX puerde compilarse con soporte para XFree86, en especial para xdvi. Si
deseas esto, elimina esta opción de configure.
−−exec−prefix=/usr −−bindir=/usr/bin: Esta opción asegurará que los binarios de TeX se instalarán en /usr/bin.
−−without−texinfo: Una instalación por defecto de LFS ya tiene instalado el paquete texinfo. Evitaremos sobreescribirlo con el paquete texinfo
incluido.
−−with−system−ncurses: Esta opción especifica que se use la librería libncurses que ya hay instalada.
−−with−system−zlib: A partir de la versión 4.0, los sistemas LFS instalan zlib como parte del sistema base. Evitaremos construirla aquí.
texconfig dvips paper letter: Este comando establece el tamaño de papel por defecto para TeX.
texconfig font rw: Este comando especifica que las fuentes sean escribibles.
Contenido
El paquete TeX contiene 125 binarios individuales. Para más detalles consulta file:///usr/share/texmf/doc/index.html, y haz una visita a la extensa
documentación de TeX.
Contenido 403
XIV. Apéndices
Índice
A. Listado de los enlaces en rc?.d usados en LFS/BLFS
B. Instalar en una localización no estándar
Es evidente que esta no es la única configuración (e incluso alguien discutirá si es óptima) para los enlaces simbólicos. Siguiendo la tradición de LFS,
deberías encontrar cual es la mejor para ti y usarla; nuestras recomendaciones son sólo una orientación.
rc0.d
rc1.d
rc2.d
rc3.d
rc2.d 406
Más Allá de Linux From Scratch
rc4.d
rc5.d
rc4.d 407
Más Allá de Linux From Scratch
rc6.d
rc6.d 408
Apéndice B. Instalar en una localización no estándar
Cuando quieres instalar un paquete en una localización diferente a /, o /usr, estás instalando fuera de las configuraciones de entorno por defecto de
muchas máquinas. Los siguientes ejemplos deberían ayudarte a determinar cómo corregir esta situación. Los ejemplos cubren el rango completo de
ajustes que puede que necesites actualizar, pero no todos son necesarios en todas las situaciones.
Glosario 410
Acrónimos
ADSL
Asymmetric Digital Subscriber Line
AIFF
Audio Interchange File Format
ALSA
Advanced Linux Sound Architecture
API
Application Programming Interface
ASCII
American Standard Code for Information Interchange
ATA
AT−Attached
ATSC
Advanced Television Systems Committee
ATK
Accessibility ToolKit
BICS
Berkeley/IRCAM/CARL
BIND
Berkeley Internet Name Domain
BIOS
Basic Input/Output System
BLFS
Beyond Linux From Scratch
BMP
Bit MaP
CD
Compact Disk
CDDA
Compact Disc Digital Audio
CIFS
Common Internet File System
Acrónimos 411
Más Allá de Linux From Scratch
Acrónimos 412
Más Allá de Linux From Scratch
Acrónimos 413
Más Allá de Linux From Scratch
Acrónimos 414
Más Allá de Linux From Scratch
Acrónimos 415