Linux Commands Examples

A great documentation place for Linux commands

tar

The GNU version of the tar archiving utility


see also : rmt

Synopsis

tar [

- ] A --catenate --concatenate | c --create | d --diff --compare | --delete | r --append | t --list | --test-label | u --update | x --extract --get [options] [pathname ...]


add an example, a script, a trick and tips

: email address (won't be displayed)
: name

Step 2

Thanks for this example ! - It will be moderated and published shortly.

Feel free to post other examples
Oops ! There is a tiny cockup. A damn 404 cockup. Please contact the loosy team who maintains and develops this wonderful site by clicking in the mighty feedback button on the side of the page. Say what happened. Thanks!

examples

1
source

Linux / OS X tar incompatibility – tarballs created on OS X give errors when untarred in Linux

I googled for the error message and it seems like a BSD tar vs. GNU tar issue.

Install gnu tar if you can on MacOS and use that to create the tar.

0

Create archive.tar from files foo and bar.

tar -cf archive.tar foo bar

List all files in archive.tar verbosely.

tar -tvf archive.tar

Extract all files from archive.tar.

tar -xf archive.tar


0
source
            
tar -zcvf GROUPDD.tar src
0
source
            
tar -xzvf deps.tar.gz
0
source

How to specify level of compression when using tar -zcvf?

Instead of using the gzip flag for tar, gzip the files manually after the tar process, then you can specify the compression level for the gzip program:

tar -cvf files.tar /path/to/file0 /path/to/file1 ; gzip -9 files.tar

Or you could use:

tar cvf - /path/to/file0 /path/to/file1 | gzip -9 - > files.tar.gz

The -9 in the gzip command line tells gzip to use the maximum possible compression level (default is -6).

Edit: Fixed pipe command line based on @depesz comment.

0
source

What is the advantage of using 'tar' today?

This has been answered on Stack Overflow.

bzip and gzip work on single files, not groups of files. Plain old zip (and pkzip) operate on groups of files and have the concept of the archive built-in.

The *nix philosophy is one of small tools that do specific jobs very well and can be chained together. That's why there's two tools here that have specific tasks, and they're designed to fit well together. It also means you can use tar to group files and then you have a choice of compression tool (bzip, gzip, etc).

Many tools are distributed in source or binary form as .tar.gz or .tar.bz2 because it is a "lowest common denominator" file format: much like most Windows users have access to .zip or .rar decompressors, most Linux installations, even the most basic, will have access to at least tar and gunzip, no matter how old or pared down. Even Android firmwares have access to these tools.

New projects targeting audiences running modern distributions may very well distribute in a more modern format, such as .tar.xz (using the Xz (LZMA) compression format, which compresses better than gzip or bzip2), or .7z, which is similar to the Zip or Rar file formats in that it both compresses and specifies a layout for encapsulating multiple files into a single file.

You don't see .7z used more often for the same reason that music isn't sold from online download stores in brand new formats like Opus, or video in WebM. Compatibility with people running ancient or very basic systems.

0
source

How do I unzip a tar gz archive to a specific destination?

You have two choices:

cd /root/Desktop/folder
tar zxf /root/Documents/file.tar.gz

or

tar zxf file.tar.gz -C /root/Desktop/folder
0
source

Untar, ungz, gz, tar - how do you remember all the useful options?

Just type tar --help and there's your cheatsheet.

0
source

Which is more efficient - tar or zip compression? What is the difference between tar and zip?

tar only makes a single file out of multiple files, it doesn't do compression unless combined a compression program such as gzip or bzip2 (which you can call from within tar by using the -z or -j options, respectively). zip combines both the archiving and compression in one program.

0
source

How can I create a zip / tgz in Linux such that Windows has proper filenames?

As far as I know, Windows NT series (XP, Vista, others) use Unicode for storing the file names. So I'm guessing it's a problem with the Windows' archiver... which one are you using?

0
source

Undo tar file extraction mess

List the contents of the tar file like so:

tar tzf myarchive.tar

Then, delete those file names by iterating over that list:

while IFS= read -r file; do echo "$file"; done < <(tar tzf myarchive.tar.gz)

This will still just list the files that would be deleted. Replace echo with rm if you're really sure these are the ones you want to remove. And maybe make a backup to be sure.

In a second pass, remove the directories that are left over:

while IFS= read -r file; do rmdir "$file"; done < <(tar tzf myarchive.tar.gz)

This prevents directories with from being deleted if they already existed before.


Another nice trick by @glennjackman, which preserves the order of files, starting from the deepest ones. Again, remove echo when done.

tar tvf myarchive.tar | tac | xargs -d'\n' echo rm

This could then be followed by the normal rmdir cleanup.

0
source

Map "untar" to tar xvfz?

alias untar='tar -xvzf'

place in your .bashrc file to persist across logins/shell sessions.

0
source

How to use password protection with the Linux tar command?

As far as I know tar doesn't provide this service. You could use 7zip instead, which does offer encrypted archives.

What you can also do is use gpg in addition to tar:

tar cvJf myarchive.tar.xz myfiles
gpg -c myarchive.tar.xz.gpg

This will give you a password protected archive.

description

Tar stores and extracts files from a tape or disk archive.

The first argument to tar should be a function; either one of the letters Acdrtux, or one of the long function names. A function letter need not be prefixed with ’’-’’, and may be combined with other single-letter options. A long function name must be prefixed with --. Some options take a parameter; with the single-letter form these must be given as separate arguments. With the long form, they may be given by appending =value to the option.

environment

The behavior of tar is controlled by the following environment variables, among others:

SIMPLE_BACKUP_SUFFIX

Backup prefix to use when extracting, if --suffix is not specified. The backup suffix defaults to ’~’ if neither is specified.

TAR_OPTIONS

Options to prepend to those specified on the command line, separated by whitespace. Embedded backslashes may be used to escape whitespace or backslashes within an option.

TAPE

Device or file to use for the archive if --file is not specified. If this environment variable is unset, use stdin or stdout instead.

TAR_LONGLINK_100

function letters

Main operation mode:

-A, --catenate, --concatenate

append tar files to an archive

-c, --create

create a new archive

-d, --diff, --compare

find differences between archive and file system

--delete

delete from the archive (not on mag tapes!)

-r, --append

append files to the end of an archive

-t, --list

list the contents of an archive

--test-label

test the archive volume label and exit

-u, --update

only append files newer than copy in archive

-x, --extract, --get

extract files from an archive

other options

Operation modifiers:

-[0-7][lmh]

specify drive and density

-a, --auto-compress

use archive suffix to determine the compression program

--add-file=FILE

add given FILE to the archive (useful if its name starts with a dash)

--anchored

patterns match file name start

--no-anchored

patterns match after any ’/’ (default for exclusion)

--atime-preserve

preserve access times on dumped files, either by restoring the times

--no-auto-compress

do not use archive suffix to determine the compression program

-b, --blocking-factor BLOCKS

BLOCKS x 512 bytes per record

-B, --read-full-records

reblock as we read (for 4.2BSD pipes)

--backup

backup before removal, choose version CONTROL

-C, --directory DIR

change to directory DIR

--check-device

check device numbers when creating incremental archives (default)

--no-check-device

do not check device numbers when creating incremental archives

--checkpoint

display progress messages every NUMBERth record (default 10)

--checkpoint-action=ACTION

execute ACTION on each checkpoint

--delay-directory-restore

delay setting modification times and permissions of extracted

--no-delay-directory-restore

cancel the effect of --delay-directory-restore option

--exclude=PATTERN

exclude files, given as a PATTERN

--exclude-backups

exclude backup and lock files

--exclude-caches

exclude contents of directories containing CACHEDIR.TAG,

--exclude-caches-all

exclude directories containing CACHEDIR.TAG

--exclude-caches-under

exclude everything under directories containing CACHEDIR.TAG

--exclude-tag=FILE

exclude contents of directories containing FILE, except

--exclude-tag-all=FILE

exclude directories containing FILE

--exclude-tag-under=FILE

exclude everything under directories containing FILE

--exclude-vcs

exclude version control system directories

-f, --file ARCHIVE

use archive file or device ARCHIVE

-F, --info-script, --new-volume-script NAME

run script at end of each tape (implies -M)

--force-local

archive file is local even if it has a colon

--full-time

print file time to its full resolution

-g, --listed-incremental FILE

handle new GNU-format incremental backup

-G, --incremental

handle old GNU-format incremental backup

--group=NAME

force NAME as group for added files

-h, --dereference

follow symlinks; archive and dump the files they point to

-H, --format FORMAT

create archive of the given formatFORMAT is one of the following:

--format=gnu

GNU tar 1.13.x format

--format=oldgnu

GNU format as per tar <= 1.12

--format=pax

POSIX 1003.1-2001 (pax) format

--format=posix

same as pax

--format=ustar

POSIX 1003.1-1988 (ustar) format

--format=v7

old V7 tar format

--hard-dereference

follow hard links; archive and dump the files they refer to

-i, --ignore-zeros

ignore zeroed blocks in archive (means EOF)

-I, --use-compress-program PROG

filter through PROG (must accept -d)

--ignore-case

ignore case

--no-ignore-case

case sensitive matching (default)

--ignore-command-error

ignore exit codes of children

--no-ignore-command-error

treat non-zero exit codes of children as error

--ignore-failed-read

do not exit with nonzero on unreadable files

--index-file=FILE

send verbose output to FILE

-j, --bzip2

-J, --xz

-k, --keep-old-files

don’t replace existing files when extracting

-K, --starting-file MEMBER-NAME

begin at member MEMBER-NAME in the archive

--keep-newer-files

don’t replace existing files that are newer than their archive copies

-l, --check-links

print a message if not all links are dumped

-L, --tape-length NUMBER

change tape after writing NUMBER x 1024 bytes

--level=NUMBER

dump level for created listed-incremental archive

--lzip

--lzma

--lzop

-m, --touch

don’t extract file modified time

-M, --multi-volume

create/list/extract multi-volume archive

--mode=CHANGES

force (symbolic) mode CHANGES for added files

--mtime=DATE-OR-FILE

set mtime for added files from DATE-OR-FILE

-n, --seek

archive is seekable

-N, --newer, --after-date DATE-OR-FILE

only store files newer than DATE-OR-FILE

--newer-mtime=DATE

compare date and time when data changed only

--null

-T reads null-terminated names, disable -C

--no-null

disable the effect of the previous --null option

--numeric-owner

always use numbers for user/group names

-O, --to-stdout

extract files to standard output

--occurrence

process only the NUMBERth occurrence of each file in the archive;

--old-archive, --portability

same as --format=v7

--one-file-system

stay in local file system when creating archive

--overwrite

overwrite existing files when extracting

--overwrite-dir

overwrite metadata of existing directories when extracting (default)

--no-overwrite-dir

preserve metadata of existing directories

--owner=NAME

force NAME as owner for added files

-p, --preserve-permissions, --same-permissions

extract information about file permissions (default for superuser)

-P, --absolute-names

don’t strip leading ’/’s from file names

--pax-option=keyword[[:]=value][,keyword[[:]=value]]...

control pax keywords

--posix

same as --format=posix

--preserve

same as both -p and -s

--quote-chars=STRING

additionally quote characters from STRING

--no-quote-chars=STRING

disable quoting for characters from STRING

--quoting-style=STYLE

set name quoting style; see below for valid STYLE values

-R, --block-number

show block number within archive with each message

--record-size=NUMBER

NUMBER of bytes per record, multiple of 512

--recursion

recurse into directories (default)

--no-recursion

avoid descending automatically in directories

--recursive-unlink

empty hierarchies prior to extracting directory

--remove-files

remove files after adding them to the archive

--restrict

disable use of some potentially harmful options

--rmt-command=COMMAND

use given rmt COMMAND instead of rmt

--rsh-command=COMMAND

use remote COMMAND instead of rsh

-s, --preserve-order, --same-order

sort names to extract to match archive

-S, --sparse

handle sparse files efficiently

--same-owner

try extracting files with the same ownership as exists in the archive (default for superuser)

--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-seek

archive is not seekable

--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

--sparse-version=MAJOR[.MINOR]

set version of the sparse format to use (implies --sparse)

--strip-components=NUMBER

strip NUMBER leading components from file names on extraction

--suffix=STRING

backup before removal, override usual suffix (’~’ unless overridden by environment variable SIMPLE_BACKUP_SUFFIX)

-T, --files-from FILE

get names to extract or create from FILE

--to-command=COMMAND

pipe extracted files to another program

--totals

print total bytes after processing the archive;

--transform, --xform EXPRESSION

use sed replace EXPRESSION to transform file names

-U, --unlink-first

remove each file prior to extracting over it

--unquote

unquote filenames read with -T (default)

--no-unquote

do not unquote filenames read with -T

--utc

print file modification times in UTC

-v, --verbose

verbosely list files processed

-V, --label TEXT

create archive with volume name TEXT; at list/extract time, use TEXT as a globbing pattern for volume name

--volno-file=FILE

use/update the volume number in FILE

-w, --interactive, --confirmation

ask for confirmation for every action

-W, --verify

attempt to verify the archive after writing it

--warning=KEYWORD

warning control

--wildcards

use wildcards (default for exclusion)

--wildcards-match-slash

wildcards match ’/’ (default for exclusion)

--no-wildcards-match-slash

wildcards do not match ’/’

--no-wildcards

verbatim string matching

-X, --exclude-from FILE

exclude patterns listed in FILE

-z, --gzip, --gunzip --ungzip

-Z, --compress, --uncompress


bugs

The GNU folks, in general, abhor man pages, and create info documents instead. Unfortunately, the info document describing tar is licensed under the GFDL with invariant cover texts, which makes it impossible to include any text from that document in this man page. Most of the text in this document was automatically extracted from the usage text in the source. It may not completely describe all features of the program.

Apr 4, 2013


history

The tar command appeared in Version 7 AT&T UNIX.


see also

tar, symlink, rmt

How can this site be more helpful to YOU ?


give  feedback