Respostas:
Nos sistemas operacionais baseados em Linux, isso pode ser feito com dispositivos de bloco de rede ou dispositivos mapeadores de dispositivos. O arquivo que você obtém é um dispositivo de bloco.
Com nbd
:
ln -s /path/to/first-file file.0
...
ln -s /path/to/last-file file.19
nbd-server -C /dev/null -m 127.0.0.1:12345 file
sudo nbd-client localhost 12345 /dev/nbd0
(a concatenação é /dev/nbd0
).
Com o mapeador de dispositivos (os tamanhos dos arquivos precisam ser múltiplos de 512):
sudo losetup /dev/loop0 file1
sudo losetup /dev/loop1 file2
s0=$(sudo blockdev --getsize /dev/loop0)
s1=$(sudo blockdev --getsize /dev/loop1)
printf '%s\n' "0 $s0 linear /dev/loop0 0" "$s0 $s1 linear /dev/loop1 0" |
sudo dmsetup create mybundle
(a concatenação é /dev/mapper/mybundle
).
escreveu um driver de fusível hoje, se alguém estiver interessado na solução de fusíveis (o mapeador de dispositivos e a solução nbd acima criarão dispositivos de bloco, não arquivos regulares - o que será interrompido se você quiser usar a saída resultante diretamente com a edição de vídeo software ou outras ferramentas que não estão preparadas para ler diretamente de um dispositivo de bloco)
Você basicamente respondeu na primeira frase da pergunta: sim, isso pode ser feito. No entanto, você teria que escrever um driver de sistema de arquivos personalizado. Se é para ser um objeto do sistema de arquivos, ele deve ser tratado pelo kernel em algum nível (que inclui o FUSE ). O driver teria que fornecer back-end para a API syscalls do sistema de arquivos padrão ( stat()
, open()
etc., incluindo a busca). Você não pode fazê-lo inteiramente no espaço do usuário (pelo menos não com um kernel monolítico - mas mesmo com um microkernel você ainda precisará fornecer um driver de sistema de arquivos, embora seja executado como um processo regular do espaço do usuário).