Trucos Linux
KDE
brinda varias opciones para cuando se cansen del mouse.
Presionando <CTRL+ ESC> cambiarán a otra aplicación.
Con <ALT+TAB>, como era de esperar, rotarán entre todas las aplicaciones
activas. Usando <CTRL+Fx> pueden cambiar de consola virtual y, por último,
presionando <ALT+F4> se cierra la ventana actual, como sucede en Windows.
Opciones
de Ventana
Haciendo doble clic
en la barra de Título de un programa, la ventana desaparece, y queda
sólo esta barra. Este efecto se llama shadowing y es algo que siempre
me gustó de las Mac. Haciendo clic con el botón central del mouse
en los botones para maximizar y minimizar las ventanas, se ejecutará
la función, pero solamente a lo largo o a lo ancho de la pantalla, sin
tomar posesión total del Escritorio.
Ejecutar al inicio
Para ejecutar un programa al inicio de KDE sólo tienen que crear un kdelnk
hacia él (pueden encontrar templates de kdelnk en la carpeta TEMPLATES
del Escritorio) y editar sus propiedades. Lo único que resta hacer es
arrastrar este kdelnk a la carpeta AUTOSTART dentro del Escritorio.
Mensaje del día
El mensaje del día (MOTD) no suele ser muy útil en sistemas hogareños,
por lo que este script nos permitirá rotar entre diferentes archivos
de arte ASCII cada vez que iniciemos el sistema. Creen e[ directorio /etc/splash
y pongan todos los archivos ASCII allí. luego, como root, agreguen un
trabajo cronometrado (cron) con el siguiente- script:
#! /bin/sh
cd /etc/splash/
[ -f splash &&
SPLASH='/bin/cat splash'
[ -z "$SPLASH" ] ||
[ ! -f "$SPLASH"
&&
SPLASH='/bin/ls /bin/sed -n ´1p´'
/bín/cp
"$SPLASH" ../motd && {
/bin/ls /bin/sed -n
´1h;/^´$SPLASH,$/{${x;p;q;};n;p;}´
>. splash
}
Es posible crear
un mensaje para que todos los usuarios que se logueen al sistema lo vean. Es,
en cierta forma, similar al mensaje que aparece cuando se conectan a un servidor
de IRC.
El archivo en cuestión se encuentra en /etc/motd (por Message Of The
Day); edítenlo a gusto y necesidad con cualquier editor de texto.
Reinstalé Windows y perdí Linux
A Windows no te
gusta que alguien más use la MBR; por eso, cuando instalamos cualquier
versión, automáticamente sobrescribe la MBR a su gusto.
Si teníamos Linux instalado con LILO, necesitaremos un disquete booteable
para ingresar en Linux y poder ejecutar /sbin/lilo para que, nuevamente, LILO
pueda instalarse en la MBR
Una particularidad
de Linux (como en todos los sistemas basados en UNIX) es que los archivos suelen
tener nombres muy largos. Pasarlos como parámetros puede volverse complicado
cuando no los recordamos de memoria. Por eso el shell Bash nos ofrece su función
de autocompletado, mediante la cual, al escribir las primeras letras del nombre
y presionar <TAB>, Bash mostrará las coincidencias; esto nos evitará
el engorro de tipear el nombre completo del archivo.
Presionando <ALT+F2>
verán la línea simple de comando, la cual les permitirá
ingresar el nombre de un programa o una URL para navegar.
Cuando la pantalla, por cualquier motivo, se llena de basura, podemos utilizar este programa en C, el cual reseteará y limpiará cualquier terminal VT100. Copien este código en un archivo:
#include <stdio.h>
int main(void)
{
Printf(P\033c");//resetea
terminal
printf(P\033[2j");// limpia la pantalla
return (0);
luego graben el
archivo y escriban "make archivo", siendo archivo el nombre con el
que lo grabaron. Ahora pueden utilizarlo en cualquier momento para resetear
su terminal
En el inmenso mar
de directorios de Linux, puede resultar complicado encontrar un archivo determinado.
Para ello pueden utilizar el comando find, por ejemplo: find /-name "nombre",
donde la "/" es el directorio de inicio de la búsqueda (en
este caso buscará en todo el sistema de archivos, así como en
cualquier unidad montada) y "nombre" es la cadena a buscar (reemplácenlo
por el nombre del archivo que buscan). Como todo comando en Linux, tiene un
montón de opciones más.
Pueden pasarte
un parámetro 1 cuando se ejecute LILO, de la siguiente forma: "lilo
1". Así entrarán como root y podrán ejecutar el comando
passwd o editar directamente el archivo /etc/passwd. También sirve arrancar
con linux single y añadirte el user root o el que sea manualmente :)
Eliminar escritorios virtuales
Puede parecer una
idea rara, pero eliminar escritorios virtuales que no utilicemos liberará
recursos. Editen el archivo /etc/inittab y busquen las líneas que indican
el inicio de una terminal "getty", por ejemplo: "2:123:respawn:/sbin/míngetty
tty2". Eliminen cada una de esas líneas por escritorio que quieran
quitar; el número posterior a tty indica el número de terminal
(a los cuales accedemos presionando <ALT+Fx>). Un número de tres
terminales es suficiente para operar el sistema. Graben el archivo y reinicien.
Ya no tendrán tantos terminales, y habrán ganado unos megabytes
de memoria.
Cuando experimentamos en Linux, precisamente en el entorno gráfico, a veces sucede que todo se cuelga. Para no ir directamente al botón de reset, pueden probar la combinación de teclas <CTRL+ ALT+BACKSPACE>, que matará todos los procesos que se encuentren en ejecución y pasará a modo texto o al login gráfico si lo tienen activado.
Montaje automático de disquetes VFAT
Abran una consola
(la de su preferencia) y ejecuten el comando
mcedit Desktop/floppy.kdelnk, que abrirá un editor de texto con el archivo
de acceso al disquete del Escritorio. En éste debemos modificar el valor
contenido dentro de la línea FStype=Default por FSType=v-fat.
Para que todos puedan usar kppp
Deben hacer clic
con el botón derecho en el archivo situado en /usr/bin/kppp, y en la
solapa [Permissions], hacer clic en el checkbox [Set UID], en la línea
[User].
Esto hará que todos los usuarios puedan iniciar Kppp y no sólo
el root. Recuerden que para realizar los cambios deben estar logueados como
root.
Konqueror, el oficial
de KDE, nos permite definir palabras nos serviran como atajos para los sitios
más visitados, desde [Settings/Configure Konqueror/Enhaned Browsing].
Por ejemplo, al escribir "gg:linux" en barra de Dirección,
se abrirá el buscador Google con palabra Linux.
si desean el inicio
en modo consola, pero su distribución instala el inicio gráfico
de forma predeterminada, pueden cambiarlo modificando el archivo inittab, dentro
del directorio /ETC. Hagan una copia de respaldo y editen el archivo inittab.
Con la búsqueda encuentren la línea: id:5:initdefault
Y cámbienla por lo siguiente: id:3:initdefault:
En el próximo inicio de sesión tendrán el clásico
modo texto. Para restaurar el inicio gráfico, hagan exactamente lo contrario.
Cómo cambiar la resolución y la profundidad de color en X
Estos parámetros son controlados por el Servidor X, independientemente
del manejador de ventanas que utilicemos. Si en la configuración de X
hemos agregado varias resoluciones, podremos cambiar de resolución con
las teclas <CTRL++>. La profundidad de color, en cambio, se modifica a
través del script de inicialización startx, de la siguiente manera:
"startx -bpp <profundidad>", donde profundidad puede tomar los
valores 8, 16, 24 o 32 para las distintas opciones. Es posible cambiarlo permanentemente
desde el configurador XF86Setup.
Cómo
evitar los pings
Si quieren evitar
que su equipo responda a las peticiones ping de la Red, pueden usar este truco.
Es necesario contar con un kernel 2.1.x o superior. Para lograrlo, en la consola
deben ejecutar el siguiente comando: "echo 1 >/proc/sys/net/ipv4/icmp_echo_ignore_all"'.
Con él evitarán que su máquina responda a cualquier ping
proveniente de la Red.
Para revertir la opción, en la consola ejecuten el comando
"echo 0 > /proc/sys/ net/ipv4/icmp_echo_ignore_all", y todo volverá
a ser como antes.
Descarga automática de webs completas
Para descargar una web completa con todas las páginas a las que apunta y todos sus elementos de forma recursiva, puede usar la aplicación wget tecleando el siguiente comando:
wget -r http://www.lawebquesea.com
Y si lo que tiene es un fichero de texto con un listado de webs puede descargarlas todas del tirón tecleando:
wget -r -i listadewebs.txt
Eso sí, si no tiene una conexión muy buena tendrá que esperar un rato hasta bajar toda la web.
NOTA: Algunas páginas están expresamente protegidas para que no sean bajadas por este método, por lo que esto no funcionará en todos los casos. Tampoco funciona con páginas creadas con Flash
Comprimir
y descomprimir en linux
Supongamos que tenemos un directorio llamado subcarpeta que cuelga de carpeta, si queremos comprimir su contenido en un fichero tar.gz o descomprimir un fichero tar.gz en el directorio carpeta para que se genere toda su estructura de directorios, estos serían los comandos:
Comprimir:
cd carpeta
tar -c subcarpeta >fichero.tar
gzip fichero.tar
Descomprimir:
cd carpeta
gunzip fichero.tar.gz
tar -xvf fichero.tar
Si quieres usar los nuevos ficheros bz2 los comandos son los mismos sustituyendo gzip con bzip2 y gunzip con bunzip2.
Los ficheros tar, gz y tar.gz se pueden ver también desde MS-DOS o Windows con algunos compresores como el Windows Commander.
ln -s /dev/null core (envía los core a /dev/null)
ulimit -c 0 (limita el tamaño de los core a 0)
11.2 Imprimir paquetes instalados con dselect
método 1 - dpkg --get-selections | awk '$2 == "install" { print $1 }'
método 2 - ( cd /var/lib/dpkg/info; ls *.list ) | sed -e "/\.list/s///"
método 3 - dpkg -l
Montar
cdrom y floppy sin ser root
Como root te creas
los directorios
/mnt/floppy /mnt/a: /mnt/cdrom
metes en /etc/fstab las siguientes lineas :
/dev/cdrom /mnt/cdrom
iso9660 ro,user,noauto 0 0
/dev/fd0 /mnt/a: msdos user,noauto 0 0
/dev/fd0 /mnt/floppy ext2 user,noauto 0 0
ahora ya puedes
montar un disquete Ms-dos , un disquete ext2 o un Cd-rom,
respectivamente, con :
mount /mnt/a:
mount/mnt/floppy
mount/mnt/cdrom
El nombre del
dispositivo puede ser distinto, por ejemplo, en vez de /dev/cdrom
puedes tener /dev/hdc ... etc., depende de cada cual.
Ampliar tamaño de partición
Linux
Bueno, ampliar no creo que se pueda, pero si te creas otra partición ext2, la montas debajo de / , como por ejemplo /home, luego te creas un directorio /home/usr/local y lo enlazas a /usr/local, etc... tendrás la sensación de que efectivamente tu partición / ha aumentado de tamaño :-).
O mejor todavía :
te creas una nueva
partición, por ejemplo: /hdc3
te copias todos los directorios de /usr a /mnt/hdc3
te renombras el fichero /usr como /usr_ant por si las moscas
te creas el fichero /usr vacío
actualizas el /etc/fstab con la siguiente línea :
/dev/hdc3 /usr ext2 defaults 0 0
rearrancas, y después de unos días, para ver que todo funciona
bien, borras /usr_ant
Utilizo un pequeño script que tengo asociado a una tecla de función en mi .inputrc, así, cada vez que quiero meter o sacar un CD, le doy a la tecla F8.
## FICHERO: $HOME/.inputrc
# Personalizar
teclas de función
# F8
"\e[19~": "(. ~/scripts/cdrom)&\C-m"
Y el script es:
#!/bin/bash
if [ `grep -c
cdrom /etc/mtab` = 0 ] ;
then mount /mnt/cdrom && cd /mnt/cdrom ;
else umount /mnt/cdrom && eject /dev/cdrom ;
fi
Eliminar paquetes instalados en Debian
dpkg --remove nombre_paquete_sin_extension_deb
eliminara el paquete
aunque no los ficheros de configuración que ese
paquete pudiera tener.
dpkg --purge nombre_paquete_sin_extension_deb
eliminara todo.
cp /boot/vmlinuz /dev/fd0
así de
simple, siempre y cuando el kernel contenga la información sobre cual
partición arrancar, etc. lo que se puede indicar así:
rdev /boot/vmlinuz /dev/tuparticionroot
rdev /boot/vmlinuz
indicará cual tiene configurada:
chanae:~# rdev
/boot/vmlinuz
Root device /dev/hda3
Entrar al sistema sin saber la password
Cuando aparece
el prompt de Lilo o el del disco de arranque
escribir 'linux single' y entras como root sin necesidad de password
después hay que entrar con un editor en /etc/passwd, buscar una línea
que pone root:xxxx:0:0:root:/root:/bin/bash,
borrar xxxxx dejando root::0:0, etc
así has borrado la pasword.
Otra opción:
desde DOS, utilizar un editor del disco duro (Norton)
buscar la cadena root en el HD y eliminar la password.
Otra opción:
en el arranque, escribir init=/bin/bash, esto hace que se lance
bash directamente sin pasar por el init, o sea, sin pedir clave.
probablemente hay que remontar las particiones:
mount -t -o remount, rw /
mount -a -t nonfs
para estar seguro de que el PATH esta correcto hacer:
source /etc/profile
source /root/.profile
y por ultimo, a partir de una cuenta no-root, hacer su; para ver si la clave
de root esta ok:
paswwd
su < usuario-no-root >
su
exit
exit
reboot
Fichero /etc/lilo.conf :
# Sección
global de arranque de LILO
boot = /dev/hda
compact # si da problemas, descomentar esta opción
delay = 50
vga = normal # forzando 'sane-state'
ramdisk = 0 # paranoia setting
#
# Sección de configuración de partición de LINUX arrancable
image = /vmlinuz
root = /dev/hdc2
label = linux
#
# Sección de configuración de partición de DOS arrancable
other = /dev/hda1
label = dos
table = /dev/hda
#fin
Sustituye las particiones
por las tuyas, la primera que pongas será la que arranque por defecto
pasado el tiempo 'delay' en décimas de segundo.
Una vez hayas modificado este archivo, ejecuta lo siguiente:
root::/# lilo
Veras como te aparecen
por pantalla las particiones que hayas configurado para gestionar por lilo y
la que hayas colocado como 'defecto' aparece con un asterisco..
Otra versión del /etc/lilo.conf
boot=/dev/hda
# donde se instalará el LILO
compact
install=/boot/boot.b
map=/boot/map
vga=normal # pantalla en modo VGA
ramdisk=0 # no creamos disco virtual, necesario para crear los
# discos boot y root de la instalación
delay=50 # espera 10 segundos. [Ctrl] nos muestra las opciones
# que seleccionaremos escribiéndola
default=linux-2.0.32 # establece el SO que arrancará por defecto
image=/vmlinuz
# la imagen del kernel a arrancar
label=linux-2.0.30 # el nombre asociado
root=/dev/hdb1 # partición donde está la correspondiente imagen
alias=l # para abreviar en la selección
read-only
image=/boot/zImage-2.0.32
label=linux-2.0.32
root=/dev/hdb1
alias=z
read-only
other=/dev/hda1
table=/dev/hda # para que msdos encuentre la tabla de particiones
label=msdos
alias=m
----
Cuando has editado tu lilo.conf, para instalarlo tienes que ejecutar, como root,
# lilo
y se instalará
en el Master Boor Record de hda (en mi caso).
Debe ser una partición a la que tenga acceso la Bios del ordenador..
En Netscape los
ficheros .gz y .tgz en lugar de bajártelos te los muestra
Edit - Preferences - Navigator - Applications.
Buscamos en la
lista "Zip compressed data", pulsamos el botón "Edit",
en Suffix añadimos ",gz,tgz" y abajo seleccionamos "Save
to disk". Ok, Ok y listos :-). (Hue-Bond)
De esta forma cuando pinches uno de estos ficheros te preguntará si quieres
guardarlo, en lugar de intentar ejecutarlo.
El Netscape no hay ninguna opción para bajarse las news, pero con el siguiente truco se puede conseguir el mismo efecto:
Lo primero es crearse
dos nuevos directorios en el Message Center con "New Folder" (yo los
llamo Linux y Linux_Archive).
Abres el grupo es.comp.os.linux y le dices que te baje todos los mensajes. Después
en menú "View" marcas "Messages" y "News".
Eso expande todos los Treads.
Ahora los marcamos para bajarlos. Lo podemos hacer con menú "Edit",
"Select", "All" (o más rápido Alt+A). Y los
bajamos con "File" al directorio que hemos creado.
Sin cerrar la conexión debemos marcarlos todos como leídos. Para
ello "Mark" y "All Read". Y ahora podemos cerrar la conexión.
Para leerlos vamos a nuestro nuevo directorio Linux y los podemos ordenar cómo
queramos... "View", "Sort"... yo lo tengo en "By Subject".
Los que me interesan los archivo en el otro directorio que creé ("Linux_Archive")
y los que no a la papelera ("Delete").
Como seleccionamos la opción "View", "New", la próxima
vez que entremos en el grupo sólo nos bajará los nuevos mensajes.
Hacer que la diskettera solo puedan montarla los usuarios de un determinado grupo
$ ls -l /dev/fd0
brw-rw---- 1 root floppy 2, 0 ago 24 1997 /dev/fd0
$ grep floppy
/etc/group
floppy::11:root,srtxg,fab
$ grep nobody
/etc/passwd
nobody:*:99:99:nobody:/dev/null:
$ grep /dev/fd0
/etc/fstab
/dev/fd0 /mnt/floppy vfat user,noauto,uid=99,gid=11,umask=007
explicaciones:
* los permisos
sobre el device (hacerlo para todos los /dev/fd0*) evitan
que se pueda acceder usando los mtools si no se es miembro del
grupo floppy.
* en fstab se declara las opciones "user" (para que pueda ser montado
por gento no-root), "noauto" (para que no sea montado al arranque),
el uid y gid de los archivos y directorios vfat (yo elegí nobody
y group floppy), y por fin la máscara (007 significa permisos 770;
o sea rwxrwx---).
Si además
quieres impedir no solo el acceso a los datos, sino también el
uso de mount; cambia los permisos de mount y umount; algo así:
chown root.mount
/bin/*mount
chmod o-rwx /bin/*mount
chmod u+s /bin/*mount
y añade
al grupo mount todos los usuarios que quieras que puedan usar mount.
para montar el floppy (u otras cosas; todo lo que tenga "user" en
las opciones
en /etc/fstab)
Pablo Saratxaga
formato tipo msdos:
mformat a:
formato tipo ext2: fdformat /dev/fd0H1440
mkfs.ext2 /dev/fd0
Para Linux --> ext2
$ mkfs.ext2 [options] /dev/fd0
ó
$ mke2fs [options] /dev/fd0
El usuario que
formatea deberá tener permiso de escritura para
`/dev/fd0'. Eso normalmente se consigue añadiéndolo al grupo
`floppy' (addgroup user group).
Para msdos
$ mkfs.msdos [options] /dev/fd0
ó
$ mkdosfs [options] /dev/fd0
Pero también
hay otras utilidades para formatear discos
DOS. Mira a ver si tienes el paquete `fdutils', que permite
formatear los discos a mayor capacidad.
Cómo
hacer que linux reconozca ampliación de memoria
> He añadido
64 megas nuevos al aparato con lo que sumo 80 megas
> el problema es que linux solo me reconoce 64 ¿como hago para que
> reconozca los 80?
pon append="mem=80M"
en lilo.conf
o loadlin vmlinuz mem=80M
Una de las primeras dificultades con las que se topan los novatos es cómo ver y editar ficheros.
El "less" está más o menos bien aunque es un poco "soso". El "vi" puede ser un auténtico trauma.
Para los que acaban de llegar a linux puede que les sea interesante este "truco":
1) Instalar el
Midnight Commander.
2) Añadir en el ~/.bashrc estás líneas:
alias lee='mc -v ' #ojo, que hay un espacio detrás de la v.
alias edit='mcedit'
3) teclear "exit" e iniciar una nueva sesión.
A partir de entonces
se puede ver el contenido de un fichero con "lee fichero" (además
lee fichero comprimidos) y editarlo con "edit fichero".
La tecla F10 es para salir, y la tecla F9 para abrir el menú.
Bueno, esto es lo que he hecho yo, y me gusta más que less y vim, pero hay una pega, y es que no puedo pegar en el mcedit con el ratón lo que previamente he copiado en otro terminal.
(ricardovm)
Pues lo acabo de probar:
Mayúsculas
+ Botón Izquierdo: inicio de la selección
Mayúsculas + Botón Derecho: fin de la selección
Mayúsculas + Botón Central: pegar
NOTA: el bloque
así seleccionado se maneja de forma estándar: si desde otra consola
pulsamos el botón central del ratón, lo pegamos, etc.
Además el mc tiene su propia herramienta de selección de bloques
(F3, o May+Flechas), y con esto se puede copiar (Ctrl+Ins), cortar (May+Del)
y pegar (May+Ins) incluso de una sesión a otra, pues lo copiado (cortado)
se guarda en /.cedit/cooledit.clip.
Ambas herramientas se pueden usar simultánea e independientemente.
(tas@idecnet.com)
Instalar las X con Dselect de Debian.
Sesión de dselect. Como root pon dselect.
Dentro del menú ve a "[S]elect", te sale un mensajito de bienvenida y tal, pulsas la barra y ahora toca seleccionar paquetes.
Pulsa la "o" minúscula 2 veces y la mayúscula otras dos, con esto consigues que la lista de paquetes salga ordenada alfabéticamente.
Entonces ahora avanza páginas y páginas hasta encontrar el paquete "xbase" (creo).
Una vez ahí lo seleccionas pulsando la tecla "Ins" (si no lo tienes seleccionado ya, en cuyo caso esta parrafada te la saltas ;-)).
Probablemente dselect ahora te saque un mensaje diciendo "Che!! Y las dependencias qué?", pulsas la barra y ves abajo que pone
"xbase requires xserver-vga16" (por ejemplo),
entonces vas al xserver-vga16, que te aparece por ahí y lo "Ins"ertas,
aunque verás que dselect ya lo ha seleccionado él solito.
Para salir y volver a la lista de todos los paquetes pulsa Enter.
Ahora un poco más abajo te aparecen los servidores, añade el xserver-svga y el xserver-s3v (el de la ViRGE). Si te pregunta por dependencias pues eso, aunque dselect ya lo suele añadir todo.
Instala también algún gestor de ventanas adicional (por defecto se instalan el twm y el fvwm creo),a mí me encanta el icewm.
Para salir de la lista de paquetes, es con Enter de nuevo y vuelves al menú principal.
Selecciona "[I]nstall" y ve a tomar un cafecito rápido de 5 minutos.
Cuando acabe pulsas Enter, te aparece de nuevo el menú y te vas a Quit o Exit o lo que sea.
Ya tienes las X instaladas.
Ahora toca sesión de XF86Setup.
Configuras el mouse, el teclado (Model: Generic 102 keys Intl PC, Layout: Spanish), la tarjeta de vídeo (tienes 5 ViRGEs, ya sabes, a experimentar), en esa misma pantalla pulsas el botoncito que pone "Detailed setup", seleccionas el servidor S3V (la fila de botones de arriba), luego el monitor (mírate el manual para saber las frecuencias, yo le puse el 4º, el que empieza por Super VGA y me va bien), por último los modos de vídeo y listo, pulsa "Done" abajo (en la sección Other no hace falta tocar nada, aunque nadie te prohibe echar un vistacito.).
Tras eso te aparece un dialoguillo, pulsas "Okay" y ahora se arrancará el servidor.
Si rula, felicidades; si no... a por otra ViRGE. ¿Que ya has probado las 5? Pues en "Detailed setup" prueba el servidor SVGA.
¿Que tampoco rula? Pueeeees entonces ya pasa de castaño... no? (Hue Bond)
Acelerar la compilación del kernel.
He encontrado un truco que puede acelerar tremendamente el compilado del kernel de linux.
Cuando se da la orden de compilar en vez de :
make zdisk
hay que escribir
make -j5 zdisk
Esto inicia hasta 5 procesos de compilado simultaneos.
Idem con
make -j5 modules
Como descomprimir un .deb en una urgencia
Como desempaquetar un .deb en una urgencia.
Suelo trabajar
con varios sistemas Linux, distribuciones Slackware
en la facultad, Debian en el trabajo y Red Hat en casa. Al tener tanto
RedHat como Debian, tengo una cantidad de soft en formato rpm como .deb,
y en algun momento me he visto en la necesidad de instalar un .deb en la
REDHAT en casa, o un rpm en Debian o Slackware. Para estas cosas, lo mejor
es alien, un programa conversor de paquetes, pero solo viene por defecto en
la Debian. Asi que me vi en la dificultad de instalar un .deb en la RedHat
de mi casa. Asi que con la utilidad file, vi que era un archivo ar:
bash# file mctools-lite_970129-1.deb
mctools-lite_970129-1.deb: current ar archive Debian binary package
bash#
En el paquete
binutils, se incluye el programa ar, que se utiliza
para archivar ficheros en un solo archivo, algo asi como el tar, solo que
este ultimo esta especializado para streamers y esas cosas.... Con una
rapida miradita al man, averiguo que la opcion para descomprinir ar's es x,
de forma que tecleo:
bash# ar x ../mctools-lite_970129-1.deb
bash# ls -la
total 159
drwxr-xr-x 2 root root 1024 Jul 21 01:45 .
drwxr-xr-x 5 root root 1024 Jul 21 01:42 ..
-rw-r--r-- 1 root root 1276 Jul 21 01:45 control.tar.gz
-rw-r--r-- 1 root root 156567 Jul 21 01:45 data.tar.gz
-rw-r--r-- 1 root root 4 Jul 21 01:45 debian-binary
bash#
Si descomprimimos
el archivo control.tar.gz, encontramos los
siguientes ficheros:
bash# tar zxvf
../control.tar.gz
bash# ls -la
total 7
drwxr-xr-x 2 root root 1024 Feb 13 1997 .
drwxr-xr-x 3 root root 1024 Jul 21 01:48 ..
-rw-r--r-- 1 root root 1299 Feb 13 1997 checksums
-rw-r--r-- 1 root root 437 Feb 13 1997 control
-rwxr-xr-x 1 root root 264 Feb 13 1997 postinst
-rwxr-xr-x 1 root root 70 Feb 13 1997 postrm
bash#
En el fichero
control, se encuentra la informacion que nos suele
ofrecer el dselect cuando le pedimos informacion sobre un paquete. Los demas
ficheros tienen informacion sobre que hacer con el sistema antes y despues
de la instalacion. Para mas informacion, en las distribuciones debian
existen HOWTO's con todos los detalles sobre los paquetes debian.
En el archivo data.tar.gz, esta la aplicacion en si, que si se
descomprime a partir del fichero raiz colocara a todos los ficheros en sus
directorios correspondientes.
Este metodo se
debe usar como ultimo recurso, ya que los programas
instalados asi no podran ser desinstalados o actualizados con rpm ni con
dpkg, pero por lo menos, nos puede servir para salir de un apuro en un
momento dado :)
Un Chaludo.
ErConde/IdeaFix
| CoSysop de Kronos BBS | SpClub de la FIE | Sevilla
spectrum@bitsmart.com | Andres.Garcia@cs.us.es | garciaso@drago.fie.us.es
Trucos para recompilar el kernel.
Casi todos no hemos topado con la consabida configuracion del nucleo de Linux, seguida de su compilacion, instalacion, etc...
make config (menuconfig, xconfig)
make dep
make clean
make zImage
cp arch/i386/boot/zImage /boot/vmlinuz
cp System.map /boot
make modules
make modules_install
Bueno pues los pasos zImage y cp's los podemos olvidar editando el fichero Makefile que hay en /usr/src/linux, buscar :
#INSTALL_PATH=/boot
Descomentar la linea (¡ quitar la #, corcho !)
Para los que tienen su Linux mas personalizado que la Harley, podeis poner el directorio donde queries poner el nuevo kernel, ese directorio debe corresponderse al que pone en el /etc/lilo.conf.
Una vez hecho esto, se puede reemplazar el make zImage y cp's por make zlilo.
Datos del autor/a:
Nombre: Manuel Soriano.
Para lanzar un proceso y luego poder matar el shell padre, solo debemos hacerlos de la siguiente manera:
nohup proceso &
por ejemplo si queremos lanzar licq con el parámetro -p \qt-gui la linea correspondiente seria la siguiente:
nohup licq -p \qt-gui &
Creando alias para montar y desmontar el CD-ROM
Para ahorrarnos tiempo al momento de montar y desmontar el CD podemos aprovechar una de las propiedades del shell bash, esto es definir alias, para ello solo tenemos que agregar en el archivo .bashrc que se encuentra en nuestro directorio home las lineas:
alias cdr='mount
-t iso9660 /dev/cdrom /mnt/cdrom -r'
alias ucdr='umount /cdrom'
Donde, /dev/cdrom especifica el dispositivo correspondiente a nuestro CD-ROM, y /mnt/cdrom debe ser un directorio vacío.
Caracteres en español en el shell
Para poder visualizar todo el set de caracteres españoles en Linux solo debemos agregar la siguiente línea a uno de los archivos de inicialización del sistema, por ejemplo /etc/profile, en algunas distribuciones esta línea ya esta incluída y solo debemos modificarla:
/usr/bin/setfont /usr/lib/kbd/consolefonts/lat1u-16.psf
Según las distribución que usemos los archivos con los sets de caracteres se ubican en distintos lugares, por ejemplo en Debian están en /usr/share/consolefonts/
Agregando en el archivo .bashrc de nuestro directorio home (/root si nos logeamos como usuario "root") la siguiente función dispondremos de un prompt mas atractivo que el común:
function promptmio
{ PS1="\[\033[31m\]\332\304\[\033[34m\](\[\033[31m\]\u\[\033[34m\]@\[\033[31m\]\h\
\[\033[34m\])\[\033[31m\]-\[\033[34m\](\[\033[31m\]\$(date +%I:%M%P)\ \[\033[34m\]-:-\[\033[31m\]\$(date
+%m)\[\033[34m\033[31m\]/\$(date +%d)\ \[\033[34m\])\[\033[31m\]\304-\[\033[34m]\\371\[\033[31m\]-\371\371\
\[\033[34m\]\372\n\[\033[31m\]\300\304\[\033[34m\](\[\033[31m\]\W\[\033[34m\])\
\[\033[31m\]\304\371\[\033[34m\]\372\[\033[00m\]"
PS2="> " }
Luego solo tenemos que salir de la sesión en curso y volver a entrar para finalmente llamar a la función mediante: promptmio
Búsqueda Rápida de Archivos en Disco
En Linux contamos con una utilidad muy poco conocida , llanmada locate que nos permite consultar en una base de datos con los nombres y las ubicaciones de todos los archivos de nuestro sistema ,esta base de datos se actualiza desde el Cron y su uso es tan sencillo como poner por ejemplo ,locate Profile ,lo que nos dara la ubicacion exacta de este archivo .
Economizando 800K de Ram de X-Window
Una buena forma de ahorrar aproximadamente 800K de Ram al arrancar X-Window es hacerlo de la siguiente manera : Exec startx Con esto lanzaremos Starx matando el proceso padre ,es decir el Shell.
Páginas del Manual en castellano
Para poder tener
el manual en español seguimos estos pasos :
Bajamos el archivo con la ultima version de las Man.
Descomprimimos el archivo en un directorio desde donde se realizara la instalacion
con : tar xvfz man-pages-es0.7a.tar.gz
ingresamos en el directorio que se creo y ponemos make install. Editamos el
directorio /etc/profile para especificar que de prioridad al lenguaje español
agregando export LANG=es_ES .
Salimos de Shell y volvemos a entrar y ya tendremos las paginas del manual en español.
Para configurar
nuestro teclado español para utilizarlo bajo Linux ,debemos usar un programa
llamado Loadkeys ,mediante el cual podremos cargar el mapa de teclado :es.map.gz
que se encuentra en el directorio /usr/share/keymaps/i386/qwerty. La siguiente
linea es la que deberiamos incluir en uno de los guiones de nuestro sistema:
loadkeys/usr/share/keymaps/i386/qwerty/es.map.gz
& manda a
2º plano
jobs muestra trabajos en 2º plano
kill %numero mata [...]
kill numero mata PID
ctrl+c mata
ctrl+d termina
ctrl+z pausa
fg %numero relanza tarea a 1ºplano
bg %numero relanza tarea a 2ºplano
entorno entorno
del sistema
incorporadas proporcionadas por el sistema, no modificables
usuario modificables en la shell
$echo $PATH rutas de comandos
ejecutables
$a=playa variable local
$echo $a visualiza variable local
export muestra variables
exportadas
export a variable a global
r lectura
w escritura
x ejecución
-r--r--rw- 1 usuario grupo 505 mar...
-{-(fichero) d(directorio)}r--{propietario}r--{grupo}rw-{usuario}
chmod {a(all),u(user),g(group),o(other)}{+,-}{r,w,x} fichero modo absoluto
r 4
w 2
x 1
chmod 644 fichero modo octal
ln crea enlaces
ls -i número inodo
$ls -i dietas
22192 dietas
$ln dietas restaurantes
enlaces duros en mismo sistema de ficheros
$ls -i
22192 dietas
22192 restaurantes
-rw-r--r-- 2{número enlaces al fichero}
ln -s fichero1
fichero2 enlace simbólico, no influye los permisos del enlace
fichero2->fichero1
Esta aplicación que sabrán apreciar todos aquellos que gusten de usar la consola: Cambia entre diferentes programas desde un solo terminal en vez de estar con varios terminales para poder usar múltiples programas a la vez en consola.
screen arrancamos la aplicación,
y ahora:
C^a c crea una nueva 'ventana'
C^n ó C^p cambias entre las 'ventanas'
C^a Esc permite mover el cursor por el terminal
exit cierras todas las sesiones ('ventanas') y la aplicación screen se
cierra
Bueno vale, no esta mal,
buff, pim, pam... pues NO!! aún queda lo mejor: Si cierras la aplicación
screen, cerrando la conexión en ssh, dando a la X en tu gestor de ventanas
o ... no pasa nada, todas las aplicaciones que tenías abiertas siguen
estándolo y puedes volver a usarlas.
screen -list ejecutado en una sesión normal de consola, nos devuelve
las screen que se están ejecutando
rubenr@petalo:~$ screen -list
There is a screen on:
840.pts-0.petalo (Attached)
1 Socket in /var/run/screen/S-rubenr.
screen -Dr 840 para recuperar esta screen, debes cambiar el 840 por la correcta
en tu caso
Si por alguna razón se traba y no acepta ninguna tecla, será porque has pulsado una combinación errónea, C^q ó C^s lo solucionan. Recomiendo man screen para sacar más provecho a esta fantástica aplicación.
Escribiendo el símbolo del euro en KDE
Lo único que debemos cambiar, o al menos cambiándolo yo he conseguido escribir el símbolo del euro, es el /etc/environment. Según Ricardo debería ser:
LC_ALL=es_ES@euro
LANG=es_ES.ISO-8859-15
LANGUAGE=en_US
LC_TYPE=es_ES@euro
Buscando por google, encontré una lista de correo en la que también se discutía sobre el tema y decían que para que funcionara las líneas de LANG y LC_ALL debían ser exactamente:
LC_ALL=es_ES@euro
LANG=es_ES@euro.ISO8859-15
Podemos ver que el valor de LANG difiere ligeramente del indicado en el artículo de Ricardo.
La verdad es que cambiando estas líneas y siguiendo el artículo de Ricardo, a mi me ha funcionado (una vez reiniciado el servidor X, por si las moscas ;-)
Si quieres que los mensajes del sistema (y las páginas del man) te aparezcan en inglés, añade la línea LANGUAGE=en_US en el fichero /etc/environment
Scroll del ratón en linux fácilmente
En Xfree versión
4 edita este fichero /etc/X11/XF86Config-4
y añade o cambia en la sección"InputDevice" Mouse0 estas
lineas:
Option "Protocol"
"IMPS/2"
Option "Buttons" "5"
Option "ZAxisMapping" "4 5"
Ahora graba sal y reinicia las X
La ruedecita ya deberia funcionar.
Recopilación de teclas rápidas del bash
Empezaremos con las que pudimos sacar de nuestros conocimientos:
* ^d (ctrl-d):
Envía un EOF (final de fichero) a la shell que causa un logout.
* ^c (ctrl-c): Termina el proceso que esté en ejecución.
* ^z (ctrl-z): Pone el proceso en ejecución en sleep, pudiendo volver
a el con, por ejemplo, fg.
* ^l (ctrl-l): Realiza un clear (borrado de la pantalla) pero manteniendo la
linea en la que fue pulsada esta combinación de teclas.
* ^t (ctrl-t): Intercambia dos letras contiguas. Por ejemplo, supongamos que
escribes apt-gte, pues te colocas en la 'e', le das a ^t y problema disléxico
(más común de lo que pudiera parecer ;-) solucionado.
* ^r (ctrl-r): El bash entra en el modo 'reverse-i-search', que se utiliza para
buscar comandos que fueron ejecutados anteriormente. En este modo el usuario
puede ir escribiendo parte de la linea de comandos que esta buscando, y el bash
va mostrando la línea de comandos que el cree la más adecuada.
Una vez has encontrado la que buscabas, enter.
* ^s (ctrl-s): Bloquea la shell.
* ^q (ctrl-q): Desbloquea la shell.
Pero aquí no acaba la cosa, ahora unos cuantos que he encontrado probando
y/o buscando por el google:
* ^a (ctrl-a):
Desplaza el cursor al inicio de la línea de comandos.
* ^e (ctrl-e): Desplaza el cursor al final de la línea de comandos.
* ^u (ctrl-u): Corta la linea de comandos desde la posición del cursor
hasta el inicio de la línea. El texto cortado se guarda en una especie
de "portapapeles", pudiendo realizar un paste (ver más abajo)
* ^k (ctrl-a): Igual que ^u pero desde el cursor hasta el final de la línea.
* ^y (ctrl-y): Pega el texto que previamente había sido cortado con ^u
o ^.
* ^b (ctrl-b): Desplaza el cursor una posición hacia la izquierda, como
si usaramos la flecha hacia la izquierda de los cursores.
* ^f (ctrl-f): Desplaza el cursor una posición hacia la derecha, como
si usaramos la flecha hacia la derecha de los cursores.
* ^p (ctrl-p): Se desplaza por el histórico de la línea de comandos
hacia atrás, como si utilizaramos la flecha hacia arriba de los cursores.
* ^n (ctrl-n): Se desplaza por el histórico de la línea de comandos
hacia delante, como si utilizaramos la flecha hacia abajo de los cursores.
Hay otras teclas rápidas que han sido aportadas por los comentarios a
este artículo:
* ^w (ctrl-w): Corta desde la posición actual del cursor hasta el primer espacio que encuentra hacia la isquierda.
Finalmente he encontrado una combinación de teclas que me ha funcionado
desde el las X (provado en konsole y xterm), pero que no me ha funcionado en
la consola: ^_ (ctrl-_) que lo que hace es un undo o deshacer.
Insto a que si alguien encuentra alguna combinación de teclas más nos lo haga saber.
Haciendo Imágenes de CD rápidamente
Muchas veces usamos programas gráficos para grabar CDs que no son más que frontends para los programas cdrecord, mkisofs, cdrdao, etc. Para hacer una imagen podemos usar simplemente cat o dd:
dd if=/dev/cdrom of=imagen.iso
Gracias a kyle
por esta:
cat /dev/cdrom > imagen.iso
Ambos comandos hacen lo mismo, después, tostamos con cdrecord o con lo que queramos:
cdrecord -v speed=VELOCIDAD dev=GRABADORA imagen.iso
Si alguien ha probado a hacer dd if=imagen.iso of=/dev/GRABADORA y le ha funcionado, que me lo comunique por favor ;-)
Si somos un poco vagos y no nos apetece hacer clear, no tenemos más que presionar la combinación de teclas Ctrl+L.
Si queremos evitar que los usuarios puedan usar esta combinación de teclas nos vamos a /etc/inittab y ponemos una almohadilla # de comentario en la siguiente linea:
ca::ctrlaltdel:/sbin/shutdown -t3 -r now
Pero si lo que queremos es que sólo determinados usuarios puedan usarlo, modificamos esa línea y la ponemos así (sin la # de antes):
ca::ctrlaltdel:/sbin/shutdown -a -t3 -r now
y creamos un archivo nuevo /etc/shutdown.allow con los nombres de usuarios que nos interese:
phantom
usuario
invitado
Está claro que si cambiamos ese -r por un -h nos apagaría el equipo, y bueno, para más opciones: man shutdown. Aun así, podríamos incluso poner otro comando, como que nos muestre un mensajito en consola y mil chorradas como esa, o no tan chorradas... a preferencia de cada uno.
Ver un documento de Microsoft Word en modo texto
Pues si no nos
apetece entrar a las X para ver un documento de estos o simplemente no queremos/podemos
cargar el openoffice, abiword y similares, nos bajamos el programita antiword
que nos muestra por pantalla el texto del documento word.
Este programa tambien permite salida en formato postscript, veamos un ejemplo:
Para ver el contenido en modo texto:
antiword cosa.doc | less
Convertimos a postscript con tamaño de página A4 y lo visualizamos con gv:
antiword -p a4 cosa.doc > cosa.ps ; gv cosa.ps
Para los de Debian:
apt-get install antiword
Para conectar a Internet a través de Linux, y con pppd, hay que seguir los siguientes pasos:
-Editar el archivo /etc/ppp/options donde se ha de poner lo siguiente :
connect /etc/ppp/conexinet
crtscts
modem
passive
user nom_usuario@servidor
noipdefault
debug
defaultroute
asyncmap a0000
/dev/modem
57600
Se debe cambiar nom_usuario@servidor por el login de conexion a Internet. 57600 es la velocidad del módem , hay que poner la que corresponda. /dev/modem puede que se tenga que cambiar por /dev/ttyS0 o ttyS1 según el puerto del módem, la equivalencia con Windows es: ttyS0 = COM1 ; ttyS1 = COM2
-Crear un archivo de texto que se llame conexinet (o el que hayamos puesto en la línea connect /etc/ppp/archivo) con el siguiente contenido:
#!/bin/sh
chat -v "" atdtw(n: de conexion) CONNECT ""
El número de conexión es el facilitado por el proveedor de Internet. El de Infovía de antes era 055, por lo que quedraría asi:
chat -v "" atdtw055 CONNECT "".
Hay que asignar permisos de ejecución a este fichero, escribiendo en la línea de comandos:
chmod 755 conexinet
-Borrar el contenido del fichero pap-secrets y poner :
nom_usuario@servidor * password
El nombre de usuario y servidor es igual que el especificado en options, un * y la contraseña de conexión a Internet. Este fichero debe ser de sólo lectura y modificable por el usuario root, para conseguir esto hay que hacer lo siguiente:
chmod 600 pap-secrets
-Editar /etc/resolv.conf donde sólo tiene que aparecer :
domain servidor.es
nameserver Ip_DNS_Primario
nameserver Ip_DNS_Secundario
En servidor.es hay que poner el nombre de dominio de nuestro servidor. En los nameservers se deben especificar las direcciones de los servidores DNS.
Para conectar hay que escribir en la línea de comandos:
pppd
Para finalizar la conexión basta con poner en la línea de comandos :
killall pppd
Si la conexión da algun error. Por ejemplo: conecta y a los pocos segundos se desconecta repentinamente. Probar quitar la w de atdtw ( atdt ).
Esta conexión sólo funcionará ejecutando pppd como usuario root. En caso de que se quiera utilizar como otro usuario hay que hacer lo siguiente:
-Crear un link en el directorio /bin o /usr/bin de los archivos /usr/sbin/pppd y /usr/sbin/chat. Esto se hace porque para los usuarios no root es imprescindible ejecutar los comandos de /sbin usando ./comando, por lo cual ,en el script no funcionará la orden chat -v .... y lo de pppd , es para evitar tener que ir al /usr/sbin y poner ./pppd , y de esta forma poder hacerlo como queramos.
-Poner el pppd con suid: chmod +s pppd desde el directorio /usr/sbin. Asignar permisos de ejecución a /usr/sbin/chat: chmod 755 chat desde /usr/sbin.
Con ésto debería de estar bien, pero en Red Hat 6.0 da una serie de fallos que hay que solucionar como sigue:
Si se hace tail -f /var/log/messages se podrá ver que no se consigue realizar la conexión correctamente debido a fallos del tipo unsuport protocol, etc..
Para solucionarlo hay que poner las siguientes líneas en el fichero /etc/conf.modules
alias ppp-compress-21
bsd_comp
alias ppp-compress-24 ppp_deflate
alias ppp-compress-26 ppp_deflate
Arrancar Linux con NTLoader (gestor de arranque NT/XP)
Si tenemos un sistema con NT o XP y usamos el gestor de arranque que estos incorporan para seleccionar entre XP y 98, por ejemplo, no es necesario perder ese sistema de arranque ni tocar el MBR para poder arrancar también Linux, y de paso, evitamos riesgos innecesarios en los cambios de configuración de arranque.
Como requisito, Linux ha de estar en una partición primaria, no servirá si lo tenemos en una partición extendida, pues allí no va a poder alojar su propio cargador en la partición que ocupa. Las particiones primarias son las que tengan un número igual o inferior a 4.
Suponiendo que la partición root de Linux es /dev/hda2 (segunda partición primaria del primer disco IDE), debemos instalar en ella (no en el MBR, ni en /dev/hda) uno de sus gestores de arranque habituales, como GRUB o LILO.
Teniendo el sistema en estas condiciones, ya desde Linux y como root, copiamos a un archivo el sector de arranque:
dd if=/dev/hda2 of=/bootsect.lnx bs=512 count=1
Movemos el archivo /bootsect.lnx recién creado a la partición iniciadora de Windows (si la tenemos montada), o a un diskette en caso contrario, del que luego lo copiaríamos a C:\ :
mv /bootsect.lnx
/mnt/win_c/
/mnt/win_c sería la partición del Windows que inicia.
Desde Windows ahora, al archivo C:\boot .ini, le agregamos una entrada para que cargue Linux, basada en el archivo que le hemos agregado. Como probablemente esté oculto, primero le quitamos los atributos:
attrib -s -h c:\boot.ini
Editamos ya el boot.ini, agregándole una línea indicando la carga de Linux, dentro de la sección [operating systems], que diga:
C:\bootsect.lnx="Linux"
Grabamos el archivo modificado y le devolvemos sus atributos:
attrib -s -h c:\boot.ini
En el siguiente reinicio, ya dispondremos de opción de cargar Linux desde el mismo menú que teníamos los Windows.
¿Cómo
puedo saber si un usuario está intentando entrarme por telnet?
Existen dos formas:
1- Se puede estar todo el rato tecleando la w y mirando quién está y qué hace en cada momento, pero no es lo recomendable.
2- En el archivo /etc/hosts.allow poner como tercer parámetro un comando, el que se quiera, y que le avise. Yo lo tengo para que haga un sonido cada vez que alguien conecta por telnet.
Por ejemplo, yo tengo esto en el /etc/hosts.allow:
ALL: ALL: spawn ( cat /usr/share/sounds/meepmeep.au > /dev/audio ) ; : ALLOW
que deja que se usen los servicios del inetd a todos, pero cuando alguien abra un puerto, ejecute el comando dado (saca un sonido).
Ver los directorios en colores con bash
El bash posee una propiedad muy interesante y útil mediante la cual es posible ver el listado de los archivos en colores diferentes que los identifican según su tipo.
Por ejemplo los ejecutables se ven en verde, los comprimidos en rojo, etc.
Para poder usar esta propiedad, hay que pasarle al comando ls el parámetro: --color=auto,
Y para que quede de forma permanente hay que definir en el archivo .bashrc los siguientes alias y variables de entorno:
eval `dircolors`
alias ls='ls $LS_OPTIONS'
alias ll='ls $LS_OPTIONS -l'
alias l='ls $LS_OPTIONS \lA'
Con esto estamos redefiniendo el "ls" y creando dos nuevos alias, "ll" y "l".
Cambiar
el logo en el arranque de Linux
Versión para kernels 2.4
Todos hemos visto como muchas instalaciones de Linux presentan una imagen en la parte superior izquierda de la pantalla durante el arranque; por ejemplo la estrella de Mandrake, Tux con una cerveza en Woody,...
Si queremos hacer algo de "tunning linuxero", podemos incluir una imagen personalizada en nuestra instalación:
Necesitaremos:
1.- Un logotipo (obvio, ¿verdad?
2.- En fuente del kernel 2.4.x que vayamos a compilar. (próximamente
para la familia 2.6)
3.- El programa "fblogo"
4.- Un Gimp o similar.
5.- El editor de texto favorito de cada uno.
Para comenzar, tendremos que tratar nuestro logo. Para ello símplemente
tomaremos la imagen, cambiaremos el fondo a negro (recomendable pero no necesario)
y la guardaremos en formato PNG con 223 colores como máximo y el tipo
de color como indexado.
A continuación utilizaremos en programa fblogo para generar un archivo que utilizaremos en nuestro kernel mediante la orden "fblogo milogotipo.png linux_logo.h"
Copiamos el archivo "linux_logo.h" dentro del directorio donde hayamos descomprimido los fuentes del kernel, por ejemplo /usr/src/linux/include en la mayoria de los casos.
Abrimos el archivo drivers/video/fbcon.h
con nuestro editor (por ejemplo 'joe', mi favorito o 'kate' en KDE) y cambiamos
las lineas que definen el alto y ancho en pixeles del logo:
#define LOGO_H <mi_tamaño_en_pixeles_de_alto>
#define LOGO_W <mi_tamaño_en_pixeles_de_ancho>
A continuación compilaremos el kernel, sin olvidarnos de añadir soporte para FrameBuffer, instalamos... y listo!!!
Ya tendremos nuestra imagen favorita durante el arranque del sistema.
Sólo un consejo para
acabar: CUIDADO CON EL TAMAÑO!!!!.
No olvideis que el gráfico estará incluido dentro del núcleo,
y eso ocupa espacio en memoria.
Cambiar
el logo en el arranque de Linux
Versión para kernels 2.6
Cambiar la imagen que nos aparece en el arranque de un kernel 2.6 es algo más simple que en los núcleos 2.4.
Necesitaremos:
1.- El logotipo
2.- En fuente del kernel 2.6.x que vayamos a compilar.
Crearemos nuestra imagen con nuestro programa favorito (como buenos linuxeros que somos usaremos Gimp :wink: ), y la guardaremos en formato PNG.
A continuación ejecutamos los pasos siguientes:
1.- Ejecutar "convert
logo.ext temporal1.ppm
2.- ppmquant 224 temporal1.ppm > temporal2.ppm
3.- pnmnoraw logo_passo2.ppm > logo_linux_clut224.ppm
Este logo lo copiaremos
dentro del directorio donde hayamos descomprimido el kernel de Linux.
En mi caso, he utilizado un kernel 2.6.5 (en el 2.6.6 no me funcionaba bien
la tarjeta de sonido), así que lo que hacemos sería:
cp logo_linux_clut224.ppm /usr/src/kernel-source-2.6.5/drivers/video/logo/.
Seguidamente, configuraremos
el núcleo con las opciones que necesitemos para nuestro hardware.
Además tendremos que añadir el soporte de Framebuffer en el mismo:
Dentro de "Device Drivers", nos vamos a "Graphics Support"
y aqui encontraremos al final de la lista dos entradas: "Console display
driver support" y "Logo configuration".
En "Console display driver support", seleccionaremos las opciones
"Video mode selection support", "Framebuffer Console support",
"Select compiled-in fonts", y "VGA 8x16 font"
Dentro de "Logo configuration", seleccionamos "Bootup logo" y "Standard 224-color linux logo".
Salimos, salvamos la configuración, compilamos e instalamos el kernel.
Sólo con esto, en el próximo arranque que realicemos veremos como Tux se ha reemplazado por la imagen de nuestra elección.
Obligar a reiniciar cuando ocurre un Kernel Panic
Esto lo que hace es que si hay un kernel panic espera x segundos y luego reinicia la máquina.
#cat /proc/sys/kernel/panic
0
El valor devuelto indica los segundos que esperará el kernel antes de reiniciar. El valor '0' indica que no se reiniciará nunca.
Si queremos habilitarlo, por ejemplo con 10 segundos de espera:
# echo "10" > /proc/sys/kernel/panic
Podemos comprobar el cambio con:
#cat /proc/sys/kernel/panic
10
Este cambio no es permanente, por lo que, si queremos que lo sea, deberemos modificar el archivo /etc/sysctl.conf.
# echo "kernel.panic=10" >> /etc/sysctl.conf
También podemos pasarlo como parámetro durante el arranque, añadiendo 'panic=10' en nuestro cargador de arranque (grub o lilo).
Recientemente me he comprado un dispositivo de almacenamiento USB en memoria flash y aunque el rendimiento en lectura es "razonable" (960KB/s, de un máximo teórico de 1.4MB/s), la escritura es muy lenta. En mi máquina SUSE 10.0, escribo en ese dispositivo a unos 200KB/s. Es decir, unas cinco veces más lento de lo que debería.
Lo primero es descartar que el dispositivo USB tenga algún tipo de defecto, cosa que se comprueba con facilidad conectando el dispositivo a una máquina Windows. La comprobación experimental fue grabar 30 megabytes en la memoria USB, proceso que supuso un minuto de tiempo, aproximadamente. Es decir, unos 500KB/s, poco más o menos.
Así pues, la grabación es bastante lenta, pero en mi linux Suse es incluso más lenta todavía. Desesperantemente lenta, de hecho. ¡¡Llenar el gigabyte de capacidad de la memoria USB me supone casi una hora y media!!.
Investigando el asunto con detenimiento y la ayuda de Google, veo que el problema es que el subsistema "submount", utilizado por SUSE y otras distribuciones Linux para gestionar dispositivos removibles como USB o CDs/DVDs, "monta" los dispositivos USB con la opción de "sync".
Utilizar la opción "sync" tiene su lógica para así poder desenchufar el USB sin necesidad de realizar una operación explícita en el GUI, como la típica aplicación de Windows para "desenchufar dispositivo de forma segura". En Linux SUSE (y posiblemente otras distribuciones que empleen "submount"), se puede desenchufar el USB directamente porque el dispositivo se monta con la opción "sync", que implica que cuando escribimos algo se fuerza inmediatamente al dispositivo, sin pasar por la caché interna del sistema previamente. Por tanto, en cuanto el ordenador nos dice que ha terminado de grabar algo, realmente ha terminado de grabar en el dispositivo. De verdad.
El problema es que "sync" implica escrituras síncronas en el USB o, lo que es lo mismo, no envía al dispositivo el bloque X hasta que éste no haya confirmado que ha almacenado correctamente el bloque X-1. Ello supone un gran desperdicio de ancho de banda USB (y por tanto, tiempo de grabación), a cambio de ganar comodidad y conveniencia. Asimismo, puede haber efectos de segundo orden debido a que las memorias flash tienen un número de escrituras limitados, y en modo síncrono un sector determinado puede reescribirse varias veces durante una sesión de grabación.
Para comprobar si es el caso en vuestros sistemas, probad a conectar un dispositivo de almacenamiento USB, montadlo (o dejad que lo haga el sistema, si es automático), y ved el resultado. En Linux SUSE 10.0, que utiliza "submount", parecerá algo parecido a:
# mount
...
/dev/sdb1 on /media/usbdisk type subfs (rw,nosuid,nodev,sync,fs=floppyfss,procuid,utf8=true)
El punto delicado es el "sync" resaltado en el listado anterior.
Una vez localizado el problema, la solución es muy simple. Basta con montar el dispositivo manualmente, pero indicándole que queremos utilizar escrituras asíncronas, más rápidas pero que exigen desconectar el USB de forma "controlada" (más sobre esto después).
La primera opción es desmontar el dispositivo y montarlo manualmente, con las opciones que nos interesan:
# mount
...
/dev/sdb1 on /media/usbdisk type subfs (rw,nosuid,nodev,sync,fs=floppyfss,procuid,utf8=true)
# umount /media/usbdisk
# mount -t subfs /dev/sdb1 /media/usbdisk -o rw,nosuid,nodev,fs=floppyfss,procuid,utf8=true
# mount
...
/dev/sdb1 on /media/usbdisk type subfs (rw,nosuid,nodev,fs=floppyfss,procuid,utf8=true)
En el ejemplo anterior primero vemos las opciones con las que se monta el dispositivo USB. Seguidamente lo desmontamos manualmente y lo volvemos a montar con las mismas opciones que acabamos de ver PERO eliminando el modo "sync". Volviendo a visualizar las opciones, vemos que ya no aparece "sync". Como debe ser.
Otra opción más limpia es utilizar las funcionalidades "remount" de los kernel Linux modernos, para realizar las operaciones de forma más simple:
# mount
...
/dev/sdb1 on /media/usbdisk type subfs (rw,nosuid,nodev,sync,fs=floppyfss,procuid,utf8=true)
# mount /media/usbdisk -o remount,async
# mount
...
/dev/sdb1 on /media/usbdisk type subfs (rw,nosuid,nodev,fs=floppyfss,procuid,utf8=true)
Usemos la opción que usemos, si nuestro sistema emplea "submount" (el tipo de ficheros "subfs", como se puede ver en los ejemplos anteriores), el sistema operativo desmontará automáticamente el dispositivo USB cuando lo desenchufemos, como siempre.
No obstante, ahora tenemos que asegurarnos de que los datos se han almacenado realmente en el dispositivo de almacenamiento USB, ya que ahora las escrituras pasan por la caché de disco interna de Linux. Para ello hay varias opciones. Por ejemplo, en el escritorio KDE de SUSE hay un menú para "desenchufar de forma segura", muy semejante a Windows (aunque con la configuración estándar de SUSE, al emplear escrituras síncronas, es innecesario). Otra opción, ya que tenemos una ventana de terminal abierta, es utilizar el comando "sync" de Unix para asegurarnos de que todos los datos modificados en la caché de escritura de Linux son volcados a los sistemas de almacenamiento del ordenador. Este comando puede tardar bastante tiempo en "terminar" (lo que tarde en grabar todo lo pendiente que mantenía en RAM, la caché), pero cuando acabe significará que no queda nada pendiente y podemos desenchufar el USB sin problemas.
Por tanto, utilizando un simple comando "mount /media/usbdisk -o remount,async" consigo pasar de grabar a una velocidad de 200KB/s a grabar a 560KB/s. Casi tres veces más rápido. E igual de rápido que con Windows.
Por supuesto las velocidades concretas dependerán de cada dispositivo USB. El mío es bastante "cutre", ya se ve, porque incluso a su velocidad de "pico" graba a la mitad de la capacidad del estándar USB 1.1. Pero menos da una piedra...
Pero vuelvo a reiterar: ¡mucho cuidado con asegurarnos de que todos los datos se han grabado en el dispositivo de almacenamiento USB ANTES de desenchufarlo del ordenador!. Recuerda utilizar el comando "sync" o similares, al terminar la grabación.
El único efecto secundario de trabajar en modo asíncrono, aparte de requerir que seamos cuidadosos, es que una vez que el sistema nos dice que ha terminado de grabar, todavía puede tardar varios minutos en completar realmente todas las operaciones pendientes que contenga en su caché en RAM. Y el acceso de lectura a un dispositivo USB mientras se está grabando en él a toda velocidad, suele ser bastante lento y poco cómodo. Por ejemplo, si durante la grabación pulsamos "cancelar", aún se pueden almacenar muchos megas adicionales y podemos tener que esperar fácilmente un minuto o dos hasta que realmente aborta la operación. Exactamente igual que en Windows...
- Trucos Visual Basic
- Trucos Visual Basic II
- Manual Visual Basic .NET
- Manual C#
- Atajos de Teclado en Gmail
- Atajos de Teclado en Photoshop
- Atajos de Teclado en Windows
- Atajos de Teclado en Windows 7
- Atajos de Teclado en Windows 8
- Atajos de Teclado en Excel
- Atajos de Teclado en Word
- Atajos de Teclado en Access
- Atajos de Teclado en Power Point
Todo sobre Windows