Logueate





Inteligencia Compartida



Posteado por:

BuleBule
Novato
* Masculino

6 Posts
16 Comentarios
220 Puntos
0 Referido/s

REGISTRATE! es GRATIS!!

 Sistema de Archivos de Linux  
Imprimir post

Acá se explica cual es la estructura del sistema de archivos de Linux, la ubicación y principal función de cada uno de los directorios del sistema y de los distintos archivos de configuración.
Es un texto bastante corto y consiso y sirve para que se saquen muchas dudas quienes están interesados en aprender acerca de este sistema operativo.

(Está dividido en dos partes, porque no entraba todo en un sólo post)



ESTRUCTURA DEL SISTEMA DE ARCHIVOS DE LINUX

Grupo de Standard de el Sistema de Archivos [FSSTND]
Daniel Quinlan
Traductor: Israel Barrientos mailto:jbarrien@ccr.dsi.uanl.mx
Maquetador Linuxdoc-SGML: Antonio Ismael Olea González,
mailto:olea@poboxes.com 2:345/108.9@fidonet.org
r1.2, abril de 1996


El proceso abierto y distribuido en el cual el sistema operativo Linux se ha desarrollado propicia un rápido crecimiento, tanto del sistema operativo, como de aplicaciones, y distribuciones integradas. Por tanto, existe la necesidad de la estandarización de la estructura del sistema de archivos de Linux. Este documento intenta especificar la localización estándar de archivos y directorios en sistemas Linux. Una estructura del sistema de archivos estandarizada permite a usuarios, desarrolladores, y distribuidores, el obtener componentes del sistema de varias fuentes que trabajarán juntas tan bien como si hubiesen sido desarrolladas bajo un proceso de desarrollo centralizado. Ésto también facilita la administración del sistema, así como el desarrollo de paquetes de segundas y terceras personas, y la escritura de documentación que no depende de la implementación.

1. Advertencia legal

Linux no es una Marca Registrada y no tiene conexión con UNIX
UNIX es una marca registrada de XOpen Company, Ltd/.
HP-UX es una marca registrada de Hewlett-Packard.
Novell y Novell NetWare son marcas registradas de Novell.
SunOS Sun Microsystems, Sun NIS, Sun RPC, y NFS son marcas registradas de Sun Microsystems.
System V y SVR4 son marcas registradas de AT&T.
X Windows System es una marca registrada de el X Consortium, Inc.
Todos los otros copyrights son de los propietarios, a menos que se especifique otra cosa .
El uso de cualquier término en este documento no debería ser tomado como que afecte la validez de una marca registrada o servicio registrado.

Copyright 1994 Daniel Quinlan

Se permite la distribución y copia de este estándar siempre que se preserve este copyright y este mensaje en todas las copias.

Se permite a los participantes y contribuyentes de la FSSTND copiar y distribuir versiones modificadas de este estándar para propósitos de las actividades de estandarizacion del sistema de archivos solamente, bajo las condiciones abajo especificadas. Todas las copias o porciones de este documento deben identificar el titulo del documento y la sección, y deben acompañar este aviso en un lugar prominente.

Ninguna porción de este documento puede ser redistribuida en una forma modificada o recortada sin la aprobación previa de el coordinador del FSSTND. Cualquier entidad que busque permiso para distribuir cualquier material derivado de este documento (Que no sean copias idénticas) debe de contactar al coordinador del FSSTND para la licencia apropiada.

2. Prefacio

2.1 Estatus del Estándar

Ésta es la versión 1.2 de la Estructura del Sistema de Archivos de Linux (Linux Filesystems Structure) FSSTND

Las guías de este estándar están sujetas a cambio. El uso de la información contenida en este documento es bajo su propio riesgo.

3. Organización del Estándar

Este estándar está dividido en 6 partes:

    * General: incluyendo un enunciado de enfoque, problemas, objetivos, y requerimientos de conformidad. ( Sección 1).
    * El Sistema de Archivos: Un enunciado de algunos principios guías. ( Sección 2).
    * El Directorio raíz /: ( Sección 3).
    * La jerarquía /usr: ( Sección 4).
    * La jerarquía /var: ( Sección 5).
    * Razonamientos adicionales y asuntos sin resolver ( Sección 6).

3.1 Convenciones Tipográficas

La fuente tipo courier se usa para los nombres de archivos y directorios.

Los componentes de nombres de archivos que varían son representados por una descripción del contenido encerrada entre los caracteres " < " y " > ". Las direcciones de correo electrónico están también encerradas entre " < " y " > " pero se muestran en la fuente usual.

Los componentes adicionales de los nombres de los archivos se encierran entre los caracteres " [ " y " ] " y pueden ser combinados con la convención " < " y " > ". Por ejemplo, si existe un archivo que puede ser encontrado con o sin extensión, éste podría ser representado por <nombre>[.extensión].

Las subcadenas variables de los nombres de archivos y directorios se indican con " * ".

4. General
4.1 Enfoque

Este documento especifica una estructura estándar del sistema de archivos para los sistemas Linux, incluyendo la localización de archivos y directorios, y el contenido de algunos archivos de sistema.

El estándar de sistema de archivos ha sido diseñado para ser usado por desarrolladores de distribuciones, desarrolladores de paquetes e implementadores de sistemas. De cualquier forma está hecho para ser una referencia y no es un tutorial de como manejar un sistema de archivos Linux ó jerarquía de directorios.

Éstos son algunos de los problemas fundamentales que motivaron originalmente el esfuerzo de estandarización. No había una estructura única, bien aceptada estructura de directorios Linux, en su lugar había muchas estructuras cada una incompatible con las demás. Las jerarquías más ampliamente usadas no estaban bien estructuradas y diferían bastante de las estructuras de directorios modernas "estándares" (tales como System V, BSD, SunOS, y otras). El sistema de archivos era poco familiar e incómodo para los usuarios de UNIX con experiencia y los administradores que habían tenido experiencia con otros sistemas operativos similares a UNIX. La falta de regularidad también confundía a los recién-iniciados en Linux, especialmente aquellos que no tenían un conocimiento previo de UNIX. Cualquier incompatibilidad entre las distribuciones primarias de Linux y los paquetes de aplicación se resolvían por métodos de una naturaleza poco elegante. Los enlaces simbólicos(symbolic links) eran usados demasiado frecuentemente para arreglar los problemas. (De todas maneras, hay veces en las que los enlaces se usan para asegurar compatibilidad hacia atrás o para permitir a algunos sistemas específicos que tengan un sistema de archivos individual y muy particular).

En cualquier esfuerzo de estandarización surgen diferencias de opinión. La necesidad del consenso y la práctica común dentro de la comunidad de Linux deben opacar estas diferencias.

Este estándar del sistema de archivos fue primeramente desarrollado dentro de la lista de correo FSSTND y previamente, en el canal FSSTND de la lista de correo de los LINUX-ACTIVISTS. Los comentarios y recomendaciones fueron recibidos de un gran numero de desarrolladores de Linux, notables programadores de Linux, administradores de sistemas y usuarios. Estos voluntarios quienes han contribuido extensivamente al estándar están listados en el final de este documento. Este estándar representa la visión en consenso de éstos y otros contribuyentes.

Este estándar busca atacar los problemas estos problemas con una estructura de sistema de archivos bien diseñada que esperamos que la comunidad Linux seguirá voluntariamente. Aunque este estándar comprende más y es más completo que cualquier anterior intento de estandarización, lo más seguro es que nunca esté verdaderamente terminado. Las necesidades de la comunidad Linux cambiarán continuamente debido a las tecnologías emergentes. Es también muy posible que se descubran mejores soluciones a los problemas que nosotros atacamos o que las soluciones que nosotros ahora proponemos dejen de ser las mejores es por eso que el FSSTND planea publicar suplementos y actualizaciones periódicas a este documento.

Los comentarios relacionados con este documento se agradecen y son bienvenidos por el grupo FSSTND. Cualquier comentario o sugerencia de cambio deberá ser dirigida a al coordinador del FSSTND o si lo prefiere, cualquier coordinador listado en este documento. Los comentarios tipográficos o gramáticos deberán ser dirigidos a el coordinador FSSTND.

Existe también una FAQ mantenida por Ian McCloghrie, que responde algunas de las preguntas más frecuentemente hechas acerca de este estándar. Si desea implementar el FSSTND o si tiene alguna pregunta por favor lea antes el FSSTND FAQ. Ésta está disponible vía ftp anonymous en tsx-11.mit.edu en el directorio /pub/linux/docs/linux-standards/fsstnd/FSSTND-FAQ.

Por favor no mande correo a la lista de correo sin antes contactar a el coordinador del FSSTND o a un colaborador listado. Los mensajes impropios no van a ser bien recibidos en la lista.

Preguntas de como interpretar ciertos artículos en este documento pueden ocasionalmente hacerse, si tiene necesidad de aclarar algún punto, por favor contacte al coordinador. Dado que este estándar representa el consenso de muchos participantes es importante asegurarse que cierta interpretación es también el consenso de su opinión colectiva. Por esa razón puede no ser posible una respuesta inmediata a menos que la pregunta halla sido objeto de discusión previa.

El coordinador del FSSTND es Daniel Quinlan <Daniel.Quinlan@linux.org>

4.2 Problemas específicos.

Naturalmente, existían ciertos problemas específicos que tratábamos de corregir cuando estandarizamos la estructura del sistema de archivos de Linux, estos son algunos de los más obvios y más grandes. Los directorios binarios principales /bin y /usr/bin no tienen divisiones bien definidas entre ellos. Como resultado la distribución de los binarios entre estos dos directorios varía grandemente entre en cada distribución de Linux. Al incluir ambos, los archivos binarios y los de configuración en /etc hace más confuso este directorio y más difícil de mantener para ambos, el administrador de sistema y el usuario inexperto (especialmente aquellos con sistemas grandes) La división entre lo que debe ser un archivo de configuración específico de un site, y lo que es un archivo de configuración local de una máquina es difícil de establecer. Muchas implementaciones comunes de /usr no pueden ser montadas sólo-lectura debido a que contienen archivos variables y directorios a los cuales se necesita escribir En un ambiente en red es deseable servir software a las estaciones de trabajo vía NFS. Tales sistemas de archivos pueden necesitar ser montados sólo-lectura, para que los accidentes o malicia deliberada desde un estación de trabajo no puedan dañar los archivos en el servidor. Ésto requiere la identificación y la separación de los archivos a los que una máquina debe escribir y los que son específicos de una máquina. Las estructuras de los sistemas de archivos Linux tradicionales no eran muy adecuadas para instalaciones en red, las cuales podrían requerir que componentes sólo-lectura dentro del sistema de archivos ( principalmente en la jerarquía /usr ) o involucrar estaciones sin discos.

Mientras que algunos de los mayores problemas fueron atacados, surgieron numerosos y adicionales que necesitan ser resueltos. Este estándar intenta atacar muchos de estos problemas, pero puede haber algo que fue pasado por alto. Si desea traer algo a nuestra atención, por favor note que hubo asuntos que se han discutido largamente y que no fueron incluidos en este estándar.

4.3 Objetivos

Al tratar de resolver los problemas arriba mencionados, se identificaron varios objetivos que necesitaban ser alcanzados en adición a los problemas más técnicos. Estas metas comprenden la corrección de problemas sobresalientes así como la validación de este estándar.

Resolver los problemas listados antes, y al mismo tiempo limitar las dificultades transicionales mientras se traslada desde los antiguos estandartes de facto. Ganar la aprobación de los distribuidores, desarrolladores y otra gente importante en la comunidad Linux, así como alentarlos a que compartan con nosotros sus sugerencias. Proveer un estándar que la comunidad Linux escoja seguir por que resuelve los problemas anteriores y provee la más sensata estructura de sistemas de archivos de las instalaciones Linux.

Algunos de estos objetivos se han completado total o parcialmente debido a la distribución limitada de este documento (en borrador) al distribuidor o desarrollador que solicitó alguno.

4.4 Historia y Progreso

El mensaje original que motivó este esfuerzo para reestructurar el sistema de archivos Linux fue escrito por Olaf Kirsh <okir@monad.swb.de> el 02 de Agosto de 1993 en el entonces canal NORMAL de la lista de correo de los LINUX-activists.

En corto tiempo se decidió que la mejor manera para acometer la necesaria reestructuración de el sistema de archivos de Linux sería la creación de una lista de correo separada con el fin de desarrollar un standard de consenso.

Después de una discusión comprensiva y con muy pocas discordias un borrador preliminar fue emitido, con la ayuda de algunas personas dedicadas, el borrador fue terminado y el borrador resultante sometido a consideración en el canal FSSTND para mayor discusión.

El primer borrador fue emitido al canal el 18 de Septiembre de 1993 por Daniel Quinlan.

Al tiempo que la discusión continuaba y los borradores de las recomendaciones de el FSSTND se desarrollaban más, se establecieron contactos con los desarrolladores más accesibles quienes entonces ofrecieron su apoyo y comentarios a nuestro esfuerzo.

Muchos desarrolladores de Linux estuvieron de acuerdo en que este esfuerzo de estandarización valía la pena y lo apoyaron.

A continuación estan algunos de los desarrolladores que intentan seguir el estándar FSSTND, parcial o completamente, listados en orden alfabético:

ATIM LINUX

    PRO/ Fred N van Kempen et al. <waltje@infomagic.com>
BOGUS LINUX

    Rik Faith, Kevin E. Martin, y Doug L. Hoffman <linux-bogus@cs.unc.edu>
DEBIAN LINUX

    Ian A. Murdock <imurdock@debian.org>
LILO boot loader

    Werner Almesberger <almesber@nessie.cs.id.ethz.ch>
MCC Interim LINUX

    Owen LeBlanc <LeBlanc@mcc.ac.uk>
Red Hat Software LINUX (RHS LINUX)

    Marc Ewing <marc@redhat.com>
Slackware LINUX

    Patrick J. Volkerding <volkerdi@mhd1.moorehead.msus.edu>
TAMU LINUX

    Dave Safford <dave.safford@net.tamu.edu>
util-linux (paquete)

    Rik Faith <faith@cs.unc.edu>
Yggdrasil Plug-and-Play LINUX

    Adam J. Richter <adam@yggdrasil.com>

4.5 Conformidad con este Documento

Esta sección define los términos "conforme" y "compatible" con respecto a este estándar, y el de " "parcialmente" conforme y compatible.

Una "implementación" aquí se refiere a una distribución, un sistema instalado, un programa, un paquete ( o alguna pedazo similar de software o datos), o algún componente de ellos.

Una implementación es totalmente conforme con este estándar si cada requerimiento en este estándar es cubierto. Cada archivo o directorio que sea parte de la implementación debe estar localizado como se especifica en este documento. Si el contenido de un archivo es descrito aquí, el contenido actual debe corresponder con el de la descripción. La implementación también debe intentar encontrar a los archivos o directorios (externos a sí mismo) primeramente o exclusivamente en el lugar especificado en este estándar.

Una implementación es totalmente compatible con este estándar si cada archivo o directorio que contiene puede ser encontrado viendo en el lugar especificado aquí, aún cuando este no sea el lugar primario o el lugar físico del archivo o directorio en cuestión. La implementación debe, cuando intente encontrar cualquier archivo o directorio que no sea parte de sí, en el lugar especificado en este estándar, aunque también puede intentar encontrarlos en otros lugares no-estándar.

Una implementación es parcialmente conforme o compatible si cumple con o es compatible con un subconjunto significante de este documento. La conformidad o compatibilidad parcial se aplica solamente a distribuciones y no a programas separados. La frase subconjunto significante es deliberadamente subjetiva y en casos marginales, la parte interesada deberá contactar al coordinador del FSSTND. Se anticipa que cierta variación será tolerada en casos marginales.

Para calificar como parcialmente conforme con FSSTND o parcialmente compatible con FSSTND, una implementación debe de proporcionar una lista de lugares en los cuales ella y el FSSTND difieren, junto con una nota breve explicando la razón de la discrepancia. Esta lista deberá de ser provista con la distribución en cuestión y deberá estar disponible para la lista FSSTND o el coordinador del FSSTND.

Los términos "tiene que ", "debe", "contiene", "es" y demás deben ser leídos como requerimientos para la conformidad o compatibilidad.

Note que una implementación no necesita contener todos los archivos y directorios especificados en este estándar para ser conforme o compatible. Sólo es necesario que aquellos archivos y directorios que sí contiene, que estén localizados apropiadamente. Por ejemplo si el sistema de archivos ext2 no está soportado por una distribución, las herramientas ext2 no necesitan estar incluidas, aunque se mencionen explícitamente en la sección sobre /sbin.

Más aún, ciertas porciones de este documento son opcionales. En este caso se enunciará explícitamente, o se indicará con el uso de una o más de las palabras " puede", "se recomienda" o "se sugiere" . Los artículos marcados como opcionales no tienen influencia en la conformidad o compatibilidad de una implementación, sólo son sugerencias pensadas para motivar la práctica común, pero pueden estar localizados en cualquier lugar a juicio del implementador.

5. El sistema de Archivos

El sistema de archivos UNIX está caracterizado por:

Una estructura jerárquica.
Un tratamiento consistente de la informacion de los archivos.
Proteccion de los archivos.

Este estándar del sistema de archivos Linux sigue el mismo principio basico que la mayoría de los sistemas de archivos UNIX siguen. Note, sin embargo que este estándar no intenta concordar en cada aspecto posible con alguna implementacion particular del sistema UNIX. De cualquier forma, muchos de los aspectos de este estándar estan basados en ideas encontradas en UNIX y sistemas similares a UNIX.

Es posible después de cuidadosa consideracion de otros factores, incluyendo:

Prácticas comunes en la comunidad Linux.
La implementación de otras estructuras de sistemas de archivos.
Los estándares aplicables.

Definir dos categorizaciones ortogonales de archivos: Compartibles vs. no compartibles, y variables vs. estaticos.

La informacion compartible es aquella que puede ser compartida entre varias máquinas diferentes; la no compartible es aquella que debe ser local a una máquina particular. Por ejemplo. Los directorios hogar de los usuarios son compartibles, pero los archivos de bloqueo de dispositivo (lock files) son no compartibles.

La información estática incluye binarios, librerias, documentación y todo aquello que no cambia sin la intervención del administrador del sistema. La informacion variable es todo lo que cambia sin la intervención del administrador.

El entendimiento de estos principios básicos ayudará a guiar la estructura, a lo largo de este documento, y en cualquier sistema de archivos bien planeado, esto brindará consistencia adicional.

La distinción entre información compartible y no compartible es necesaria por varias razones:

En un ambiente de red (i.e. más de un host en un site), existe una buena cantidad de información que se puede compartir entre diferentes máquinas para ahorrar espacio y facilitar la tarea de administración.
En un ambiente de red, ciertos archivos contienen información específica a una sola máquina, por tanto, estos sistemas de archivos no pueden ser compartidos (sin tomar medidas especiales).
Las implementaciones de facto del sistema de archivos no permitían que la jerarquía /usr fuera montada sólo-lectura, porque contenía archivos y directorios que nesecitaban ser escritos muy frecuentemente. Éste es un factor que debe atacarse cuando algunas partes de /usr se comparten en una red, o se montan sólo-lectura debido a otras consideraciones tales como la seguridad.

La distincion "compartible" puede ser usada para soportar, por ejemplo:

    * Una partición /usr (o componentes de /usr) montada (sólo-lectura) atraves de la red (usando NFS).
    * Una particion /usr (o componentes de /usr) montada desde medios de sólo-lectura.Un cd-rom puede ser considerado como un sistema de archivos sólo-lectura compartido con otros sistemas Linux utilizando el sistema de correo como una red.

La distincion "estática" contra "variable" afecta el sistema de archivos de dos maneras principales:

Dado que / contiene ambos tipos de información, variable y estática necesita montarse lectura-escritura.
Dado que el /usr tradicional contiene ambos tipos de información variable y estática y dado que podríamos desear montarlo sólo-lectura (vea arriba), es necesario proporcionar un método para hacer que /usr se monte sólo-lectura. Ésto se logra con la creación de una jerarquía /var que se monta lectura-escritura (o es parte de una partición lectura-escritura tal como /), que toma mucho de la funcionalidad tradicional de la particion /usr.

5.1 Tabla con ejemplos.

CompartibleNo-CompartibleEstática/usr/etc/home/bootVariable/var/spool/mail/var/run/var/spool/news/var/lock3. El directorio raíz /. Esta sección describe la estructura del directorio raíz. El contenido del sistema de archivos raíz será el adecuado para arrancar, bootear, restaurar,recuperar y/o reparar el sistema:

Para arrancar el sistema, debe estar presente lo suficiente como para montar /usr y otras partes no-esenciales del sistema de archivos. Ésto incluye herramientas, información de configuración y del cargador de arranque (boot loader) y alguna otra información esencial al arrancar.
Para habilitar la recuperación y/o la reparación del sistema, estará presente en el sistema de archivos raíz aquellas herramientas que un administrador experimentado necesitaría para diagnosticar y reconstruir un sistema dañado.
Para restaurar un sistema, estarán presentes en el sistema de archivos raíz aquellas herramientas necesarias para restaurar el sistema desde respaldos (en floppy, cintas, etc).

La principal preocupación que se usa para balancear las anteriores consideraciones, que favorecen el colocar muchas cosas en el sistema de archivos raíz, es la meta de mantener / tan pequeno como sea razonablemente posible. Por varias razones es deseable mantener el sistema de archivos /

Es frecuentemente montado desde media muy pequena. Por ejemplo muchos usuarios de Linux instalan y recuperan sistemas montando / como un disco ram, que es copiado de un disco de 1.44Mb único.
El sistema de archivos / tiene muchos archivos de configuración específicos de un sistema. Posibles ejemplos son un kernel que es específico al sistema, un hostname diferente, etc. Ésto significa que el sistema de archivos / no es siempre compartible entre sistemas en red. Manteniéndolo pequeño en sistemas en red, se minimiza el espacio perdido en los servidores por archivos no-compartibles. También permite estaciones de trabajo con discos duros locales más pequeños.
Aunque usted podría tener el sistema de archivos / en una partición grande, y ser capaz de llenarla según sus deseos, siempre habrá gente con particiones más pequeñas. Si usted tiene más archivos instalados, podría encontrar incompatibilidades con otros sistemas que utilizan un sistema de archivos / en particiones más pequeñas. Si usted es un desarrollador entonces estaría volviendo su suposición en un problema para un gran número de usuarios.
Los errores del disco, que corrompen la información en el sistema de archivos / son un problema mayor que los errores en cualquier otra partición. Un sistema de archivos / pequeño es menos propenso a corromperse como resultado de una falla del sistema.
En este documento, actualmente se requiere un sistema de archivos / escribible (debido principalmente a /etc/mtab). De cualquier forma, no se necesita que el sistema de archivos / esté totalmente almacenado localmente. La partición / no tiene porque estar almacenada localmente para ser específica del sistema por ejemplo, podría estar montada de un servidor NFS.

El software no deberá crear o requerir archivos o subdirectorios especiales en el directorio /. La estructura del sistema de archivos Linux proporciona más que suficiente flexibilidad para cualquier paquete. Cualquier paquete que ocupe un directorio bajo la raíz / del sistema de archivos sufre de bastante arrogancia.

5.2 El Directorio Raíz

    bin             Binarios de comandos esenciales 
    boot            Archivos estáticos de cargador de arranque(boot-loader)
    dev             Archivos de dispositivos
    etc             Configuración del sistema local-máquina
    home            Directorios home de los usuarios
    lib             Librerías compartidas
    mnt             Punto de montaje de particiones temporales
    root            Directorio hogar del usuario root
    sbin            Binarios del sistema esenciales
    tmp             Archivos temporales
    usr             Segunda jerarquía mayor
    var             Información variable

Cada directorio listado será discutido en detalle en una subsección separada más delante. /usr y /var, cada uno tiene en su propia sección en este documento.

El kernel de Linux estaría localizado en, ya sea / ó en /boot. Si está localizado en / recomendamos usar el nombre VMLINUX o VMLINUZ, nombres que han sido usados en paquetes fuentes del kernel de Linux recientes. Más información de la localización del kernel se puede encontrar en la sección acerca de / más delante.

5.3 /bin Binarios de comandos esenciales de usuarios (disponibles para todos los usuarios).

bin contiene comandos que pueden ser utilizados por ambos los usuarios y /el administrador del sistema, pero que son requeridos en el modo /mono-usuario (single-user mode) puede también contener comandos que son /utilizados indirectamente por algunos scripts.

Todos los binarios utilizables sólo por root, tales como daemons,init,getty, update, etc. Estarían localizados en /sbin ó /usr/sbin dependiendo si son o no esenciales. Para una mayor discusión de la definición de que es esencial en el sistema de archivos /, lea por favor la sección 6, "Razonamientos adicionales y asuntos sin resolver".

No habrá subdirectorios dentro de /bin.

Los binarios de los comandos que no son suficientemente esenciales para estar en /bin estarán localizados en /usr/bin, los elementos que son utilizados por usuarios solamente (pero no por root) (mail,chsh, etc) no son suficientemente esenciales para estar dentro de la partición /.

Archivos requeridos en /bin:

Comandos generales:

Los siguientes comandos han sido incluidos porque son esenciales. algunos están presentes debido a que tradicionalmente han estado en /bin.

    arch, cat, chgrp, chmod, chown, cp, date, dd, df, dmesg, echo, ed, false,kill, in, login, mxdir, mknod, more, mount, mv, ps, pwd, rm, rmdir, sed, setserial, sh, sfty, su, sinc, true, umount, uname.

Si /bin/sh es Bash, entonces /bin/sh sería en enlace simbólico o duro a /bin/bash dado que bash se comporta diferente cuando es llamado como sh ó bash. La pdksh que puede ser la /bin/sh en los discos de instalación y sería igualmente arreglada a que /bin/sh sea un enlace simbólico a /bin/ksh. El uso de enlaces simbólicos en estos casos permite que los usuarios vean fácilmente que /bin/sh no es una shell estilo bourne.

Dado que la localización estándar de facto de shell estilo c es /bin/csh,si y sólo si está disponible en el sistema una shell estilo c ó equivalente (tal como /bin/tcsh, esta, estaría disponible con el nombre /bin/csh. /bin/csh puede ser un enlace simbólico a /bin/tcsh ó /usr/bin/tcsh).

Los comandos [ y test están interconstruidos en bash, pdksh, zsh, y las shell korn recientes, esencialmente cada remplazo de las shell tipo bourne que hay para Linux. Estos comandos estarían localizados dentro de /usr/bin. (se deben incluir como binarios separados con cualquier sistema Linux que intente cumplir con el estándar POSIX).

bin/arch produciría el mismo resultado que uname-m, especificamente; 386 /o; 486 para sistemas intel y compatibles.

Comandos para restauración.

Estos comandos se han incluido para hacer posible el restaurar el sistema(siempre que / este intacto).

    tar, gzip, gunzip (enlace hacia gzip), zcat (enlace hacia gzip).

Si se hacen respaldos de sistemas utilizando otros programas, entonces la particion / contendrá los componentes mínimos necesarios. Por ejemplo,muchos sistemas incluirían cpio como la segunda utilería más usada para respaldos después de tar. Pero si jamás se espera restaurar el sistema desde la partición /, entonces estos binarios se pueden omitir (i.e.,montar / en chip ROM, montar /usr desde NFS). Si la restauración del sistema se planea a traves de la red, Entonces FTP ó TFTP (junto con todo lo necesario para obtener una conexión FTP) estarían disponibles en la partición /.
Los comandos de restauración pueden aparecer en, ya sea /bin ó /usr/bin en sistemas Linux diferentes.

Comandos de red.

Éstos son unicamente los binarios de red que los usuarios y root querrán o necesitarán ejecutar que no sean los que estan en /usr/bin ó /usr/local/bin

    domainname, hostname, netstat, ping.

5.4 /boot: Archivos estáticos del cargador de arranque (boot loader).

Este directorio contiene todo para arrancar excepto los archivos de configuración y el instalador de mapas. En su sentido más sencillo /boot es para cualquier cosa que se utiliza antes de que el kernel ejecute /sbin/init. Ésto incluye sectores maestros de arranque (master boot sectors) guardados, archivos de mapeo de sectores y cualquier otra cosa que no es editada directamente a mano.Los programas necesarios para arreglar que el cargador de arranque sea capaz de arrancar un archivo (tal como el instalador de mapas [lilo] ) estarán localizados en /sbin. Los archivos de configuración para cargadores de arranque podrían estar localizados en /etc.

Como se expuso arriba, el kernel de Linux puede estar localizado en / ó en /boot, si se localiza en /boot, recomendamos que se le dé un nombre más descriptivo.

5.5 /dev Archivos de dispositivos.

Éste es el directorio de los dispositivos. Contendría un archivo por cada dispositivo que el kernel de Linux puede soportar.

dev también contiene un script llamado MAKEDEV el cual puede crear /dispositivos cuando se necesiten. Puede contener un MAKEDEV local para /dispositivos sólo-local.

MAKEDEV debe hacer previsión para crear cualquier archivo de dispositivo especial listado en la lista de numeros mayores/menores, no sólo aquellos de una distribución particular.

Los enlaces simbólicos no se deben distribuir en sistemas Linux, sino sólo como se preveé en la lista de dispositivos de Linux. Ésto es porque las instalaciones locales seguro diferirán de aquellas de la máquina del desarrollador. Ademas si un script de instalación configura enlaces simbólicos en la instalación, estos enlaces seguramente no se actualizarán si se hacen cambios locales en el hardware. Cuando se usan responsablemente,como sea, son de buen uso.

Este documento incorpora como referencia la lista de dispositivos de Linux, mantenida por: Peter.Anvin@linux.org: El encargado de los dispositivos Linux.Todos los archivos especiales de dispositivo seguirán el estándar en ese documento, que está disponible en ftp.yggdrasil.com en /pub/device-list.

5.6 /etc : Configuración del sistema local a la máquina.

etc contiene archivos y directorios que son locales al sistema actual.

Ningún binario debe ir directamente dentro de /etc. Los binarios que en el pasado se encontraban en /etc, irán en /sbin ó /usr/sbin. Ésto incluye archivos tales como init, getty y update. Los binarios tales como hostname que son utilizados por usuarios ordinarios y por root no irían en /sbin sino en /bin.

    /etc --- Configuracion de sistemas locales de máquina.

    X11             Archivos deconfiguracion para el x11
    skel            Esqueletos de configuracion de usuarios

etc/skel es la localidad para los llamados archivos esqueletos de /usuarios, que le son dados por defecto cuando un nuevo usuario recibe una /cuenta, este directorio puede contener subdirectorios para diferentes /grupos de usuarios (i.e./etc/skell/apoyo, /etc/skell/usuarios).

etc/X11 es el lugar recomendado para todos los archivos de configuración /de X11 locales a la máquina. Este directorio es necesario para permitir el /control local si /usr se monta sólo-lectura. Los archivos que deben ir en /este directorio incluyen Xconfig (y/o XF86Config) y Xmodmap.

Los subdirectorios de /etc/X11 pueden incluir aquellos para xdm y para cualesquier otros programas (como algunos manejadores de ventanas por ejemplo) que lo necesiten. Recomendamos que los manejadores de ventanas con un solo archivo de configuración que es un archivo .*wmrc por defecto, que lo llamen system.*wmrc (a menos que exista una alternativa ampliamente aceptada) y que no utilize un subdirectorio. Cualquier subdirectorio de un manejador de ventanas se llamaría idéntico al binario del manejador de ventanas.

etc/X11/xdm retiene los archivos de configuración de xdm. Ésto es la /mayoría de los archivos normalmente hallados en /usr/lib/X11/xdm; Vea la /seccion 5,/var/lib/xdm, para mayor información.

La siguiente sección intenta parcialmente examinar la descripción del contenido de /etc con algunos ejemplos: Definitivamente ésta no es una lista exhaustiva.

Archivos requeridos en /etc:

Archivos generales:

Estos archivos son necesarios en la mayoría de los sistemas Linux.

    adjtime, csh.login, disktab, fdprm, fstab, gettydefs, group, inittab, issue, ld.so.conf, lilo.conf, magic, motd, mtab, mtools, passwd, profile, psdatabase, securetty, shells, syslog.conf, tercamp, ttytype

Archivos de Red:

Estos archivos estarían instalados en la mayoria de los sistemas Linux.

     

    exports, ftpusers, gateways, hosts, host.conf, host.equiv, host.lpd,
    inetd.conf, networks, printcap, protocols, resolv.conf.rpc, services

Hay dos modelos para la instalación de los scripts de comandos "rc" los cuales son invocados por init(8) al momento de arrancar, el modelo /etc/rc.d/* estilo SystemV. Cualquiera puede ser utilizado o una mezcla de los dos.

Los sistemas con la suite de passwords sombreadas (shadow password) tendrán archivos de configuración adicionales, en /etc (/etc/shadow y otros) y /usr/bin (useradd, usermod, y otros).

5.7 /home: Directorios hogar de los usuarios (opcional)

home es un concepto algo estándar, pero es claramente un sistema de /archivos específico de un site. El arreglo diferirá de máquina a máquina. /Esta sección describe una localización sugerida para los directorios hogar /de los usuarios, aun así, recomendamos que todas las distribuciones /Linux usen este lugar como la localización por defecto de los /directorios hogar.

En sistemas pequeños, cada directorio de usuario es uno de los subdirectorios debajo de /home, p.ej. /home/smith, /home/torvalds, /home/operador, etc.

En sistemas grandes (especialmente cuando los directorios /home son compartidos entre varias máquinas usando NFS) es útil subdividir los directorios hogar. La subdivisión puede ser llevada a cabo utilizando subdirectorios tales como /home/apoyo, /home/huéspedes, /home/estudiantes, etc.

Muchas personas prefieren poner las cuentas de los usuarios en una variedad de lugares. Por tanto, ningún programa deberá confiar en esta localización. Si usted desea encontrar el directorio hogar de cualquier usuario, debería usar la función de librería getpwent(3) en vez de contar con /etc/passwd, por que la información puede estar almacenada remotamente usando usando sistemas como NIS.

5.8 /lib: Librerías compartidas y módulos de kernel escenciales

El directorio /lib contiene aquellas imágenes de las librerías compartidas que se necesitan para arrancar el sistema y ejecutar los comandos en el sistema de archivos raíz.

lib --- librerías compartidas y modulos de kernel esenciales.
modules Modulos de kernel cargables.

Esto incluye /lib/libc.so.*, /lib/libm.so.*, el enlazador dinámico compartido /lib/ld.so.*, y otras librerías compartidas requeridas por binarios en /bin y /sbin.

Las librerías que son necesitadas sólo por los binarios en /usr (como cualquier binario de X Window) no pertenecen a /lib. Sólo las librerías compartidas requeridas para ejecutar los binarios dentro de /bin y /sbin deben estar aquí. La librería libm.so.* podría estar localizada en /usr/lib si no es requerida por nada en /bin ó /sbin.

Por razones de compatibilidad, /lib/cpp necesita existir como una referencia al pre-procesador C instalado en el sistema. La localización usual del binario es /usr/lib/gcc-lib/<target>/<version>/cpp. Puede existir un enlace/lib/cpp apuntando a este binario o a cualquier otra referencia a este binario que exista en el sistema de archivos. (Por ejemplo, /usr/bin/cpp se usa frecuentemente).

La especificación para /lib/modules está aún por aparecer.

5.9 /mnt: Punto de montaje para sistemas de archivos montados temporalmente.

Este directorio se ha provisto para que el administador pueda montar temporalmente sistemas de archivos cuando lo necesite. El contenido de este directorio es un asunto local y no debe afectar la manera en la cual se ejecuta ningún programa.

Recomendamos la no utlización de este directorio por programas de instalación, y sugerimos utilizar un directorio temporal adecuado que no este en uso por el sistema.

5.10 /proc: Sistema de archivos virtual de informacion de procesos y del kernel.

El sistema de archivos proc se está convirtiendo en el estándar de facto para el manejo de informacion de procesos y de sistema en vez de /dev/kmem y otros metodos similares. Recomendamos fuertemente esto para el almacenamiento y obtención de información de procesos asi como otra información del kernel y de memoria.

5.11 /root: Directorio hogar de root (opcional)

El directorio / es tradicionalmente el directorio hogar del usuario root en los sistemas UNIX. /root se usa en muchos sistemas Linux y en algunos sistemas UNIX. El directorio hogar de la cuenta de el usuario root puede ser determinada por el desarrollador o por preferencias locales. Las posibilidades obvias incluyen /, /root, y /home/root.

Si el directorio hogar de root no está almacenado en la partición raíz, será necesario asegurarse que tome / por defecto si no puede ser localizado.

NOTA: Recomendamos contra el uso de la cuenta root para cosa mundanas tales como leer el correo y ver las noticias (mail & news) sino que se use solamente para la administración del sistema. Por esta razón recomendamos que no aparezcan subdirectorios como Mail y News en el directorio hogar de la cuenta del usuario root. Recomendamos que el Mail para root y postmaster sean redirigidos a un usuario más adecuado.

5.12 /sbin: Binarios del Sistema (Alguna vez mantenidos en /etc)

Los útiles usados por la administración del sistema ( y otros comandos que sólo root utiliza ) están almacenados en /sbin, /usr/sbin, y /usr/local/sbin. /sbin típicamente contiene binarios escenciales para arrancar el sistema ademas de los binarios en /bin. Cualquier cosa que se ejecuta después de que se sabe que /usr se ha montado (cuando no hay problemas) debería estar en /usr/sbin. Los binarios de administración de sistema sólo-locales deben estar localizados en /usr/local/sbin.

Decidir que cosa va en los directorios de /sbin es sencillo: Si un usuario necesitará ejecutarlo, debe de ir en otro lado. Si sólo será ejecutado por el administrador del sistema o por root como scripts de administración, entonces debe ir en /sbin (o en /usr/sbin o en /usr/local/sbin, si el archivo no es vital para la operación del sistema).

Archivos como chfn que los usuarios usan sólo ocasionalmente deben aun estar en /usr/bin. ping aunque es absolutamente necesario para el root (recuperación de la red y diagnóstico) es tambien frecuentemente usado por los usuarios y por esa razon debe ir en /bin.

Los usuarios ordinarios no tendrán que poner ninguno de los directorios sbin en su búsqueda (path).

Recomendamos que los usuarios tengan permisos de lectura y ejecución en todo lo que se encuentra en /sbin excepto tal vez ciertos programas; setuid y setgid. La división entre /sbin y /bin no fue creada por motivos de seguridad o para evitar que los usuarios vieran el sistema operativo, sino para proveer una buena partición entre binarios que todos usan y los que se usan, principalmente las tareas de administración. No hay ganancia inherente en seguridad en hacer que /sbin este fuera del alcance de los usuarios.

Archivos requeridos en /sbin:

Comandos Generales.

    clock, getty, init, update, mkswap, swapon, swapoff, telinit.

Comandos de Apagado.

    fastboot, fasthalt, halt, reboot, shutdown.

Comandos de manejo de sistemas de archivos.

    fdisk, fsck, fsck.*, mkfs, mkfs.*

donde * = uno de los siguientes.
ext, ext2 minix, msdos, xia, y tal vez otros.

Comandos del sistema de archivos ext2 (opcional)

    badblocks, dumpe2fs, e2fsck, mke2fs, mklost+found, tune2fs.

Instalador del mapa del cargador de arranque.

    lilo

Comandos de Red.

    arp, ifconfig, route.

Archivos opcionales en /sbin:

Binarios estáticos. (compilados estáticamente)

ln estático sln y sync estático ssync son útiles cuando las cosas salen mal. El principal uso de sln (reparar enlaces simbólicos incorrectos en /lib despues de una actualización mal orquestrada) ya no es preocupación mayor ahora que existe el programa ldconfig (usualmente localizado en /usr/sbin) y puede actuar como una mano guiadora al actualizar las librerías dinámicas. sync estático es útil en algunas ocasiones de emergencia. Note que estas no necesitan ser versiones compiladas estáticamente de los ln y sync estándares, pero pueden ser.

El binario ldconfig es opcional en /sbin, dado que un site puede escoger ejecutar ldconfig al arrancar, en vez de sólo cuando se actualizan las librerías compartidas. (No está claro si es o no ventajoso ejecutar ldconfig en cada arranque). Aun así, a algunos les gusta tener ldconfig a la mano para las siguientes (muy comunes) situaciones:
Se acaba de remover /lib/<archivo>.
No se puede encontrar el nombre de la librería porque ls está enlazado dinámicamente. Se está usando una shell que no tiene ls interconstruida y no se sabe como usar "echo * " como remplazo.
Se tiene un sln, pero no se sabe como nombrar al enlace.

    ldconfig, sln, ssync.

Misceláneos

Para lidiar con el hecho de que muchos teclados vienen con una tasa de repeticion tan alta como para hacerlos inutilizables, se puede instalar kbdrate en /sbin en algunos sistemas. Dado que la acción por defecto del kernel ante la combinacion de teclas Ctrl-Alt-Del es un rearranque instantáneo duro, es recomendable generalmente deshabilitar esta conducta antes de montar el sistema de archivos raíz con modo lectura-escritura. Algunas suites init son capaces de deshabilitar Ctrl-Alt-Del, pero otras pueden requerir el programa ctrlaltdel, el cual puede ser instalado en /sbin en estos sistemas.

ctrlaltdel, kbdrate

5.13 /tmp: Archivos temporales.

tmp se utiliza para archivos temporales, preferentemente en un /dispositivo rápido (un sistema de archivos basado en memoria por ejemplo)

La "persistencia" de la informacion que es almacenada en /tmp es diferente de aquella que sea almacenada en /var/tmp. /tmp puede ser limpiada en cada arranque o a intervalos relativamente frecuentes. Por tanto, no se debe esperar que la informacion almacenada en /tmp permanezca por algún periodo largo de tiempo.

Los programas deben utilizar /tmp ó /var/tmp (que era originalmente /usr/tmp) de acuerdo a los requerimientos esperados de la informacion, pero no deben confiar en alguna persistencia temporal particular en cualquier directorio de almacenamiento temporal.

Los administradores de sistemas pueden elegir enlazar /tmp a algun otro directorio, tal como /var/tmp; esto es útil, por ejemplo, para conservar espacio en la partición raíz. Si ésto se lleva a cabo, entonces la persistencia de archivos en /var/tmp debe ser al menos tan larga como la de /tmp.

tmp puede estar e un disco RAM. /var/tmp no debe nunca localizarse en /algun dispositivo RAM.



Parte 2

FUENTE: http://server-die.alc.upv.es/alumno/linux/fsstnd12/fsstnd12.html#toc2
Información del Post
 122 Visitas0 Favoritos 0 Puntos
Creado el: Septiembre 12, 2009, 09:26:49 pm
Categoría: Distros
Tags: unix  GNU  debian  LINUX  estructura  sistema de archivos 
Agregar a:
1 Comentarios
#1 DrLemon | 13.9.2009 05:09:16 dijo:
el comentario y puntines, en la segunda parte...

(excelente aporte)