Назад | Перейти на главную страницу

Объединение файлов в виртуальный файл в Linux

В системе Linux есть ли способ объединить серию файлов в один открытый файл для чтения и записи, не занимая при этом еще N байтов дискового пространства? Я надеялся на что-то вроде монтирования этих файлов через loopback / devmapper для достижения этой цели.

У меня проблема с разделенными двоичными файлами, которые могут стать довольно большими. Я не хочу удваивать свои требования к пространству с помощью массивного дискового ввода-вывода только для временного чтения / записи содержимого из этих файлов с помощью catобъединяя их все вместе в один огромный файл.

Я нашел этот проект Вот, но, похоже, имеет очень специфический вариант использования, а также зависит от Perl

Вы можете сделать это, объединив петлевые устройства и устройство отображения, благодаря «все является файлом». Но с одним ограничением: размер файла нельзя изменить (так как вы не можете увеличивать блочные устройства, записывая на них). Поэтому, если вы хотите добавить данные, вам нужно создать более крупное блочное устройство и перезаписать добавленные фиктивные данные.

# for testing, Create 4 files
echo foo | dd of=block0 cbs=512 conv=block
echo bar | dd of=block1 cbs=512 conv=block
echo bat | dd of=block2 cbs=512 conv=block
echo baz | dd of=block3 cbs=512 conv=block
# Create a loop device for each of the 4 files
losetup /dev/loop0 block0
losetup /dev/loop1 block1
losetup /dev/loop2 block2
losetup /dev/loop3 block3
# Create a device map named "test" using those loop devices
(
    echo "0 1 linear /dev/loop0 0"
    echo "1 1 linear /dev/loop1 0"
    echo "2 1 linear /dev/loop2 0"
    echo "3 1 linear /dev/loop3 0"
) | dmsetup create test
$EDITOR /dev/mapper/test # use overwrite mode only

Для расширения файла вы можете создать большой разреженный файл и использовать его как дополнительное устройство.

Это можно сделать с помощью именованного канала в Linux.

Предположим, у вас есть файлы с именем file0, file1, file2, file3, file4, file5

# create a name pipe
$ mkfifo mynewfile
# cat to named file
$ cat file{0..5} > mynewfile &

В C программно вы можете делать

mkfifo(mynewfile , 0777);
system("cat file{0..5} > mynewfile");

Затем используйте mynewfile, как если бы вы читали его из обычного файла.

mynewfile - это файл FIFO

Для чтения вы можете less несколько файлов, а затем используйте :n и :p варианты пройти их.

Для записи без прямого доступа к файлам вы не сможете писать в них.

Ты можешь vim несколько файлов, и он просто будет проходить в том порядке, в котором они были вызваны (т.е. vim fileA fileB fileC - файлB открывается после закрытия файлаA, файлC открывается после закрытия файлаB).