En el principio fue la línea de comandos (12 page)

BOOK: En el principio fue la línea de comandos
12.9Mb size Format: txt, pdf, ePub

Dec 14 15:04:15 theRev syslogd 1.3-3#17: restart.

Dec 14 15:04:15 theRev kernel: klogd 1.3-3, log source =

/proc/kmsg started.

Dec 14 15:04:15 theRev kernel: Loaded 3535 symbols from

/System.map.

Dec 14 15:04:15 theRev kernel: Symbols match kernel version

2.0.30

Dec 14 15:04:15 theRev kernel: No module symbols loaded.

Dec 14 15:04:15 theRev kernel: Intel MultiProcessor

Specification v1.4

Dec 14 15:04:15 theRev kernel: Virtual Wire compatibility

mode.

Dec 14 15:04:15 theRev kernel: OEM ID: INTEL Product ID:

440FX APIC at: 0xFEE00000

Dec 14 15:04:15 theRev kernel: Processor #0 Pentium(tm) Pro

APIC version 17

Dec 14 15:04:15 theRev kernel: Processor #1 Pentium(tm) Pro

APIC version 17

Dec 14 15:04:15 theRev kernel: I/O APIC #2 Version 17 at

0xFEC00000.

Dec 14 15:04:15 theRev kernel: Processors: 2

Dec 14 15:04:15 theRev kernel: Console: 16 point font, 400

scans

Dec 14 15:04:15 theRev kernel: Console: colour VGA+ 80x25,

1 virtual console (max 63)

Dec 14 15:04:15 theRev kernel: pcibios_init : BIOS32

Service Directory structure at 0x000fdb70

Dec 14 15:04:15 theRev kernel: pcibios_init : BIOS32

Service Directory entry at 0xfdb80

Dec 14 15:04:15 theRev kernel: pcibios_init : PCI BIOS

revision 2.10 entry at 0xfdba1

Dec 14 15:04:15 theRev kernel: Probing PCI hardware.

Dec 14 15:04:15 theRev kernel: Warning : Unknown PCI device

(10b7:9001). Please read include/linux/pci.h

Dec 14 15:04:15 theRev kernel: Calibrating delay loop..

ok - 179.40 BogoMIPS

Dec 14 15:04:15 theRev kernel: Memory: 64268k/66556k

available (700k kernel code, 384k reserved, 1204k data)

Dec 14 15:04:15 theRev kernel: Swansea University Computer

Society NET3.035 for Linux 2.0

Dec 14 15:04:15 theRev kernel: NET3: Unix domain sockets

0.13 for Linux NET3.035.

Dec 14 15:04:15 theRev kernel: Swansea University Computer

Society TCP/IP for NET3.034 Dec 14 15:04:15 theRev

kernel: IP Protocols: ICMP, UDP, TCP Dec 14 15:04:15

theRev kernel: Checking 386/387 coupling... Ok, fpu using

exception 16 error reporting.

Dec 14 15:04:15 theRev kernel: Checking ’hlt’

instruction... Ok.

Dec 14 15:04:15 theRev kernel: Linux version 2.0.30

(root@theRev) (gcc version 2.7.2.1) #15 Fri Mar 27

16:37:24 PST 1998

Dec 14 15:04:15 theRev kernel: Booting processor 1 stack

00002000:Calibrating delay loop.. ok - 179.40 BogoMIPS

Dec 14 15:04:15 theRev kernel: Total of 2 processors

activated (358.81 BogoMIPS).

Dec 14 15:04:15 theRev kernel: Serial driver version 4.13

with no serial options enabled

Dec 14 15:04:15 theRev kernel: tty00 at 0x03f8 (irq = 4) is

a 16550A

Dec 14 15:04:15 theRev kernel: tty01 at 0x02f8 (irq = 3) is

a 16550A

Dec 14 15:04:15 theRev kernel: lp1 at 0x0378, (polling)

Dec 14 15:04:15 theRev kernel: PS/2 auxiliary pointing

device detected -- driver installed.

Dec 14 15:04:15 theRev kernel: Real Time Clock Driver v1.07

Dec 14 15:04:15 theRev kernel: loop: registered device at

major 7

Dec 14 15:04:15 theRev kernel: ide: i82371 PIIX (Triton) on

PCI bus 0 function 57

Dec 14 15:04:15 theRev kernel: ide0: BM-DMA at

0xffa0-0xffa7

Dec 14 15:04:15 theRev kernel: ide1: BM-DMA at

0xffa8-0xffaf

Dec 14 15:04:15 theRev kernel: hda: Conner Peripherals

1275MB - CFS1275A, 1219MB w/64kB Cache, LBA,

CHS=619/64/63

Dec 14 15:04:15 theRev kernel: hdb: Maxtor 84320A5, 4119MB

w/256kB Cache, LBA, CHS=8928/15/63, DMA

Dec 14 15:04:15 theRev kernel: hdc: , ATAPI CDROM drive

Dec 15 11:58:06 theRev kernel: ide0 at 0x1f0-0x1f7,0x3f6 on

irq 14

Dec 15 11:58:06 theRev kernel: ide1 at 0x170-0x177,0x376 on

irq 15

Dec 15 11:58:06 theRev kernel: Floppy drive(s): fd0 is

1.44M

Dec 15 11:58:06 theRev kernel: Started kswapd v 1.4.2.2

Dec 15 11:58:06 theRev kernel: FDC 0 is a National

Semiconductor PC87306

Dec 15 11:58:06 theRev kernel: md driver 0.35 MAX_MD_DEV=4,

MAX_REAL=8

Dec 15 11:58:06 theRev kernel: PPP: version 2.2.0 (dynamic

channel allocation)

Dec 15 11:58:06 theRev kernel: TCP compression code

copyright 1989 Regents of the University of California

Dec 15 11:58:06 theRev kernel: PPP Dynamic channel

allocation code copyright 1995 Caldera, Inc.

Dec 15 11:58:06 theRev kernel: PPP line discipline

registered.

Dec 15 11:58:06 theRev kernel: SLIP: version

0.8.4-NET3.019-NEWTTY (dynamic channels, max=256).

Dec 15 11:58:06 theRev kernel: eth0: 3Com 3c900 Boomerang

10Mbps/Combo at 0xef00, 00:60:08:a4:3c:db, IRQ 10

Dec 15 11:58:06 theRev kernel: 8K word-wide RAM 3:5 Rx:Tx

split, 10base2 interface.

Dec 15 11:58:06 theRev kernel: Enabling bus-master

transmits and whole-frame receives.

Dec 15 11:58:06 theRev kernel: 3c59x.c:v0.49 1/2/98 Donald

Becker http://cesdis.gsfc.nasa.gov/linux/drivers

/vortex.html

Dec 15 11:58:06 theRev kernel: Partition check:

Dec 15 11:58:06 theRev kernel: hda: hda1 hda2 hda3

Dec 15 11:58:06 theRev kernel: hdb: hdb1 hdb2

Dec 15 11:58:06 theRev kernel: VFS: Mounted root (ext2

filesystem) readonly.

Dec 15 11:58:06 theRev kernel: Adding Swap: 16124k

swap-space (priority -1)

Dec 15 11:58:06 theRev kernel: EXT2-fs warning: maximal

mount count reached, running e2fsck is recommended

Dec 15 11:58:06 theRev kernel: hdc: media changed

Dec 15 11:58:06 theRev kernel: ISO9660 Extensions:

RRIP_1991A

Dec 15 11:58:07 theRev syslogd 1.3-3#17: restart.

Dec 15 11:58:09 theRev diald[87]: Unable to open options

file /etc/diald/diald.options: No such file or directory

Dec 15 11:58:09 theRev diald[87]: No device specified. You

must have at least one device!

Dec 15 11:58:09 theRev diald[87]: You must define a

connector script (option ’connect’).

Dec 15 11:58:09 theRev diald[87]: You must define the

remote ip address.

Dec 15 11:58:09 theRev diald[87]: You must define the local

ip address.

Dec 15 11:58:09 theRev diald[87]: Terminating due to

damaged reconfigure.

Las únicas partes de esto que resultan legibles para las personas normales son los mensajes de error y las advertencias. Y sin embargo, es notable que Linux no se detiene, o se viene abajo, cuando encuentra un error; escupe un gemido quejumbroso, abandona los procesos dañados, y sigue adelante. Decididamente, esto no era así en las primeras versiones de los sistemas operativos de Apple y Microsoft, por el sencillo motivo de que un sistema operativo que no es capaz de andar y mascar chicle a la vez no puede recobrarse de los errores. Buscar y solucionar errores requiere un proceso aparte que corra en paralelo al que ha fallado. Una especie de superego, si lo prefieren, que mantiene vigilados a los demás y entra en acción cuando uno se desvía. Ahora que MacOS y Windows pueden hacer más de una cosa a la vez se les da mucho mejor tratar con los errores que antes, pero no se aproximan siquiera a Linux o los demás sistemas Unix en este aspecto; y su mayor complejidad les ha hecho vulnerables a nuevos tipos de error.

Falibilidad, enmienda, redención, confianza y otros arcanos conceptos técnicos

Linux no es capaz de tener políticas centralmente organizadas que dicten cómo escribir mensajes de error y documentación, así que cada programador escribe los suyos propios. Habitualmente están en inglés, aunque montones de programadores de Linux son europeos. Frecuentemente son graciosos. Siempre son honestos. Si ha ocurrido algo malo porque el software sencillamente todavía no está acabado, o porque el usuario fastidió algo, lo dirán con todas las letras. La interfaz de línea de comandos facilita que los programas escupan pequeños comentarios, advertencias y mensajes aquí y allí. Incluso si una aplicación está implosionando como un submarino dañado, habitualmente puede seguir lanzando un pequeño mensaje de SOS. A veces, cuando se deja de trabajar con un programa y se cierra, uno se encuentra con que ha dejado detrás una serie de advertencias y mensajes de error no muy graves en las ventanas de la interfaz de línea de comandos desde la que se ejecutó. Como si el software te contara cómo le iba mientras trabajabas con él.

La documentación, en Linux, viene en forma de páginas man (abreviatura de
manual
. Se puede acceder a ellas bien mediante una GUI (xman) o desde la línea de comandos (man). Esta es una muestra de la página man de un programa llamado rsh:

Detener señales detener sólo el proceso rsh local; esto es posiblemente erróneo, pero actualmente bastante difícil de solucionar por razones demasiado complicadas para explicarlas aquí.

Las páginas man contienen un montón de material parecido, que suena como las murmuraciones de pilotos pugnando con los mandos de aviones averiados. La sensación general es la de miles de monumentales pero oscuras pugnas vistas a la luz paralizante de un estroboscopio. Cada programador está tratando con sus propios obstáculos y fallos; está demasiado ocupado solucionándolos, y mejorando el software, para explicar las cosas en detalle o tener elaboradas pretensiones.

En la práctica casi nunca se encuentra un fallo serio en Linux. Cuando se encuentra, es casi siempre en el software comercial (varios vendedores comercializan software que funciona en Linux). El sistema operativo y sus programas fundamentales de utilidad son demasiado importantes para contener fallos serios. Llevo ejecutando Linux cada día desde finales de 1995 y he visto cómo muchos programas de aplicaciones caían pasto de las llamas, pero nunca he visto que el sistema operativo se venga abajo. Nunca. Ni una sola vez. Hay unos cuanto sistemas Linux que llevan meses o años funcionando continuamente y trabajando duro sin necesidad de reiniciarlos.

Los sistemas operativos comerciales tienen que adoptar la misma postura oficial hacia los errores que tenían los países comunistas frente a la pobreza. Por razones de doctrina, no resultaba posible admitir que la pobreza era un serio problema en los países comunistas, porque la idea misma del comunismo era erradicar la pobreza. Igualmente, las compañías de sistemas operativos comerciales como Apple o Microsoft no pueden ir por ahí admitiendo que su software tiene errores y se cae todo el rato, no más de lo que Disney puede emitir comunicados de prensa firmando que el ratón Mickey es un actor disfrazado.

Esto es un problema, porque los errores existen y suceden. Cada pocos meses Bill Gates trata de hacer una demostración de un nuevo producto de Microsoft ante un gran público sólo para que le reviente en las narices. Los distribuidores de sistemas operativos comerciales, como consecuencia directa de ser comerciales, se ven forzados a adoptar la posición groseramente tosca de que los errores son raras aberraciones, habitualmente la culpa de otro, y por tanto no merece la pena hablar de ello en detalle. Esta postura, que todo el mundo sabe que es absurda, no se limita a comunicados de prensa y campañas publicitarias: constituye el modo mismo en que estas compañías hacen negocios y se relacionan con sus clientes. Si la documentación estuviera bien escrita, mencionaría fallos, errores y caídas del sistema en cada página. Si los sistemas de ayuda en línea que vienen con estos sistemas operativos reflejaran la experiencia y preocupaciones de sus usuarios, estarían dedicados básicamente a instrucciones acerca de cómo tratar con los fallos y errores del sistema.

Pero esto no sucede. Las compañías de accionistas son maravillosos inventos que nos han dado muchos excelentes bienes y servicios. Se les dan bien muchas cosas. Admitir el fracaso no es una de ellas. Diablos, ni siquiera admiten fallos menores.

Por supuesto, este comportamiento no es tan patológico en una compañía como lo sería en un ser humano. La mayoría de la gente hoy en día entiende que los comunicados de prensa de las empresas se lanzan para quedar bien con los accionistas de la compañía, no para ilustrar al público. A veces los resultados de esta deshonestidad institucional pueden ser espantosos, como en el caso del tabaco y del amianto. En el caso de los distribuidores de sistemas operativos comerciales no es nada así, por supuesto; solamente es irritante.

Algunos podrían argüir que la irritación de los consumidores, con el tiempo, se convierte en una especie de placa endurecida que puede ocultar un serio deterioro, y que la honestidad podría ser así la mejor política a largo plazo; el jurado aún tiene que decidir acerca de esto en el mercado de los sistemas operativos. El negocio se está expandiendo lo bastante rápido como para que siga siendo mucho mejor tener miles de millones de clientes crónicamente irritados que millones de clientes contentos.

La mayoría de administradores de sistemas que conozco que trabajan siempre con Windows NT están de acuerdo en que cuando tiene un fallo hay que reiniciarlo, y cuando se fastidia en serio el único modo de arreglarlo es reinstalar el sistema operativo desde el principio. O al menos éste es el único modo que conocen de arreglarlo, lo cual viene a ser lo mismo. Es muy posible que los ingenieros de Microsoft tengan un montón de información privilegiada sobre cómo arreglar el sistema cuando va mal, pero si la tienen, no parecen estar transmitiendo el mensaje a ninguno de los administradores de sistema que yo conozca.

Debido a que Linux no es comercial —porque es, de hecho, gratuito, así como bastante difícil de obtener, instalar, y operar
29
— no tiene que mantener ninguna pretensión acerca de su fiabilidad. En consecuencia, es mucho más fiable. Cuando algo falla en Linux, el error es detectado y discutido vivamente de inmediato. Cualquiera con los conocimientos técnicos necesarios puede ir derecho al código fuente y señalar el origen del error, que es rápidamente solucionado por el hacker que fuera responsable de ese programa en particular.

Other books

Ruthless by Robert J. Crane
Men of War by William R. Forstchen
Enemy In the Room by Parker Hudson
To Hold Infinity by John Meaney
Casey's Courage by Neva Brown
Open Roads by Zach Bohannon
Only with You by Lauren Layne
Bake Me a Murder by Carole Fowkes