Administracion Linuxl

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 153

CIC -IPN

Administracin LINUX

M. en C. ALEJANDRO SOTO RAMOS CENTRO DE INVESTIGACION EN CMPUTO IPN

Historia De LINUX
La historia de LINUX inicia con el desarrollo de un pequeo programa llamado Minix, un sistema operativo tutorial, escrito por el cientfico Andrew Tannebaum, este sistema operativo gano popularidad siendo desarrollado para poder trabajar en diferentes plataformas de equipo de cmputo lo que inspiro al desarrollo de LINUX.

En la dcada de los 60s cuando todo el software se mantena en una arquitectura cerrada dictada por el diseo de cada productor de hardware los Laboratorios Bell de AT&T en conjunto con GE trabajaron en el MIT en un proyecto llamado MULTICS (Servicio de computo de informacin Multiplexada) un antiguo sistema de tiempo compartido el cual tenia como finalidad proporcionar un soporte para diferentes arquitecturas de hardware compartiendo los recursos de hardware y software y as poder eliminar el concepto de arquitectura cerrada

En el ao de 1969 el proyecto MULTICS fracasa por su alta demanda de espacio requerido en disco duro y memoria RAM, lo cual evita que el proyecto sea financiable, abandonndolo en este ao. Kenneth Thompson y Dennis Ritchie, ingenieros de laboratorios BELL deciden continuar con el proyecto por su cuenta, desarrollando herramientas de programacin que les permitieron tener un mejor desempeo de los programas diseados por ellos mismos.

Kenneth Thompson desarrolla un lenguaje de programacin de bajo nivel al cual le llam lenguaje B, ste es analizado y mejorado por Dennis Ritchie, desarrollando un lenguaje de programacin ms potente y robusto al cual le llamaron C, el cual se ha mantenido desde entonces hasta la fecha como un lenguaje de programacin de excelencia para los diseadores de programas que tienen un alto nivel de interaccin con el hardware.

Para el ao de 1971 es lanzada la segunda versin de UNIX, esta versin se diseo en lenguaje C, lo que le permiti la portabilidad entre las diferentes arquitecturas de hardware, de este modo se inicia el diseo de la arquitectura abierta en los equipos de cmputo. En el ao de 1983 Novell compra UNIX a AT&T y lo registra con el nombre de System V obteniendo todos los derechos sobre el producto.

El nombre de UNIX se desprende de una aberracin de Multics, ya que unix inicio como un proyecto menos ambicioso el cual slo poda ser usado por una persona, donde cada parte del sistema estaba diseada para hacer solo una cosa y hacerla bien, de aqu el nombre; uni que quiere decir mono o uno seguido de la letra X homfona

UNIX surgio en 1969 en los Laboratorios Bell (Ken Thomson,Dennis Ritchie) Dos grandes vertientes BSD: SunOS, NetBSD, OpenBSD, Mac OS System V: Solaris, Iris, Aix, Linux (ao 1991) Distribuciones Linux Slackware Gentoo Suse RedHat y derivados: Fedora, Mandriva (Mandrake) Debian y derivados: Ubuntu, knoppix, GnuLiNex

Introduccin a GNU/Linux

Posteriormente en 1990 un estudiante Finlands inicio un proyecto personal basado en Minix, un sistema operativo tipo UNIX, su intencin era desarrollar un sistema compatible con plataforma PC el cual fuera ms confiable que Minix, comenz creando drivers para dispositivos de hardware en lenguaje C mejorando su plataforma, para 1991 libera la primera versin de Linux sin ser una distribucin oficial, la 0.01

Caractersticas De LINUX
Es un sistema operativo de tiempo compartido Multiusuario Multitarea Multiproceso Multiplataforma Modular Portable entre sistemas abiertos Programable Es un sistema tipo cliente - servidor

Filosofa De LINUX
Su forma modular lleva a su filosofa Principal Entre ms pequeo mejor. Permite la reduccin de esfuerzo combinando las herramientas. Es un sistema personalizable de a cuerdo a las necesidades de cada usuario.

Plataformas y Distribuciones Ms Comunes


El tipo de plataforma se refiere a la arquitectura del hardware sobre el que va a correr nuestro linux, para ello de se debe conocer las caractersticas nuestro hardware para

adquirir el tipo de distribucin apropiada de acuerdo al equipo donde se va a instalar.

Las plataformas principales son: I386 Para equipos tipo PC compatibles. PPC Para equipos Maquintoch Sparc Para estaciones de trabajo Alpha Para arquitectura de trabajo con procesadores en paralelo de tipo alpha.

Existen muchas distribuciones que pueden ser adquiridas por medio de Internet, haciendo la compra en el sitio oficial que le distribuye o descargndolo gratuitamente de los sitios de FTP, todas las distribucin utilizan la versin del kernel que se actualiza constantemente, la diferencia radica en que los diseadores y programadores le dan su toque especial, principalmente en presentacin de la interfaz grfica, implementacin de nuevas herramientas, programas, formatos grficos, etc.

Las distribuciones ms comunes son:

http://www.slackware.com/

http://www.redhat.com/

http://www.debian.org/

http://www.linux-mandrake.com/

http://www.suse.com/

http://www.freebsd.org/

http://www.netbsd.org/

http://www.turbolinux.com/

http://www.knopper.net/

Componentes Del Sistema Operativo LINUX


LINUX esta compuesto bsicamente de cuatro capas, la capa mas interna esta conformada por el hardware, que es el conjunto de piezas fsicas del equipo de cmputo. La segunda capa es el Kernel o ncleo del sistema, su funcin principal es interpretar las instrucciones proporcionadas por el usuario y convertirlas en lenguaje de mquina e indicarle al hardware lo que tiene que realizar con dicha informacin.

Como interpretar los nmeros de las versiones: Las versiones del kernel se numeran con 3 nmeros, de la siguiente forma: XX.YY.ZZ XX: Indica la serie principal del kernel. Hasta el momento solo existen la 1 y 2. Este numero cambia cuando la manera de funcionamiento del kernel ha sufrido un cambio muy importante. YY: Indica si la versin es de desarrollo o de produccin. Un numero impar, significa que es de desarrollo, uno par, que es de produccin. ZZ: Indica nuevas revisiones dentro de una versin, en las que lo nico que se ha modificado, son fallos de programacin/bugs.

La tercer capa esta conformada por el grupo de los Shells o interpretes de comandos, los cuales funcionan como la interfaz entre el usuario y el kernel, proporcionan las herramientas para que el usuario se pueda comunicar con el ncleo del sistema de LINUX. La cuarta y ltima capa es donde se encuentra el usuario junto con los programas y aplicaciones que se le han agregado al sistema como hojas de clculo, lenguajes de programacin, manejadores de bases de datos, procesadores de texto, etc.

Hardware Kernel Shell Aplicaciones y usuarios

Linux
Hoy en da existen muy buenas razones para optar por Linux ya que, el sistema ofrece estabilidad, seguridad y velocidad. Otro aspecto importante es su capacidad de conectividad en redes que ha sido decisiva para la conquista del mercado de servidores. Los gurs del Linux aprecian la disponibilidad del cdigo fuente lo que proporciona al sistema operativo un alto nivel de independencia y flexibilidad.

GNU/Linux
GNU/Linux es un sistema operativo. Esto significa que es un conjunto de instrucciones que nos va a permitir "hacer cosas", cualquier tipo de tarea, con nuestro ordenador. Sus caractersticas ms notables son: Proviene de UNIX, otro sistema operativo, y es casi un derivado de l. Es parte del proyecto GNU, lo que significa, entre otras muchas cosas, que es libre y que muchas veces no ests obligado a pagar por l. Puedes usarlo de modo gratuto y adems puedes modificar su cdigo fuente, para adaptarlo a tus propias necesidades o para contribuir en su continuo desarrollo, en el que toman parte programadores de todo el mundo (http://www.gnu.org).

GNU/Linux
Es potente, seguro y estable. Debido a ello resulta un sistema operativo ideal para servidores ya que cumple muy bien esta funcin aunque como sistema operativo de oficina, de escritorio o de publicacin tambin es excelente. Existen infinidad de programas para cualquier tipo de tarea que se quiera desarrollar y aunque muchos de ellos son gratuitos (no por ello de menos calidad que los comerciales, pues muchas veces los superan), tambin existen aplicaciones comerciales.

GNU/Linux
Es un sistema multiusuario real y multitarea y funciona de manera muy productiva en redes. Desde sus races UNIX siempre lo ha sido. En definitiva Linux pone todo lo bueno de los grandes UNIX y algunas cosas ms al alcance de todo el mundo.

GNU/Linux
Puede decirse que Linus Trovalds cre este sistema operativo en 1991. Escribi un KERNEL (parte principal de un sistema operativo) y lo dej a disposicin de sus amigos y luego de toda la Internet para que cualquiera pudiese mejorarlo. Siempre se ha seguido la regla POSIX para que el sistema operativo sea compatible con otros UNIX y de esta manera tener mayor software a su disposicin, y que el que se cree para Linux valga tambin en otros UNIX. Algn tiempo ms tarde, para adaptar el sistema operativo y facilitar la instalacin, nacieron las compaas distribuidoras de Linux.

GNU/Linux
Entre ellas destacan RedHat, Debian, Caldera, SuSE. Estas distribuidoras pueden cobrar por ofrecer sus productos en CD o en algn otro soporte, pero deben poner su cdigo a disposicin del pblico, si han utilizado software GNU (bajo licencia GPL, que dice entre otras cosas que si usas cdigo GPL en tu programa, tu programa se convierte automticamente en GPL). Actualmente Linus Torvalds sigue coordinando el trabajo de los programadores de todo el mundo en el ncleo del sistema operativo para mejorarlo y adaptarlo al nuevo hardware.

Cuando la BIOS termina su chequeo, empieza a buscar dnde hay software para ser ejecutado. Si los CDROMs no son de arranque, pasa al primer disco duro por defecto. En el principio del disco duro o MBR en una particin queda instalado con Linux un cargador de arranque. Los dos ms usados son LILO (LInux LOader) y GRUB. Nada ms al arrancar se ejecuta este cargador cuya misin permitir al usuario elegir sistema operativo de los que tenemos en nuestro equipo instalados Seleccionamos nuestra versin de Linux y el cargador da paso al Kernel de Linux que empieza a hacer sus chequeos y a montar (hacer utilizable) el sistema de archivos.

El arranque de Linux

El arranque de Linux
Kernel (Ncleo): elemento mas importante. Permite que las aplicaciones accedan al hardware. Es responsable de la gestin de recursos, seguridad, etc Procesos de usuario: distintos programas ejecutndose concurrentemente en un sistema La interaccin entre el ncleo y los procesos se hace mediante llamadas al sistema (system calls) La shell es un interfaz de usuario en modo texto. Es una aplicacin como otra cualquiera

El kernel de Linux

El kernel de Linux
La Free Software Foundation (Richard Stallman) considera 1 que: Linux es estrictamente el kernel Los procesos de usuario (programas y otras utilidades bsicas para el sistema) provienen del proyecto GNU (y algunos otros). Al conjunto se le debe llamar GNU/Linux. Un nmero importante de personas y organismos se oponen a esta definicin. La mayor de la gente lo llama simplemente Linux

Linux
Hay software libre para cualquier S.O. Hay software propietario para Linux Cuatro libertades. Quien lo recibe tiene: libertad de uso. Usarlo como quiera, donde quiera libertad de redistribucin. Redistribuirlo a quien quiera, como quiera libertad de modificacin. Modificar, adaptar, corregir, mejorar libertad de distribuir las modificaciones Imprescindible: disponibilidad de cdigo fuente.

El sistema de archivos
El sistema de archivos es ms o menos "la forma de escribir los datos en el disco duro". El sistema de archivos nativo de Linux es el EXT2. Ahora proliferan otros sistemas de archivos con journalising (si se arranca sin haber cerrado el sistema, no necesitan hacer un chequeo sino que recuperan automticamente su ltimo estado), los ms conocidos son EXT3, ReiserFS y XFS.

El sistema de archivos
Linux soporta varios tipos de sistemas de ficheros. Entre los ms importantes podemos destacar los siguientes: MINIX: el ms antiguo, presume de ser el ms seguro, pero es bastante limitado en las caractersticas que proporciona. Un sistema de ficheros de este tipo solo puede tener 64 MB. EXT2: es el sistema de ficheros nativo de Linux. Est diseado para ser compatible con versiones anteriores, as que las nuevas versiones del cdigo del sistema de ficheros no requerirn rehacer los sistemas de ficheros existentes. EXT3: es una modificacin del ext2 para aadirle funcionalidades de journaling.

El sistema de archivos
VFAT: este tipo permite utilizar sistemas de ficheros de Windows (FAT, FAT32), y actualmente est soportado el sistema de ficheros de Windows NT, pero solo fiable en solo lectura. Iso9660: es el sistema de ficheros estndar para CD-ROM. NFS: un sistema de ficheros en red que permite XT2: es el sistema de ficheros nativo de Linux. Est diseado para ser compatible con versiones anteriores, as que las nuevas versiones del cdigo del sistema de ficheros no requerirn rehacer los sistemas de ficheros existentes. HPFS: es el tipo de sistema de ficheros de OS/2 SYSV: es el tipo de sistema de ficheros de SystemV/386, Coherent y Xenix.

El sistema de archivos
El sistema de ficheros /proc permite acceder fcilmente a ciertas estructuras de datos del kernel, como es la lista de procesos. Convierte estas estructuras de datos en algo parecido a un sistema de ficheros y por tanto da la posibilidad de manipularlas con las herramientas habituales de manipulacin de ficheros. Hay que tener en cuenta que aunque se le denomine sistema de ficheros, ninguna parte del sistema de ficheros /proc toca el disco

El sistema de archivos
Recursos principales por los que luchan los procesos. Linux soporta mltiples procesadores. Dispone de memoria virtual El administrador debe conocer la utilizacin que se esta haciendo de estos recursos. CPU podemos ver su utilizacin con top, uptime. La memoria con free, top, vmstat.

El sistema de archivos
En un sistema Unix todo son archivos: memoria fsica, ratn, modems, teclado... Filosofa de diseo de grn xito y potencia, aunque tambin peligrosa: un simple error de permisos puede permitir modificar todo un disco duro. Tipos de archivos: ficheros planos directorios ficheros especiales (dispositivos) orientados a carcter orientados a bloque

La estructura de directorios
La estructura de directorios que sigue Linux es parecida a la de cualquier UNIX. No tenemos una "unidad" para cada unidad fsica de disco o particin como en Windows, sino que todos los discos duros o de red se montan bajo un sistema de directorios en rbol, y algunos de esos directorios enlazan con estas unidades fsicas de disco. MUY IMPORTANTE: Las barras en Linux al igual que en cualquier UNIX son inclinadas hacia la derecha

La estructura de directorios
Directorio Descripcin / Es la raz del sistema de directorios. Aqu se monta la particin principal Linux EXT. /etc Contiene los archivos de configuracin de la mayora de los programas. /home Contiene los archivos personales de los usuarios. /bin Contiene comandos bsicos y muchos programas. /dev Contiene archivos simblicos que representan partes del hardware, tales como discos duros, memoria...

La estructura de directorios
/mnt Contiene subdirectorios donde se montan (se enlaza con) otras particiones de disco duro, CDROMs, etc. /tmp Ficheros temporales o de recursos de programas. /usr Programas y libreras instalados con la distribucin /usr/local Programas y libreras instalados por el administrador /sbin Comandos administrativos

La estructura de directorios
/lib /var Libreras varias y mdulos ("trozos") del kernel Datos varios como archivos de log (registro de actividad) de programas, bases de datos, contenidos del servidor web, copias de seguridad... /proc Informacin temporal sobre los procesos del sistema (explicaremos esto ms en profundidad posteriormente).

La estructura de directorios
Cualquier sistema de archivos lo montaremos sobre el rbol de directorios, con el comando mount. Para quitarlo con umount. Para tener informacin de los sistemas tenemos los comandos df y du. Podemos establecer cuotas (quotaon) del sistema a los usuarios, con edquota, verlas con quotacheck. Dispone de premisos para ficheros unix y acl.

La estructura de directorios
Tener todo el sistema en una sola particin es mala idea ya que no es flexible y hace difcil de administrar el servidor. Lo ms recomendable es hacer particiones pensando en la carga de archivos del sistema, de los usuarios, servicios y otras consideraciones, logrando con ello facilitar las tareas de respaldo, actualizacin, administracin fcil y eficiente, entre muchas otras ventajas

La estructura de directorios
Dispositivo (device) es el dispositivo al que est conectado el mouse. Las posibilidades son las siguientes. /dev/psaux, si se trata de un mouse PS/2. /dev/ttyS0, si est conectado al COM1. /dev/ttyS1, si est conectado al COM2. /dev/ttyS2, si est conectado al COM3. /dev/ttyS3, si est conectado al COM4. /dev/usb/mouse, si es un mouse USB. /dev/mouse, que normalmente es un symlink al dispositivo correspondiente al mouse.

La estructura de directorios
En UNIX, la mayora de los dispositivos fsicos estn representados en el sistema dearchivos por ficheros especiales de tipo dispositivo (device). Estos archivos se agrupan dentro del directorio /dev. Veamos un ejemplo: $ cd /dev $ ls -l ttyS0 crw-rw---brw-rw---brw-rw---brw-rw---crw-rw---fd0 hda hda1 dsp 1 root 1 root 1 root 1 root 1 root audio floppy disk disk dialout 14, 2, 3, 3, 4, 3 abr 0 abr 0 abr 1 abr 64 ene 22 2000 22 2000 22 2000 22 2000 9 12:38 dsp fd0 hda hda1 ttyS0

Si se necesitan nuevos archivos de dispositivo, el script /dev/MAKEDEV puede ejecutarse con los argumentos adecuados para crear los dispositivos o grupos de dispositivos que se necesiten

La estructura de directorios
Las tuberas son ficheros especiales que no almacenan informacin en el disco, sino que la guardan en memoria en espera de que algn programa la lea. En este sentido funcionan como un buffer tipo FIFO (First In First Out). Permiten conectar la salida de un programa con la entrada de otro, de forma parecida a como lo hace el shell con el operador "|". Last tuberas se crean con el comando mkfifo(1). primero creamos una tubera llamada mififo $ mkfifo mififlo $ ls -l Ahora ejecutamos un proceso que escriba en la tubera. El proceso quedar bloqueado en espera de que alguien lea de la tubera, por eso lo ejecutamos en el background: $ ls > mififo & $ ls -l Ahora leemos de la tubera. Esto hace que el proceso ls pueda escribir los datos y termine: $ cat mififo mififo|

La estructura de directorios /etc


Almacena los parmetros de configuracin de distintos elementos del sistema Algunos ejemplos clock ide keyboard pcmcia sound ssh

La estructura de directorios /etc


Las bases de datos de los usuarios y passwords: passwd, shadow, group, gshadow El fichero de configuracin de init, que es el padre de todos los procesos: inittab El directorio de los scripts de arranque de servicios: /etc/init.d (junto con los links simblicos hacia ellos, que estn en /etc/rc*.d/) El directorio en donde se configuran variables por defecto para algunos de los servicios que arranca init: /etc/default/ Configuracin esencial de filesystems: fstab Configuracin esencial de red: hostname, hosts, network/interfaces Variables de entorno por defecto para shells de usuarios: environment y profile

Nombres de archivos en Linux


Los nombres de archivos en Linux (como en todos los UNIX) distinguen maysculas de minsculas, esto es, son "case sensitive". Los archivos README, readme, REadme y rEadme por ejemplo son archivos distintos y por lo tanto al ser nombres distintos pueden estar en el mismo directorio. En Linux los archivos no tienen por qu tener una extensin. La suelen tener a modo orientativo, pero no es en absoluto necesario. Linux sabe qu contiene cada archivo independientemente de cul sea su extensin. Por comodidad, podremos llamar a todos nuestros archivos de texto con la extensin .txt,o .doc

Nombres de archivos en Linux


Los nombres de archivos o directorios pueden ser muy largos, de ms de 200 caracteres, lo cual nos da bastante flexibilidad para asociar el nombre de un archivo a lo que contiene. No obstante, hay ciertos caracteres que nunca se deberan utilizar a la hora de nombrar un archivo. El espacio,tampoco son recomendados otros caracteres raros como signos de puntuacin (a excepcin del punto), acentos o la . En algunos casos Linux ni siquiera nos permitir usarlos. Utilizar letras A-Z, a-z, los nmeros (0-9), el punto, el guin (-) y el guin bajo (_)

Espacio en disco
df df (Disk Free) nos informa del espacio disponible de las unidades de disco (locales o de red) que tengamos montadas. # df
S.ficheros /dev/hdd1 /dev/hda2 none 1K-blocks 6040288 11719052 128008 Used Available Use% Montado en 3247924 3526412 0 2485528 57% / 8192640 31% /home 0% /dev/shm

128008

Una opcin til de la que dispone es -m, que mostrar el espacio en MegaBytes.

Montar dispositivos
En realidad, las operaciones de montado y desmontado las llevan a cabo los comandos mount y umount, por ejemplo: # mount /dev/hdc /cdrom Antes del montado, el directorio /cdrom debe estar creado. Tras el montado, el contenido del dispositivo montado aparece en /cdrom como si se tratara de un directorio ms del sistema. De la misma forma de hara para un diskette: # mount /dev/fd0 /floppy

Montar dispositivos
Disco duro IDE y CDROM: /dev/hdXY X: Nmero de disco/dispositivo_IDE (a, b, c...) Y: Nmero de particin (1, 2, 3...) /dev/hda /dev/hda1 /dev/hdb3 Disco duro SCSI, SATA y externos USB: /dev/sdXY /dev/sda /dev/sda1 /dev/sdc4

Montar dispositivos
Linux reconoce muchos formatos posibles de discos, diskettes y CDROM. En la mayora de los casos el sistema identifica automticamente el formato del dispositivo, pero cuando esto no es posible, podemos indicar el formato con la opcin -t de mount, por ejemplo: # mount -t vfat /dev/fd0 /floppy montara un diskette con formato MSDOS y soporte para nombres largos. Otros formatos comunes son: msdos (formato MSDOS normal), iso9660 (formato de los CD ROMs) y ext2 (formato nativo de Linux)

Montar usb
creas un sitio donde montar la particion mkdir /media/discoUSB luego lo montas como root mount /dev/sda1 -t vfat /media/discoUSB para que no tengas que ser root, escribe (como root) esto en /etc/fstab
/dev/sda1 /mnt/discoUSB vfat users,noauto,umask=000,exec 0 0

mount /media/discoUSB

Fichero /etc/fstab
Para facilitar el uso de mount y para indicar al sistema que dispositivos forman el sistema de ficheros, existe el fichero /etc/fstab. En l se indican que dispositivos han de montarse en qu lugar y con que opciones Para crear particiones se utiliza el comando fdisk o cfdisk: # cfdisk /dev/hda . Los cambios propuestos no se hacen efectivos hasta que se escribe la tabla de particiones. Si el sistema esta funcionando combiene conocer previamente que particiones estan montadas y activas (con el comando mount o df) para no modificarlas pues se daara el sistema. Una vez escrita la tabla de particiones, se ha asignado un tipo de sistema de fichero a cada una de las particiones establecidas en dicha tabla pero no se les ha dado el formato adecuado.

Fichero /etc/fstab
/dev/hda5 Particin o dispositivo /respado Punto de montaje en el sistema ext3 0 0 Tipo de sistema Sistemas que requieren dump Orden en que son revisados los sistemas. defaults Opciones de montaje asociadas al dispositivo

Formateando nuevas particiones


En la particion de disco duro libre denominada ext3, se realiza un proceso de division por bloques de tamao entorno a 4KB numerandolos secuencialmente. Estos bloques se agrupan en, como minimo, 6 grupos distintos: Grupo 1: Bloque 1: Bloque donde se coloca el sector de arranque Grupo 2: Bloque 2: Se especifica el tamao de los restantes bloques Grupo 3: Bloque 3 hasta n1: Se especifica el mapeado de los inodos Grupo 4: Bloque n1+1 hasta n2: Se especifica el mapeado de los datos Grupo 5: Bloque n2+1 hasta n3: Espacio de inodos Grupo 6: Bloque n3+1 hasta n4: Espacio de datos Para formatear una particion en Linux se utiliza el comando mkfs # mkfs -t ext3 /dev/hda3

Formateando nuevas particiones


Si existen herramientas de reparaci on del sistema de ficheros que, incluso, se ejecutan automaticamente cada vez que al arrancar el sistema se detecta que en la ultima sesion no fueron cerrados apropiadamente. El comando para reparar el sistema de ficheros es fsck o e2fsck en el caso de sistemas de ficheros ext3: # e2fsck /dev/hda3 Es importante tener en cuenta que este proceso solo debe llevarse a cabo con la particion no montada o bien montada de solo lectura lo cual plantea un problema con la particion raiz del sistema.

Formateando nuevas particiones


Una vez formateada una nueva particion, por ejemplo, /dev/hda3, se puede acceder a ella montndola en algun directorio designado para contenerla: # mount -t ext2 /dev/hda3 /mnt Si se pretende disponer automaticamente de esta particion al arrancar el sistema se necesita aadir una linea al fichero /etc/fstab. Si por ejemplo se quisiera montar la particin /dev/hda3 en el directorio /home la lnea sera la siguiente: /dev/hda3 /home ext2 defaults,errors=remount-ro 0 1

Formateando nuevas particiones


Crear una particin swap El proceso comienza por crear una nueva particion con el comando cfdisk siguiendo el mismo procedimiento que contamos previamente. Lo unico que hay que tener en cuenta es que el tipode la nueva particion debe ser Linux swap. Para formatear esta particion se utiliza el siguiente comando: # mkswap /dev/hdxx Para activarla: # swapon /dev/hdxx

Formateando nuevas particiones


El proceso de creacion y activacion de un fichero swap es como sigue: 1. Se crea un fichero relleno de ceros de un tamao adecuado: # dd bs=1024 if=/dev/zero of=/dev/swapfile count=1000 Con esta orden se crea un fichero /dev/swapfilede tamao 1024X1000 (aprox. 1M) 2. Se formatea el fichero swap: # mkswap /dev/hdxx 1000 3. Activar el fichero swap: # sync # swapon -v /dev/swapfile

Formateando nuevas particiones


Actualizacin de sistemas ext2 a ext3 Como ext3 es slo una actualizacin a ext2, los sistemas de ficheros ext2 pueden convertirse de forma sencilla a ext3, sin tener que formatear particiones ni copiar discos Aadimos primero un registro de transacciones a los sistemas de ficheros. No hace falta desmontar los sistemas de ficheros ni nada: # tune2fs -j /dev/hdb1 # tune2fs -j /dev/hdb3 Luego alteramos /etc/fstab para reflejar el cambio en el sistema de ficheros: La prxima vez que arranquemos el sistema, los sistemas de ficheros funcionarn como ext3. Podemos comprobarlo en los mensajes de arranque del kernel: # dmesg | less

Manipulacin de diskettes a bajo nivel


El acceso a los diskettes a travs de dispositivos como /dev/fd0 permite un acceso a bajo nivel. Esto es, al igual que ocurre con la mayora de los dispositivos en /dev, podemos escribir y leer directamente de ellos (siempre que tengamos los permisos adecuados) Esto nos permite extraer literalmente el contenido de diskettes, sector a sector, o grabar en ellos imgenes literales almacenadas en ficheros, como discos de arranque de Linux cat /dev/fd0 > /tmp/imagen dd es un programa genrico para transferir datos entre ficheros o dispositivos con la posibilidad de hacer ciertas traducciones de formato : $ dd if=/dev/fd0 of=/tmp/imagen bs=512 para crear la imagen, y $ dd if=/tmp/imagen of=/dev/fd0 bs=512

Usuarios el Linux
Caractersticas de usuarios Unix Los sistemas Unix son sistemas multiusuario. Cada usuario tiene una serie de caractersticas propias y asociadas: uid: identificativo de usuario (debe ser nico) gid: identificativo de grupo home: carpeta de trabajo o personal shell: interprete de comandos Comandos: who/whoami/id (muestra informacin de usuarios) su/sudo (cambia de usuario o privilegios)

Elementos Bsicos De Una Cuenta De Usuario

Una cuenta de correo esta basada en un login y un password, sta se complementa con el nombre del servidor y el dominio del mismo en el cual se encuentra alojada dicha cuenta

El login es el identificador del usuario dentro del servidor, dicho login es nico, es decir, no puede haber dos cuentas en el servidor con el mismo login ya que ste es el nombre con que se conoce al usuario dentro del servidor. usuario@equipo:

El password Es la clave de acceso al sistema, slo debe conocerla el dueo de la cuenta ya que permite el acceso al servidor, a todos sus servicios disponibles y a la informacin del usuario. Cuando el sistema nos pide la contrasea y nosotros la tecleamos, sta no es impresa en el monitor por seguridad para evitar que sea vista por otra persona.

Cambio De Contrasea passwd


ste comando nos permite realizar el cambio de contrasea de una cuenta, para poder realizar el cambio necesitamos saber la contrasea actual de la cuenta ya que por seguridad el sistema nos pedir que insertemos dicha contrasea para a continuacin teclear la nueva contrasea dos veces para verificar que haya sido escrita correctamente.

Salida Del Sistema


Es necesario indicarle al sistema que queremos terminar la sesin de trabajo en el servidor, para ello existen varios comandos, entre ellos se encuentran los comandos exit y logout o la combinacin de teclas Ctrl+d. Ambos comandos nos permiten terminar la sesin en el servidor, al momento que lo tecleamos y presionamos enter se cierra la conexin en el servidor.

Usuarios el Linux
Gestin de Usuarios adduser (crear usuarios) usermod (modificar usuarios) deluser (eliminar usuarios) Gestin de Grupos addgroup (aade grupo o usuario a grupo) groupmod (modifica grupo) delgroup (elimina grupo o usuario de grupo)

Usuarios el Linux
/etc/passwd Contiene lista de usuarios reconocidos por el sistema, consultado por el sistema en un login login (nombre) password encriptado (puede estar en archivo shadow) UID GID por defecto GECOS directorio home shell por defecto

Usuarios el Linux
/etc/passwd: Archivo donde se almacena toda la informacin relativa a los usuarios del sistema, excepto la contrasea (encriptada) si se utilizan shadow passwords.Se recomienda utilizar shadow passwords por cuestiones de seguridad (evitar el ataque con diccionario). /etc/shadow: En un sistema con el mecanismo de shadow passwords activado es el archivo que almacena las contraseas (encriptadas) de los usuarios. /etc/group: Fichero donde se guardan los nombres y los identicadores numericos de los grupos ademas de la lista de usuarios adscritos a cada grupo . /etc/gshadow: Fichero que guarda informacin complementaria para grupos si se activa el mecanismo de shadow passwords.

Usuarios el Linux
Nombres (login) Hasta 32 caracteres (todos excepto : y LF) Recomendado lmite de 8. Viejos UNIX limitan a 8 (adoptado por NIS) Se recomienda usar reglas para asignar cuentas (nombres se usan en email!) /etc/mail/aliases puede ser usado para equivalencias entre email y login Password encriptado Se usa DES (usa 8 caracteres) o MD5 Cuando se crea una cuenta, debe asignrsele un password usando comando passwd Un * en /etc/passwd (o /etc/shadow) significa que no se puede hacer login. Vaco significa que no requiere password!!

Usuarios el Linux
UID y GID UID de 32 bits (0 reservado para root) Pseudousuarios (bin, daemon, etc.) se les asigna los nmero bajos Usuarios normales: recomendado UID > 100 Conveniente usar mismo UID para el mismo usuario en la red (NFS!!) Los grupos estn definidos en /etc/group Un usuario puede estar hasta en 32 grupos

Usuarios el Linux
GECOS General Electric Comprehensive Operating System. Usado para mandar login en trabajos batch de Unix a mainframe en Bell Puede estar vaco Se usa para informacin personal (nombre, telefono, oficina, etc.) El comando finger interpreta el campo como nombre, oficina, etc. El comando chfn permite modificarlo

Fichero oculto que incluye la codificacin y las restricciones de las claves de acceso a las cuentas. Sus campos son: Usuario:clave:F1:N1:N2:N3:N4:Caduc: 1. 2. 3. 4. 5. 6. 7. 8. 9. Nombre de usuario. Clave codificada. Fecha del ltimo cambio de clave. Das hasta que la clave pueda ser cambiada. Das para pedir otro cambio de clave. Das para avisar del cambio de la clave. Das para deshabilitar la cuenta tras su caducidad. Fecha de caducidad. Reservado (ignorado por Red Hat).

Usuarios el Linux

Nota: Las fechas se expresan como el no de das desde el 1/1/1.970.

Gestion de usuarios
Cambiando el propietario y grupo Para cambiar el propietario o grupo puede hacerse a travs del nombre o del identificativo (uid o gid). chown (cambiar el propietario) chmod (cambiar el grupo)

Gestion de usuarios
linux:~$ adduser alumno linux:~$ addgroup consultec linux:~$ adduser home /home/consultec/alumno shell /bin/sh uid 5001 ingroup consultec alumno linux:~$ usermod -shell /bin/bash alumno linux:~$ adduser alumno softwarelibre Esto aade a alumno al grupo softwarelibre

Gestion de usuarios
Useradd es el comando para agregar usuarios genrico para todos los linux, es ms complejo y se requiere conocimiento ms profundo sobre administracin de usuarios y grupos. Se debe conocer los grupos que existen en el sistema, la secuencia de UID del sistema de usuarios entre otras cosas. A parte de agregar los registros hay que crear el directorio del usuario, otorgarle privilegios de usuario y grupo y asignarle un password a la cuenta.

Gestion de usuarios
linux:~$ ls -l ~/documentos/linux.pdf -rw-rw-r-- 1 alumno alumno 2684 ene 2 21:09 linux.pdf linux:~$ chown alumno:consultec ~/documentos/linux.pdf linux:~$ ls -l ~/documentos/linux.pdf -rw-rw-r-- 1 alumno consultec 2684 ene 2 21:09 linux.pdf linux:~$ id aktor uid=500(aktor) gid=500(aktor) grupos=500(aktor) linux:~$ chown 500 ~/documentos/linux.pdf linux:~$ ls -l ~/documentos/linux.pdf -rw-rw-r-- 1 aktor consultec 2684 ene 2 21:09 linux.pdf

Gestion de usuarios
Userdel Permite eliminar usuarios, aqu tenemos que utilizar la opcin r para que haga un borrado recursivo de todo lo que pertenece al usuario aeliminar, de otra forma solo se eliminarn los registros del usuario de los archivos passwd, shadow y group, posteriormente el administrador tendr que eliminar todo lo que pertenecia al usuario a mano.

Gestion de usuarios
Useradd es el comando para agregar usuarios genrico para todos los linux, es ms complejo y se requiere conocimiento ms profundo sobre administracin de usuarios y grupos. Se debe conocer los grupos que existen en el sistema, la secuencia de UID del sistema de usuarios entre otras cosas. A parte de agregar los registros hay que crear el directorio del usuario, otorgarle privilegios de usuario y grupo y asignarle un password a la cuenta.

En ocasiones es necesario modificar el perfil de un usuario, para ello el sistema cuenta con el comando usermod, aunque tiene muchas opciones solo vamos a describir las ms importantes. usermod u usermod g usermod G usermod d usermod s usermod c usermod f usermod e usermod p usermod L usermod U modifica el UID del usuario modifica el grupo principal de usuario

Gestion de usuarios

modifica los grupos adicionales del usuario modifica el directorio HOME del usuario modifica el shell por default Modifica el comentario (campo de GECOS) Asigna/modifica fecha de inactividad modifica/asigna fecha de expiracin de la cuenta Cambia el password del usuario Bloquea el acceso de la cuenta (Lock) Desbloquea una cuenta bloqueada (Unlock)

Gestion de usuarios
Para agregar un grupo nuevo se usa el comando groupadd, todos los registros de los grupos se encuentran en el archivo /etc/group. Algunos sistemas permiten agregar un grupo privado para cada usuario, este no es el caso de debian, ya que tiene un grupo llamado users al cual pertenecen todos los usuarios por default, aunque es posible modificar las propiedades para apropiarlo a las necesidades administrativas y funcionales del sistema.

Gestion de usuarios
Eliminacin de un grupo Antes de eliminar un grupo es conveniente revisar que ningn usuario tenga este grupo como principal, ya que el sistema no le permitir eliminar el grupo lo que significa una reorganizacin del sistema.

Permisos
Todos

los archivos en Unix tienen permisos que indican que y quien puede hacer o no hacer una accin con el archivo.

Es la base de la seguridad de Unix. 2 formas de notacin: Modo alfabtico Modo octal

Atributos de los archivos.


Tipos de archivos: Dentro del sistema operativo vamos a encontrar archivos de diferentes tipos, los cuales los vamos a distinguir por el primer bit de sus propiedades. El atributo del primer bit nos indica si el elemento listado es directorio o archivo, as mismo nos indica de que tipo de archivo se trata.

Archivos ms comunes. d Nos indica que el elemento es un directorio. _ Archivo ordinario. l El elemento listado es una liga suave. c Archivo de tipo carcter (Archivos de acceso de hardware mediante un bit como el mouse). b Archivo de bloque (acceso por bloques en paralelo como la impresora).

Permisos
Existen tres tipos de permisos que se aplican tanto a los archivos como a los directorios, ellos son: r lectura w escritura

x ejecucin

Debemos asignar los permisos a los archivos de acuerdo a la funcin que van a realizar dependiendo para lo que fueron creados. r El permiso de lectura permite que el archivo pueda ser ledo o copiado. w Permite escribir en el archivo, modificaciones o borrarlo si as lo desea. hacer

x Los archivos ejecutables son aquellos que pueden realizar un proceso.

Estos permisos se encuentran asignados en tres bloques, los cuales representan al usuario o dueo del elemento listado, al grupo al que pertenece el usuario y a los otros usuarios del sistema, de ello que los atributos se componen de 10 bits, el primer bit indica el tipo de elemento que esta listado (archivo o directorio), los siguientes 9 bits representan los tipos de permisos asignados a cada elemento listado.

Ejemplo de listado de permisos

chmod (Permisos)

ste

comando a los

nos

permite y

modificar directorios, simblico

los la o

permisos formas,

archivos el

asignacin de permisos puede hacerse de dos mediante mtodo mediante el mtodo octal.

Asignacin de permisos: chmod indica al sistema el cambio de permisos. u Indica que se modificarn los permisos del usuario dueo del elemento. g Indica que se modificarn los permisos asignados al grupo. o Indica que se modificaran los permisos de los otros usuarios que no pertenecen al grupo. a Indica que afectar los permisos para todos usuarios. los

Permisos
Modo alfabtico

chmod u+r,g-rx,o+r hola Para modificar los permisos se pone el indicador de los permisos a afectar ya sea para el usuario, el grupo o los otros, seguido del signo + si se quiere agregar el permiso o de si se quiere quitar el permiso separando con una coma los bloques de permisos, al final se indica el nombre del elemento a afectar.

Mtodo octal
Con el mtodo octal se asignan directamente los permisos en base a una tabla de validacin que va numerada de 0 a 7 dependiendo de los permisos que se deseen asignar, cada permiso adquiere un valor numrico: X vale 1 W vale 2 R vale 4 quedando nuestra tabla de la siguiente forma:

Asignacin 0 1 2 3 4 5 6 7 ___ __x _w_ _wx r __ r_x rw_ rwx

Permisos Ninguno Ejecucin Escritura Escritura y Ejecucin Lectura Lectura y Ejecucin Lectura y Escritura Lectura, escritura y ejecucin

De tal forma que si deseamos poner todos los permisos para el usuario, permisos de lectura y ejecucin para el grupo y ninguno para los otros el comando quedara de la siguiente forma: chmod 750 hola Sustituyendo el nmero correspondiente para cada bloque de permisos al usuario, al grupo y a los otros.

Comandos para administrar los usuarios: Adduser Useradd Userdel Usermod Groupadd Groupdel Groupmod Groups Passwd Agrega usuarios modo comando Agrega usuarios modo comando Elimina usuario Modifica las propiedades del usuario Agrega grupos Elimina grupos Modifica grupos Lista los grupos a los que pertenece un usuario Modifica propiedades de usuarios/grupos

who muestra un listado sencillo de quien se encuentra conectado en el servidor, a que hora se conecto y que esta haciendo. w Muestra un listado con detalles de los usuarios conectados en el servidor. whoami me indica con que login estoy registrado dentro del servidor, este comando es til ya que es posible que un usuario se convierta en otro diferente utilizando el comando su

Arranque de Linux
El administrador de sistemas debe conocer las diferentes formas para dar de alta o de baja el sistema, de ello depender en gran medida el rendimiento y confiabilidad del sistema incluso despus de un reinicio, tambin pude ser muy til para rescatar un sistema cuando no inicia apropiadamente. Primero es necesario comprender lo que sucede cuando encendemos el equipo y el proceso de arranque del sistema.

Arranque de Linux
Lo primero que realiza el proceso de arranque de Linux es cargar una copia del kernel que se encuentra en el dirctorio /boot, a continuacin detecta todos los dispositivos de hardware y los pone a disposicin del sistema, busca en los scripts de configuracin para leer el nivel de inicio para el cual esta configurado por default, luego busca los scripts del runlevel, finalmente ejecuta el script rc.local.

Arranque de Linux
Bios checa el sistema Lanzamiento del Boot Loader (MBR) segundo Boot Loader /boot (kernel +initrd) carga del Kernel en memoria y los diferentes mdulos Ejecucin de /sbin/init /etc/rc.d/rc.sysinit /etc/inittab /etc/rc.d /sbin/mingetty Carga de servicios, aplicaciones y sistemas de ficheros Secuencia de Login

Arranque de Linux
El nivel de inicio por default se encuentra definido en el archivo /etc/inittab, para ello necesitamos conocer los diferentes niveles que estn predefinidos en el archivo de inicio: # These are the default runlevels # 0 = halt # 1 = single user mode # 2 = unused (but configured the same as runlevel 3) # 3 = multiuser mode (default Debian runlevel) # 4 = X11 with KDM/GDM/XDM (session managers) # 5 = unused (but configured the same as runlevel 3) # 6 = reboot

Arranque de Linux
Este programa de iniciacin carga todos los servicios definidos, ejecuta los programas de iniciacin y configuracin y monta las particiones definidas. /sbin/init lee la informacin del fichero de configuracin /etc/inittab, carga en primer lugar los servicios bsicos y luego los asociados al nivel de arranque elegido por el administrador. Se finaliza el arranque del sistema presentando al usuario el proceso de conexin (login) o el entorno grfico (normalmente GNOME o KDE).

Arranque de Linux
Una vez que se ha cargado en memoria, el kernel ejecuta su primer programa init. Esta aplicacin va a ser el padre de todos los procesos del sistema. El comando /sbin/init utiliza la configuracin que se encuentra en el archivo /etc/inittab, primero en busqueda de initdefault, que le indica cual es el runlevel en el que debe entrar. Un runlevel es una configuracin que permite iniciar cierto grupo de programas Cada lnea contiene id:runlevels:action:process

Scripts de inicio
Cuando se inicia la maquina, se suelen ejecutar una serie de scripts basicos del sistema. En Debian GNU/Linux estos scripts son /etc/init.d/rcS y /etc/init.d/rc, este ultimo recibe como parametro el runlevel con el que. Estos scripts ejecutan otros scripts, que se encuentran en /etc/rcS.d y /etc/rc[1-6].d, respectivamente. Que a su vez son symlinks de scripts que estan en /etc/init.d/. Los symlinks tienen la forma [SK][0-9][0-9]nombre, la S o la K le dice si debe iniciar o detener ese proceso respectivamente. Esto lo hace ejecutando el script con el parametro start o stop segun corresponda. El nmero de 00-99 determina el orden de ejecucion.

Scripts de inicio
Servicios / Daemons Entre los servicios que se inician al ejecutarse algun runlevel, existen algunos que podemos esperar que se encuentren en cualquier sistema UNIX. Como el syslog, el cron, anacron, at y inetd

Apagar Linux
Para apagar el sistema podemos usar varios comandos: poweroff halt shutdown reboot init telinit Aunque estos comandos nos permiten apagar o reiniciar el proceso puede variar, aqu hay que determinar cual es la forma ms apropiada.

Apagar Linux
Shutdown Este es considerado el comando ms eficiente para detener, reiniciar el sistema, ya que su proceso de apagado es muy eficiente, de hecho da de baja el sistema en una forma segura. Se tiene control del apagado del sistema ya que se puede definir un tiempo, todos los usuarios son avisados de que el sistema se va a dar de baja mediante la instruccin SIGTERM, deshabilita el login para que nadie se pueda logear en el sistema, se comunica con el programa init y le solicita el nivel 0 de ejecucin.

Apagar Linux
Shutdown Este comando enva una seal de sincronizacin de discos, manda la seal de termino a todos los programas y los cierra eficientemente siguiendo su proceso normal de las aplicaciones, una vez que se han cerrado todos los procesos manda una nueva seal de sincronizacin para verificar que no hay tareas en ejecucin, termina baja los demonios y finalmente apaga el sistema en forma segura.

Apagar Linux
shutdown h now shutdown r now Apaga el sistema en forma inmediata Reinicia el sistema en forma inmediata segundos de espera . shutdown k shutdown f accin shutdown F accin shutdown c Shutdown +m accin No apaga el sistema, solo enva un aviso a todos los usuarios conectados. Evita que se ejecute fsck al reinicio Fuerza a que se ejecute fsck al reinicio Cancela la instruccin shutdown Espera m minutos antes de realizar la accin shutdown t sec accin Realiza la accin con t numero de

Runlevel
Para saber en que nivel se esta ejecutando el sistema puede ejecutar el comando runlevel: sesion1@milo:~$ /sbin/runlevel N3 Aqu nos dice que el sistema se inicio en modo 3.

Monousuario Linux
Init Si deseamos cambiar el modo de ejecucin del sistema podemos hacerlo directamente con el comando init y el numero de inicio, por ejemplo si deseamos cambiar a nivel de ejecucin 1 init 1 El sistema ejecutara los scripts correspondientes para cerrar los demonios, los dispositivos de red y quedar en modo monousuario. sesion1@milo:~$ /sbin/runlevel 31 Aqu el sistema nos dice que inici en modo 3 pero se reinicio en modo 1, ahora podemos comenzar nuestras tareas administrativas.

Introduccin al Sistema Operativo LINUX

Reconocimiento del servidor y del sistema hostname


hostname nos muestra el nombre del servidor. -i Esta opcin nos muestra la direccin ip que tiene asignada el servidor de trabajo.

-d -f

Nos muestra el dominio del servidor. Muestra un listado completo incluyendo el nombre del

servidor y su dominio.

uname
uname Nos indica el tipo de LINUX que se esta utilizando. linux -n Indica el nombre del servidor r Muestra la versin del kernel m Indica la arquitectura del procesador -a Muestra todos los datos antes mencionados

pwd

(Print Working Directory) ste comando imprime en pantalla el directorio actual de trabajo, es decir, donde nos encontramos posicionados dentro del sistema absoluta. de directorios indicndonos la ruta

touch

Este comando nos permite crear archivos vacos, de tamao 0. touch prueba Este comando es til cuando nos interesa generar archivos que tienen una funcin especial como las bitcoras.

Caracteres Especiales.
UNIX maneja varios caracteres especiales, cada uno de ellos realiza una funcin en especfico, en ocasiones pueden ser combinados para aumentar el potencial del comando en ejecucin o para redireccionamiento, se recomienda que estos caracteres no se utilicen al nombrar archivos o directorios. Estos caracteres son:
; , < > | >> ^ $ & / ~ \ [ ] ( ) . * ?

Comodines *, ?
Existen dos caracteres llamados comodines los cuales pueden sustituir un carcter o conjunto de caracteres durante la ejecucin de comandos, Ej. ls ??a Muestra aquellos archivos y directorios los cuales tengan el nombre de tres letras y la tercera sea la letra a ls *u*t* Muestra aquellos archivos y directorios los cuales tengan en el nombre una u y una t en cualquier posicin pero en el orden que se le indica.

Rutas Absolutas Y Relativas


Las rutas absolutas siempre inician con el smbolo de / que indica el punto ms alto de la estructura de directorios, a partir de aqu se debe de poner la ruta completa para llegar al punto que se quiera afectar. cd /home cd /var/spool/mail

Las rutas relativas nunca inician con el smbolo de raz / en lugar de ello inician la ruta a partir del directorio actual de trabajo. Supongamos que se encuentra en su directorio home y quiere regresar dos directorios hacia arriba para posicionarnos en la raz del sistema: cd ../..

rm (Remove)
El comando rm borra archivos, puede ser borrado un solo archivo o varios haciendo uso de los metacaracteres * ? rm saludo rm lo* rm pr??ba

rm r directorio
La opcin r hace un borrado en forma recursiva, esta opcin es de mucho cuidado ya que se borrar el directorio especificado y todo su contenido.

rm f *
La opcin f fuerza a que los elementos sean borrados aunque nosotros no tengamos permisos sobre ellos.

mv (move)
El comando mv tiene dos funciones bsicas, la primera es mover archivos o estructuras de directorios de un lugar a otro, la segunda es renombrar archivos o directorios. mv saludo carta/ Aqu se esta moviendo el archivo saludo dentro del directorio carta. mv saludo hola Aqu se est cambiando el nombre del archivo saludo, ahora se llamar hola.

Trabajo con archivos


cat nos permite ver el contenido de uno o mas archivos, su funcin original es concatenar archivos. cat archivo1 archivo2 ... n Utilizando la opcin el comando imprime el contenido del o los archivos numerando las lneas en forma ascendente. cat -n archivo1 archivo2 ...

head
nos muestra las primeras 10 lneas contenidas en un archivo head nom_archivo -n esta opcin le indica al comando que despliegue las primeras n nmero de lneas en lugar de 10. head 20 nom_archivo

tail
nos muestra las ltimas 10 lneas contenidas en un archivo tail nom_archivo -n Esta opcin le indica al comando que despliegue las ltimas n nmero de lneas en lugar de 10. tail 20 nom_archivo

Este es un programa que permite editar archivos de texto, es muy fcil de utilizar, ya que presenta un men de comandos en la parte inferior de la pantalla y no requiere de muchos comandos para poder editar el contenido del archivo. Permite el desplazamiento del cursor mediante las teclas de navegacin. ctrl+o permite guardar el archivo, si ya tiene nombre el archivo lo guarda automticamente, si el archivo no tiene nombre nos va a pedir el nombre con el cual lo deseamos guardar.

pico

Filtros
grep Este comando busca patrones en archivos. Por defecto devuelve todas las lneas que contienen un patrn determinado en uno o varios archivos. Utilizando las opciones se puede variar mucho este comportamiento. Si no se le pasa ningn archivo como argumento hace la bsqueda en la entrada estndar. Sintaxis: grep [opciones] <patrn> [ficheros]

Algunas opciones: -c : devuelve slo la cantidad de lneas que contienen al patrn. -i : ignora las diferencias entre maysculas y minsculas. -H : imprime adems de las lneas, el nombre del archivo donde se encontr el patrn. Es as por defecto cuando se hace la bsqueda en ms de un archivo. -l : cuando son mltiples archivos slo muestra los nombres de aquellos donde se encontr al patrn y no las lneas correspondientes. -v : devuelve las lneas que no contienen el patrn. -r : busca en un directorio de forma recursiva. -n : imprime el nmero de cada lnea que contiene al patrn.

Ejemplos: $ grep -H -r linux /usr/share/doc # grep -n error /var/log/messages $ grep -i ftp /etc/passwd $ grep -c root /etc/group $ grep -l -r -i img /var/www/icons/*

Algunos programas tiles dentro de LINUX


fortune Elige de una base de datos el mensaje del da como el que aparece en pantalla cada vez que iniciamos sesin. date muestra la hora del sistema. df Muestra el estado de las particiones de los discos duros indicndonos el espacio utilizado y el estado libre en disco.

du muestra el espacio utilizado entre archivos y directorios a partir del directorio desde donde se ejecut el comando. last muestra las ltimas conexiones de los usuarios al servidor. last 20 muestra los ltimos 20 registros al servidor. last 20 usuario muestra los ltimos 20 registros al servidor del usuario carlos

sort Ordena el contenido de un archivo por lneas en orden alfabtico. sort r ordena el contenido de un archivo en forma inversa alfabticamente. wc cuenta las lneas, palabras y caracteres contenidos en un archivo. wc l Cuenta nicamente las lneas wc w Cuenta nicamente las palabras wc c Cuenta nicamente los caracteres

Respaldos
tar tar nos permite empacar una estructura de directorios, su funcin principal es almacenar el contenido de un directorio en forma recursiva dentro de un archivo. Sintaxis: tar [opciones] archivo.tar archivo

Principales opciones de tar -c crea un nuevo archivo tarareado. -v verbose, imprime en pantalla todo aquello que esta afectando. -f Indica al sistema que va a afectar a un archivo -x Extrae el contenido de un archivo .tar

tar cvf archivo.tar archivo


Aqu se esta creando un archivo utilizando la opcin c la opcin v muestra en pantalla todos los archivos y directorios que esta afectando, la opcin f indica que se va a enviar la salida del comando a un archivo, a continuacin de las opciones se especifica el nombre que va a tener el archivo tarareado y por ltimo el nombre del directorio que va a ser afectado.

tar xvf archivo.tar Aqu se esta recuperando la informacin almacenada dentro de un archivo tarareado, con la opcin x, una de las principales caractersticas de tar es que no le importa quien es el dueo del archivo, el grupo al que pertenece ni los permisos que tuvo el archivo al momento de ser tarareado, ya que cuando realizamos el proceso de destararear toda la informacin afectada toma los permisos que nosotros tenemos por default.

Como regla general cualquier opcin es combinada con las opciones vf ya que es recomendable ver qu esta realizando el sistema, as como para indicarle que se est enviando la salida del comando a un archivo, de lo contrario tomar por default la unidad de cinta. -t Lista todos los archivos contenidos en un archivo .tar en formato largo mostrando todos sus detalles. tar tvf archivo.tar

-u update, actualiza el contenido del archivo tar realizando una bsqueda dentro de la estructura de directorios del sistema desde donde se inici el proceso de tarareo, aadiendo todos los archivos y directorios que hayan sido creados o sufrido modificaciones despus de haber sido creado el archivo tarareado. tar uvf archivo.tar

-w Esta opcin nos pide confirmacin para tararear o destararear cada elemento que va a ser afectado. tar cwvf archivo.tar tar xwvf archivo.tar -d Opcin no disponible en todas las versiones, hace una bsqueda de todos los archivos y directorios que hayan sufrido modificaciones despus de haber sido creado el archivo .tar tar dvf archivo.tar

gzip Permite realizar una compresin de archivos, manejando 9 niveles de compresin que van desde el 1 al 9 donde el nivel 1 es el nivel de compresin ms bajo mientras el nivel -9 es el nivel de compresin ms alto. Al momento de ejecutar esta utilera el programa le aade la extensin .gz al archivo comprimido, por default maneja el nivel de compresin 6.

Sintaxis: gzip [-n] archivo La opcin n indica el nivel de compresin que se quiera realizar, el nivel ptimo es el 9 ya que realiza la compresin ms alta que puede tener el archivo afectado. -d Esta opcin permite descomprimir un archivo gzipeado. Sintaxis: gzip -d archivo

-f Fuerza la compresin o descompresin de la informacin afectada sin importar los permisos o propiedades que tenga el archivo o directorio al momento de ser afectado. Sintaxis: gzip [-fn] archivo -t sta opcin hace una revisin del archivo tarareado para verificar su integridad, en caso de que el archivo no se encuentre ntegro el sistema mandara un mensaje indicando el tipo de incongruencia del archivo. Sintaxis: gzip -t archivo.gz

-l sta opcin muestra las propiedades del archivo tarareado indicando el tamao del archivo cuando esta comprimido, el tamao de la informacin cuando se encuentra descomprimida y el porcentaje de compresin de la informacin. gzip lv archivo.tar.gz

Existen dos tipos de ligas, una de ellas es la de tipo suave y la otra es de tipo dura. La liga de tipo suave es un vnculo hacia un archivo pero la liga es de tamao muy pequeo ya que solo hace referencia al archivo que se esta ligando, funciona como un acceso directo y su funcin generalmente es asociar a un programa de nombre complejo con una liga la cual tiene un nombre ms fcil de recordar.

Ligas

Sintaxis de la liga suave ln s nom_archivo nom_liga El comando ln nos permite generar las ligas, en este caso con la opcin s se indica al sistema que se esta generando una liga de tipo suave.

Liga dura La liga dura al igual que la liga suave mantiene una relacin con un archivo el cual esta ligado, la diferencia es que al comparar el tamao de la liga con el archivo, ambos tienen el mismo tamao, al editar el contenido de uno se actualiza automticamente el otro, pero a comparacin de un archivo comn es que la liga esta asociada al mismo inodo del archivo con el que esta ligado.

Sintaxis de la liga dura ln nom_archivo nom_liga En este caso se esta generando una liga dura, al aplicar el comando ln sin opciones el sistema interpreta el comando como la creacin de una liga dura.

También podría gustarte