Todo lo que necesita saber sobre el sistema de archivos Linux

Los archivos y su manipulación se encuentran en el centro de la informática moderna. Incluso uno de los principios básicos de todos los sistemas similares a Unix es describir todo en el sistema como archivos. Es válido para prácticamente todos los sistemas Linux. Desde directorios hasta dispositivos, su distribución de Linux trata todo en su sistema como archivos. Ahora, los sistemas también deben incorporar un medio para almacenar y administrar estos archivos. Aquí es donde entran en juego los sistemas de archivos de Linux. Dado que Linux admite numerosos sistemas de archivos e implementa varias operaciones para ellos, creemos que es necesario proporcionar a nuestros lectores algunos conocimientos sobre cómo funcionan los sistemas de archivos en Linux.

Fundamentos del sistema de archivos Linux

El sistema de archivos de Linux es responsable de almacenar los datos de su sistema y administrarlos. Un sistema de archivos se puede definir como el mecanismo detrás del . Los sistemas de archivos generalmente se componen de varias capas, incluida una capa lógica que proporciona interacción con el usuario, API para diferentes operaciones de archivos, etc.

Es posible que haya notado que toda su instalación de Linux se resuelve en torno al punto / . Se llama raíz del sistema de archivos y es esencialmente el punto de partida de su sistema. Contiene varios directorios, la mayoría con algún significado histórico. Discutiremos la jerarquía del de archivos de adelante en esta guía.

Comprobación del sistema de archivos de Linux

Puede conectar componentes adicionales a esta jerarquía del sistema de archivos montándolos en un punto de montaje. Una vez montado, los usuarios pueden atravesar nuevos sistemas de archivos usando este punto. Le mostraremos cómo hacer esto en las siguientes secciones. Ahora bien, ¿cómo realiza el sistema un seguimiento de estos sistemas de archivos? En resumen, utiliza tablas de particiones predefinidas para determinar los inodos (puntos de partida), los límites, los nombres y otra información para hacer esto.

Al definir tablas de particiones utilizando , es posible que haya notado que hay varios tipos de sistemas de archivos. Algunos ejemplos comunes son NTFS, FAT y EXT. Linux admite una amplia gama de tipos de sistemas de archivos, como verá más adelante.

Descubriendo la estructura del sistema de archivos de Linux

El sistema de archivos de Linux se parece mucho al sistema de archivos de Unix original . Aunque las innovaciones informáticas modernas han contribuido al aumento de las nuevas tendencias, la jerarquía del sistema de archivos sigue siendo casi la misma debido a su importancia histórica. Hemos delineado esta jerarquía usando ejemplos apropiados en esta sección. Suponemos que está familiarizado con el intérprete de línea de comandos, también conocido como .

De forma predeterminada, al usuario se le presenta el directorio / home / USER en cada inicio de sesión. Puede confirmar esto escribiendo pwd en la terminal. Usaremos tree , una de las utilidades de facto para visualizar jerarquías de directorios en Linux. Puede obtener esto en Ubuntu emitiendo sudo apt install tree .

comando de árbol

Si ejecuta tree en su directorio actual, es probable que se encuentre en una estructura compleja y críptica. Sucede porque el árbol atraviesa cada elemento en esta ubicación (es decir, imágenes, documentos, descargas, etc.) de forma recursiva y crea la estructura final combinándolos. Sin embargo, puede agregar el indicador -L para especificar la profundidad de este comando.

$ tree -L 1

La ejecución de este comando le dará una estructura sencilla en forma de árbol que consta solo de los componentes del primer nivel de su punto de partida. Puede aumentar este valor para obtener una visualización más transparente y sólida. Puede usar el comando cd para cambiar ubicaciones dentro de su sistema de archivos. Ahora, hemos discutido anteriormente que todo en Linux es un archivo. Entonces, un directorio debe ser un archivo. De hecho, es.

Los directorios son solo archivos especiales que contienen el nombre de otros archivos (también conocidos como elementos secundarios). Las nuevas instalaciones de Linux vienen con algunos directorios incorporados. Los discutiremos a continuación. Le ayudará a comprender mucho mejor su sistema.

Primero, vaya a la raíz de su sistema usando cd / y ejecute ls . Esto le mostrará todos estos directorios predeterminados. Continúe leyendo para descubrir su propósito.

Estructura del sistema de archivos de Linux

/compartimiento

Contiene los binarios, también conocidos como ejecutables de los diversos programas instalados en su máquina. En muchos sistemas, esto no existe como un directorio real, pero sirve como enlace simbólico al directorio / usr / bin .

/bota

Todos los archivos esenciales necesarios para el inicio del sistema se encuentran aquí. No debe experimentar con el contenido de este directorio a menos que sepa lo que está haciendo. De lo contrario, podría dañar el sistema en sí e interrumpir la funcionalidad.

/ dev

El directorio / dev contiene los archivos de dispositivo de su sistema. Estas son las representaciones de archivos de sus unidades USB, unidades de disco duro, cámara web, etc.

/ etc

Históricamente, el directorio / etc se utilizó para mantener varios archivos diversos. Hoy, sin embargo, es una convención estándar almacenar los archivos de configuración de todo el sistema en este directorio. Aquí se almacena información como su nombre de usuario / contraseña, credenciales de red, punto de montaje de particiones.

/casa

Este es el directorio personal del usuario. Puede albergar varios subdirectorios en función del número de usuarios de su máquina. Digamos que es un usuario “maníaco”, entonces se le asignará el directorio / home / maniac . Cuando inicie sesión, se le presentará el directorio / home / maniac dentro de su terminal. También se indica como : $ en el shell Bash.

/ lib

Las bibliotecas del sistema se encuentran aquí. Estos son los fragmentos de código utilizados por sus aplicaciones para realizar alguna tarea. Su ejemplo incluye fragmentos de código que dibujan ventanas o envían archivos.

/medios de comunicación

Este directorio es el punto de montaje de dispositivos plug and play, como el almacenamiento externo. Es una adición relativamente nueva al sistema de archivos de Linux.

/ mnt

Los viejos y malhumorados administradores de Unix usaban este directorio para montar dispositivos o particiones bajo demanda manualmente. Aunque se usa con poca frecuencia, permanece en el sistema de archivos de Linux debido a su importancia histórica.

/optar

Significa opcional y destinado a contener archivos de sistema opcionales. Los administradores a menudo lo utilizan para alojar aplicaciones de terceros que instalaron desde la fuente.

/ proc

Alberga los archivos de proceso, los módulos del kernel y datos dinámicos similares. No debe interferir con esto, de lo contrario, puede hacer que su sistema quede obsoleto.

/raíz

Me gusta / home pero para el superusuario del sistema. Es el directorio que se le presentará cuando cambie a la cuenta raíz.

/correr

Se utiliza para almacenar datos temporales utilizados por los procesos del sistema Linux. No te metas aquí a menos que sepas lo que estás buscando.

/ sbin

Me gusta / bin pero contiene solo los binarios esenciales del sistema. Varias utilidades de uso diario como ls, cd, cp, etc. se encuentran aquí. No los manipule.

/ usr

Una ubicación de ‘úselo para todo tipo’ donde se almacena información diversa. Pueden incluir binarios, bibliotecas, iconos, manuales, etc.

/ srv

El directorio del servidor. Contiene los archivos de origen de las aplicaciones web y alberga otros protocolos de comunicación.

/ sys

Otro directorio virtual, como / dev . Contiene información confidencial y no debe experimentarse a menos que el usuario sepa lo que está haciendo.

/ tmp

Se utiliza para almacenar valores temporales que se eliminarán durante el reinicio del sistema.

/ var

El propósito original de este directorio era alojar todos los archivos variables. Hoy en día, contiene varios subdirectorios para almacenar cosas como registros, cachés y demás.

Puede haber algunos directorios adicionales en su raíz. Por lo general, está sujeto a la distribución específica de Linux y puede variar según los sistemas.

Inspección de la jerarquía del sistema de archivos de Linux

Puede moverse rápidamente por la jerarquía de su sistema de archivos utilizando herramientas de línea de comandos estándar. Hemos compilado una lista de algunos de los para este propósito. Dirígete hacia allí si te resulta difícil seguir el ritmo de la siguiente sección.

Entonces, después de encender su terminal, está en la ubicación / home / USER , señalada por el signo : $ . Puede moverse a una nueva ubicación mediante el cd (cambiar directorio) de comandos como cd / etc . Utilice el comando de árbol como se muestra a continuación para generar una estructura de visualización simple de su directorio actual, como se muestra a continuación.

$ tree -L 1

estructura de directorio con árbol

Puede ver el tipo de un archivo usando el comando ls -l . La primera sección de su salida denota con qué tipo de archivos está tratando. Por ejemplo, digamos que su directorio actual contiene un subdirectorio llamado Imágenes y un archivo de texto llamado prueba. Emita el comando ls -l en este directorio y busque la línea que contiene información sobre estos dos elementos.

Verá que la línea que contiene la carpeta Imágenes comienza con d , como en el directorio. Mientras tanto, el elemento inicial de la línea para la prueba debería ser , que denota archivos regulares. Otros archivos como dispositivos y sockets se representan de manera similar. Los archivos especiales se indican con c , los sockets con s , las tuberías con p , los dispositivos de bloque con by los enlaces simbólicos con l .

enumerar archivos y directorios

Otro comando robusto que se puede utilizar para determinar el tipo de un archivo es el comando de archivo en sí. Para el ejemplo anterior, ejecutar el archivo de comando Imágenes produciría el resultado ‘directorio’. Además, la prueba de archivo debería producir algo como texto ASCII, que denota un archivo de texto simple.

$ file FILENAME

También puede usar el comando mount para adjuntar un sistema de archivos en una ubicación específica en su jerarquía. El siguiente comando monta el dispositivo / dev / sdb en / home / USER / devices .

$ sudo mount /dev/sdb /home/USER/devices

El usuario ahora puede acceder al contenido de este dispositivo desde la ubicación seleccionada. Para encontrar el nombre de un dispositivo de bloque, puede usar el comando lsblk . De manera similar, lspci se puede usar para detectar dispositivos PCI, lsusb para enumerar los USB y lsdev para enumerar todos los dispositivos.

Comprensión de los tipos de archivo y los permisos

Como ya se mencionó, hay varios tipos de archivos en el sistema de archivos de Linux. Cada uno tiene su propio propósito, pero nos ocuparemos principalmente de archivos y directorios normales. Los archivos normales incluyen archivos cotidianos como códigos fuente, ejecutables, documentos, música, etc. Los directorios son archivos simples que contienen el nombre de otros archivos. Mientras tanto, los archivos especiales son componentes del sistema de bajo nivel como tuberías y enchufes. Por lo general, estos son tratados por el kernel de Linux.

Ahora, los permisos son un concepto completamente diferente y son extremadamente importantes para los usuarios de Linux. Debe comprenderlos claramente si desea sobresalir en sus habilidades de administración de sistemas. Linux, como otros Unix, usa permisos de archivo para determinar cuánto privilegio tiene un usuario sobre un archivo.

permisos de archivo básicos

Los permisos garantizan que los usuarios solo puedan acceder o modificar los contenidos del sistema a los que están autorizados. Es el aspecto más crucial detrás de la seguridad de su sistema Linux. Dado que los permisos de archivos de Linux son un tema extremadamente importante en sí mismos, hablaremos de ellos en detalle en una guía posterior. Por hoy, nos ceñiremos a lo básico.

Anteriormente usamos el comando ls -l para determinar los tipos de archivos. Lo determinamos simplemente mirando el primer carácter de la columna inicial. Ahora, esta es la columna que dicta los permisos. Ejecute ls -l de nuevo, pero en un archivo / directorio específico.

ver permisos

La primera sección de la salida debe contener tres campos separados por el símbolo . El primer carácter denota el tipo de archivo. Lo será , para archivos normales, como dijimos anteriormente. La siguiente parte debe contener uno o más caracteres del conjunto {r, w, x} . Por ejemplo, si es rw , entonces el usuario tiene acceso de lectura (r) y escritura (w). Si es ( rwx ), el usuario tiene permisos de lectura, escritura y ejecución (x).

Entonces, si esta sección denota el control de acceso del usuario, ¿por qué hay dos secciones más similares? Son los permisos del grupo y otros usuarios. Dado que Unix es un sistema multiusuario, el sistema de archivos fue diseñado para facilitar el uso concurrente del mismo sistema por diferentes usuarios. Cada usuario tenía su propio par de nombre de usuario y contraseña, que podían usar para acceder a un sistema. Los permisos simplemente definen cuánto control tiene un usuario específico sobre algún contenido.

Puede modificar los permisos de algunos contenidos utilizando el chmod y chown comandos. Se demostrarán en una guía complementaria.

Una descripción general de los diferentes tipos de sistemas de archivos de Linux

Hay varios tipos de sistema de archivos en los sistemas operativos basados ​​en Linux. Los tipos comunes de sistemas de archivos de Linux son ext3, ext4, zfs, FAT, XFS y Btrfs. Indudablemente, hay muchos más en esta lista, y le daremos una descripción concisa de ellos en breve. Encontrar el tipo de sistema de archivos correcto generalmente depende de los requisitos de los usuarios. Aconsejamos a los usuarios principiantes de Linux que se queden con el sistema de archivos de diario ext4.

Dado que existen varios tipos de sistemas de archivos Linux, creemos que es esencial tener algún conocimiento sobre ellos. Aquí, presentamos 10 tipos de sistemas de archivos ampliamente utilizados en Linux.

1. Sistemas de archivos EXT

El ext (Extended File System) está diseñado especialmente para Linux y tiene 4 versiones hasta la fecha. Son ext, ext2, ext3 y ext4. La mayoría de las distribuciones modernas ya no brindan soporte para ext y ext2. La versión ext3 implementó el registro en diario, una función que evita la corrupción de datos en caso de fallas eléctricas accidentales. Ha experimentado una disminución relativa en el uso desde que se lanzó la versión ext4. Ext4 es el tipo de sistema de archivos predeterminado en las distribuciones más recientes.

2. BtrFS

El “B-Tree File System” es un innovador sistema de archivos desarrollado por Oracle. Ofrece algunas características asombrosas que no se encuentran en los tipos de sistemas de archivos estándar de Linux. Algunos de ellos incluyen la capacidad de tomar instantáneas sobre la marcha, capacidades de agrupación de unidades, desfragmentación en línea y métodos de compresión transparentes. Mucha gente pronuncia BtrFS como “Better FS” y lo considera el próximo gran tipo de sistema de archivos en servidores Linux y estaciones de trabajo personales.

3. ReiserFS

ReiserFS es otro sistema de archivos basado en diario que se puede utilizar para la informática de propósito general. Es compatible con Linux y tiene una licencia GNU GPL de código abierto. ReiserFS ganó muchos seguidores en sus primeros años debido a algunas de las características que eran relativamente nuevas en ese momento. Entre ellos se incluye la capacidad de cambiar el tamaño de los volúmenes en línea, el empaquetado final para reducir la fragmentación interna y el registro en diario de solo metadatos. El desarrollo de ReiserFS se ha estancado debido a que su desarrollador principal cumplió condena en la cárcel.

4. ZFS

ZFS es un robusto sistema de archivos y administrador de volúmenes desarrollado por Sun Microsystems y actualmente es mantenido por Oracle. Es un sistema de archivos extremadamente poderoso que admite almacenamientos masivos, técnicas de compresión eficientes, modelos RAID modernos, deduplicación de datos y muchas más funciones. ZFS está disponible en la mayoría de las distribuciones de Linux y BSD junto con Mac OS y FUSE. Los usuarios de Ubuntu pueden descubrir más sobre ZFS aquí .

5. XFS

XFS es un sistema de archivos similar a Ext4 desarrollado por Silicon Graphics y está disponible en Linux desde 2001. Ofrece muchas características que se encuentran en el sistema de archivos estándar ext4, pero limita algunas de sus capacidades. XFS utiliza una técnica denominada asignación diferida para detectar fragmentaciones de archivos de forma más eficaz. Por lo tanto, es adecuado para configurar . Descubrimos que funciona mejor con archivos grandes, pero bastante más lento cuando se trata de una gran cantidad de archivos más pequeños.

6. JFS

JFS es un acrónimo de “Journaled File System”, un sistema de archivos Linux desarrollado por IBM. Es conocido por su uso limitado de recursos de CPU y proporciona un rendimiento significativamente mejor tanto para archivos grandes como para colecciones de varios archivos más pequeños. Además, permite a los administradores del sistema cambiar el tamaño de sus particiones de forma dinámica. Sin embargo, esta función solo admite la ampliación, no la reducción.

7. MARTILLO

HAMMER es un tipo de archivo extremadamente robusto desarrollado para la versión DragonFly BSD. Es un sistema de archivos de alta disponibilidad que solo admite sistemas de 64 bits. Hammer usa árboles B + para implementar sus funcionalidades, que incluyen la capacidad de tomar instantáneas exportables a NFS ilimitadas, retención de historial, sumas de verificación y operaciones maestro-esclavo múltiple, entre otras. También admite la deduplicación de datos a pedido y las compresiones transparentes.

8. GRASA

FAT o tabla de asignación de archivos es una clase de sistema de archivos conocido por su flexibilidad y su robusto conjunto de funciones. Algunos sistemas de archivos FAT populares incluyen FAT 16, FAT32, exFAT y vFAT. Son uno de los sistemas de archivos más utilizados debido a su incorporación en máquinas Windows más antiguas. Linux admite un amplio conjunto de sistemas de archivos FAT comunes conocidos por su alto rendimiento.

9. NTFS

NTFS (New Technology File System) es otro tipo de sistema de archivos común para muchos usuarios. Es el sistema de archivos predeterminado en las máquinas modernas de Windows y es compatible con Linux y otros sistemas BSD. NTFS implementa varias técnicas para aumentar su rendimiento y es un sistema de archivos registrado. Admite flujos de datos alternativos, varios métodos de compresión, cambio de tamaño, archivos dispersos y muchas más funciones.

10. cramfs

El sistema de archivos ROM comprimido, también conocido como cramfs, es uno de los tipos de archivos más utilizados en . Es solo un sistema de archivos de solo lectura que permite que el sistema lea imágenes sin la necesidad de descomprimirlas primero. Esta es la razón por la que muchas distribuciones de Linux lo usan para imágenes de initrd e imágenes de instalación.

Hay muchos más tipos de sistemas de archivos en Linux. Además, permite a los usuarios adjuntar múltiples tipos de particiones en la estructura del sistema de archivos. De hecho, es una práctica muy extendida. Un tipo especial de sistema de archivos de Linux es el intercambio. En realidad, no es un sistema de archivos, sino una técnica utilizada para implementar la memoria virtual .

Comprobación del tipo de sistema de archivos en Linux

Dado que Linux permite a los usuarios usar más de un tipo de sistema de archivos al mismo tiempo, a menudo es necesario verificar el tipo de sistema de archivos antes de realizar operaciones con archivos. Describiremos algunos métodos convencionales para determinar el tipo de sistema de archivos de una partición desde la línea de comandos.

1. Identificación del tipo de sistema de archivos mediante el comando df

Puede determinar el tipo de sistema de archivos en Linux usando el siguiente comando df . Consulte nuestros para comprender el comando df en detalle.

$ df -T /

Produciría el tipo de sistema de archivos de raíz (/) en la columna de salida Tipo.

2. Identificación del tipo de sistema de archivos mediante el comando fsck

El comando fsck (verificación del sistema de archivos) se puede utilizar para determinar el tipo de sistema de archivos de una partición. La bandera -N se utiliza para deshabilitar las comprobaciones de errores.

$ fsck -N /

Este comando debería generar el tipo de sistema de archivos y su ID de bloque.

comprobar los tipos de sistemas de archivos de Linux

3. Identificación del tipo de sistema de archivos mediante el comando lsblk

El comando lsblk se usa para mostrar los dispositivos de bloque en una máquina Linux. Puede agregar el indicador -f para decirle a lsblk que muestre el tipo de sistema de archivos.

$ lsblk -f

Imprimirá todos los dispositivos de bloque junto con su tipo, punto de montaje y disponibilidad.

4. Identificación del tipo de sistema de archivos mediante el comando mount

Como se mencionó anteriormente, mount se usa para adjuntar un dispositivo o partición a una ubicación seleccionada en su sistema de archivos. También puede usarlo con grep para determinar el tipo de archivo de los sistemas de archivos de Linux actualmente montados.

$ mount | grep "^/dev"

Mostrará todas las particiones montadas con su tipo.

5. Identificación del tipo de sistema de archivos mediante el comando blkid

El comando blkid se utiliza para imprimir las propiedades de los dispositivos de bloque. También muestra el tipo de sistema de archivos, como se muestra en el siguiente ejemplo.

$ blkid /dev/sda9

Contiene información adicional. Puede utilizar el comando cut de Linux para extraer la información específica.

$ blkid /dev/sda9 | cut -d ' ' -f 3

6. Identificación del tipo de sistema de archivos mediante el comando de archivo

El comando de archivo imprime información sobre archivos y directorios. Agregar la opción -sL al archivo le permite determinar también el tipo de sistema de archivos.

$ sudo file -sL /dev/sda9

Imprimirá el tipo de sistema de archivos de la partición / dev / sda9 .

7. Identificación del tipo de sistema de archivos mediante el archivo fstab

El archivo fstab contiene la información utilizada por su sistema para determinar el tipo de un sistema de archivos. Puede usarlo para obtener el tipo de sistema de archivos, como se muestra a continuación.

$ cat /etc/fstab

Este comando imprimirá el tipo de sistema de archivos de sus particiones junto con otra información.

8. Identificación del tipo de sistema de archivos mediante el comando parted

El comando parted es una de las formas más útiles de determinar los tipos de sistemas de archivos en Linux. Puede usarlo, como se muestra a continuación.

$ sudo parted -l

Este comando debería imprimir todas las particiones junto con el tipo de sistema de archivos de Linux y otra información. Utilice este método cuando necesite determinar el tipo de todos los sistemas de archivos en su sistema.

comprobar el tipo de sistema de archivos en Linux

9. Identificación del tipo de sistema de archivos mediante el comando inxi

Otro comando útil que permite a los usuarios averiguar el tipo de sistema de archivos es inxi . Puede utilizar el siguiente comando para descubrir el tipo de sistema de archivos de todas las particiones.

$ inxi -p

Imprimirá todos los dispositivos junto con la información de su tipo.

10. Identificación del tipo de sistema de archivos mediante el archivo mtab

También puede grep del archivo mtab para obtener la información de tipo para los sistemas de archivos montados. El siguiente comando le muestra cómo hacer esto.

$ cat /etc/mtab | grep "/dev/sd*"

Imprimirá el tipo de información de los dispositivos montados actualmente.

Pensamientos finales

El sistema de archivos de Linux cubre numerosos aspectos de su . Desde el punto de vista de la ingeniería de software, discutimos cómo Linux estructura sus sistemas de archivos y dictamos varios comandos para atravesar esta jerarquía de manera efectiva. El tipo de sistema de archivos en Linux denota la entidad lógica de un sistema de archivos en particular. Hemos descrito diez tipos de sistemas de archivos de Linux ampliamente utilizados y luego le mostramos cómo determinar esto desde la terminal. Aunque es muy difícil abarcar el sistema de archivos en una sola guía, nuestros editores han hecho todo lo posible para hacer lo imposible. Déjenos un comentario si tiene alguna confusión o tiene más preguntas.

Leave a Comment

Your email address will not be published.