Por que a pasta /home está faltando no meu arquivo de backup criado pelo tar?

Por que a pasta /home está faltando no meu arquivo de backup criado pelo tar?

Então estou fazendo backup completo do meu VPS usando o seguinte comando (como root, é claro):

tar czvf 20120604.tar.gz /

Tudo parece estar bem, todos os arquivos parecem aparecer na lista. O tamanho do arquivo é de 6 Gb e a versão compactada é de 11 Gb, o que inclui /home, porque tenho um total de 11 Gb de dados no VPS. Mas quando tento descompactar o arquivo ou abri-lo usando mc ou WinRAR, não há pasta/home. E o WinRAR conta 20120604.tar.gz - TAR+GZIP archive, unpacked size 894 841 346 bytes. Não pode ser bug do WinRAR, porque quando digito tar xzvf 20120604.tar.gz, /homea pasta também não é descompactada.

Por que a pasta está /homefaltando no meu arquivo? E o que posso fazer para incluí-lo aí?

tar --versiongera o seguinte:tar (GNU tar) 1.15.1

Responder1

Eu suspeito fortemente que a exclusão do /homediretório em seu backup tar é resultado da execução como root (o diretório inicial do root é /root/). Olhando para a página de manual (retirada dehttp://linux.die.net/man/1/tar), as seguintes opçõespoderiapotencialmente causar/resolver/depurar sua situação:

  Main operation mode: 
    -C, --directory=DIR
        change to directory DIR 
    -p, --preserve-permissions
        extract information about file permissions (default for superuser) 
    -v, --verbose
        verbosely list files processed 

  Operation modifiers:
    -g, --listed-incremental=FILE
        handle new GNU-format incremental backup 
    -G, --incremental
        handle old GNU-format incremental backup 

  Handling of file attributes: 
    --group=NAME
        force NAME as group for added files 
    --mode=CHANGES
        force (symbolic) mode CHANGES for added files 
    --no-same-owner
        extract files as yourself (default for ordinary users) 
    --no-same-permissions
        apply the user's umask when extracting permissions from the archive (default for ordinary users) 
    --no-xattrs
        Don't extract the user/root xattrs from the archive 
    --numeric-owner
        always use numbers for user/group names 
    --owner=NAME
        force NAME as owner for added files 
    -p, --preserve-permissions, --same-permissions
        extract information about file permissions (default for superuser) 
    --same-owner
        try extracting files with the same ownership as exists in the archive (default for superuser) 
    --xattrs
        Save the user/root xattrs to the archive 

  Device selection and switching:
    --force-local
        archive file is local even if it has a colon 

  Archive format selection:
    -H, --format=FORMAT
        create archive of the given format--FORMAT is one of the following: 
    gnu, oldgnu, pax, posix, ustar, v7, --old-archive, --portability, 
    --pax-option=keyword[[:]=value][,keyword[[:]=value]]... , --posix, 
    -V, --label=TEXT
        <see webpage/ man page for details>

  Local file selection:
    --add-file=FILE
        add given FILE to the archive (useful if its name starts with a dash) 
    -C, --directory=DIR
        change to directory DIR 
    -h, --dereference
        follow symlinks; archive and dump the files they point to 
    --hard-dereference
        follow hard links; archive and dump the files they refer to 
    -K, --starting-file=MEMBER-NAME
        begin at member MEMBER-NAME in the archive 
    --one-file-system
        stay in local file system when creating archive 
    -P, --absolute-names
        don't strip leading '/'s from file names 
    --recursion
        recurse into directories (default) 

  File name transformations:
    --no-anchored
        patterns match after any '/' (default for exclusion) 
    --no-ignore-case
        case sensitive matching (default) 
    --no-wildcards
        verbatim string matching 
    --no-wildcards-match-slash
        wildcards do not match '/' 
    --wildcards
        use wildcards (default) 
    --wildcards-match-slash
        wildcards match '/' (default for exclusion) 

  Informative output:
    --index-file=FILE
        send verbose output to FILE 
    -l, --check-links
        print a message if not all links are dumped 
    --show-defaults
        show tar defaults 
    --show-omitted-dirs
        when listing or extracting, list each directory that does not match search criteria 
    --show-transformed-names, --show-stored-names
        show file or archive names after transformation 
    -v, --verbose
        verbosely list files processed 
    -w, --interactive, --confirmation
        ask for confirmation for every action 

Certamente há MUITO a considerar, mas os comandos do Linux são flexíveis e poderosos. Imagino que se você estudar cada uma dessas opções usando uma caixa de teste com uma estrutura de sistema de arquivos limitada, executando a distribuição que pretende empregar, encontrará a combinação exata a ser incluída em seu script para produzir o resultado exato que deseja.

Para construir o conhecimento comunitário, você poderia postar de volta com a solução que proporciona o comportamento que você deseja?

informação relacionada