TAR(1) TAR(1)
tar - tape archiver
tar key [ arguments ] [ name ... ]
tar saves and restores multiple files on a single file (usually a
magnetic tape, but it can be any file). This single logical file may
span multiple physical tapes (this is known as "multi-volume tar"). Such
tapes do not have a filemark at the end of intermediate volumes, and an
archived file may be split across multiple tapes. The second through
last tape may be read without earlier tapes (aside from the possible
first file split across the tape boundary) by using the e option.
The key argument controls tar's actions. The key is a string of
characters containing at most one function letter and possibly one or
more function modifiers. Other arguments to tar are file or directory
names specifying which files to dump or restore. The order must match
the order of the matching options in key. In all cases, appearance of a
directory name refers (recursively) to the files and subdirectories of
that directory. These files are dumped to tape in alphabetical order.
If name is -, the list of files is read from the standard input.
In order to create a tar archive that is portable to as many types of
systems as possible, use the fixed block, non-byte swapped device.
Historically, a blocking factor of 20 (with any type of tape device)
would have been more portable, but with newer tapes this is not
necessarily true. If the tape drive is a SCSI tape at ID 7 on bus 0, the
following command would do this:
tar cOdbf 20 /dev/rmt/tps0d7ns filelist
If you know the other system has a POSIX compatible version of tar, omit
the O and d options.
To extract tapes from other systems, use the variable block device, if
the device supports it, with a large blocking factor, otherwise specify
the blocking factor with which the tape was made (usually 20 on non-IRIX
systems, if the b option was not specified):
tar xbf 512 /dev/rmt/tps0d7nsv
Or, for fixed block only devices, such as QIC tape drives:
tar xbf 20 /dev/rmt/tps0d7ns
Also see the notes at the b option below.
If the O option is specified the maximum pathlength--including the
filename itself-- is 99 characters (NAMSIZ) not including the stringterminating
NULL character, and any archives created with non-POSIX
Page 1
TAR(1) TAR(1)
standard versions of tar will also obey this length rule. Otherwise,
(the [default] POSIX format), pathnames are limited to 255 total
characters (not including the NULL), subject to several caveats
necessitated by the requirement of total backward compatibility with
previous versions of tar. Referring to /usr/include/tar.h, there are two
storage fields for filenames name, (100 chars) and prefix (156 chars).
If the entire pathname is 100 characters or less including the NULL, it
will be stored in the name field. Otherwise the pathname is split
between the two fields, with the restriction that an implicit (i.e.,
unstored) '/' character separates the prefix and name fields. Upon
extraction, the full pathname is constructed by concatenating these
fields with the added '/'. Because of this requirement, files whose
actual names (not including the leading path) exceed 99 characters cannot
be archived. If the split field is used, and the tape is read on older,
non-POSIX capable tar, the file will be extracted in the current
directory, since no leading pathname information is located in the older
location in the header; this at least allows the file to be extracted on
older systems, but if multiple files with the same final component are
extracted, the earlier will be overwritten by the later file(s).
If the file is a symbolic link the link-name must obey the above rules;
however, the total pathlength of the target file may not exceed NAMSIZ
characters in either POSIX or non-POSIX format. See /usr/include/tar.h
for more detail about these length values.
A tar archive is a stream of 512-byte header structures which may be
followed by file data rounded up to the next 512-byte boundary. The end
of the archive is signaled by two header structures beginning with null
bytes.
The function portion of the key is specified by one of the following
letters:
r Append the named files at the end of the archive. On tape, named
files are appended at the end of the last archive on tape. See the
NOTES section below, for drives that support this operation, and
other limitations.
u Update; put the named files at the end of the archive if they are
not currently in the archive, or if the file has been modified more
recently than the file in the archive. Note that if the pathnames
do not exactly match those already in the archive, the files will
always be appended (e.g., don't use absolute pathnames one time,
and absolute the next). The same restrictions as for the r
function apply as to which drives support this.
x Extract the named files from the tape. If a named file matches a
directory whose contents had been written onto the tape, this
directory is (recursively) extracted. The owner, modification
time, and mode are restored, subject to umask(2). If no file
argument is given, the entire content of the tape is extracted.
Note that if multiple entries specifying the same file are on the
Page 2
TAR(1) TAR(1)
tape, the last entry overwrites all earlier entries.
X For each file to be extracted, if it is identical to the file in
the corresponding position in the comparison tree, link the
existing file to the new file. Otherwise, extract the new file as
a separate new file. X is like x but also takes the next argument
as the root of a directory tree for comparison.
t List the names of the specified files each time they occur on the
tape. If no file argument is given, list all of the names on the
tape.
c Create a new tape; writing starts at the beginning of the tape
instead of after the last file. This option assumes that you are
at the beginning of the tape.
C Compare files on tape against existing files. For each specified
file, print a line with a key character followed by the file name.
L linked to an earlier file on the tape
S symbolic link
B block special file
C character special file
P named pipe
D directory
? can't read the disk file, so can't compare
> disk file doesn't exist
= files compare
! files don't compare
In addition to the letter which selects the function desired the
following characters may be used:
d On output, tar normally places information specifying owner and
modes of directories in the archive. Former versions of tar, when
encountering this information print error messages of the form:
``<name>/: cannot create''.
This option suppresses the printing of the directory information.
This option implies the D option.
D On output, tar normally places information specifying the owner,
modes, and device numbers of character and block special files and
named pipes (fifos) in the archive. Former versions of tar, when
encountering this information create an ordinary file of the same
name whose contents is the device number, in binary. This option
suppresses the special file information.
N When extracting files, extract the file only if it is new; that is,
if the stat(2) system call fails on the pathname that is about to
be extracted. When listing files with the t key, only list them if
they would be extracted (that is, the file doesn't exist).
Page 3
TAR(1) TAR(1)
p This option restores files to their original modes, ignoring the
present umask(2). Setuid and sticky information are also restored
to the super-user. This is the default when run as super-user.
v Normally tar does its work silently. The v (verbose) option make
tar print the name of each file it treats preceded by the function
letter. With the t function, the verbose option gives more
information about the tape entries than just their names.
w tar prints the action to be taken followed by file name, then waits
for user confirmation. If a word beginning with `y' is given, the
action is done. Any other input means do not do it.
f tar uses the next argument as the name of the archive instead of
/dev/tape. If the f argument is not given, and $TAPE is set in the
environment, then that value is used instead of the default. If
the name of the file is `-', tar writes to standard output or reads
from standard input (whichever is appropriate). Thus, tar can be
used as the head or tail of a filter chain.
The specified archive name can also reference a remote tape device.
A remote tape device name has the form:
[user@]system:/dev/???
where system is the remote system, /dev/??? is the particular drive
on the remote system (raw, rewinding, non-rewinding, etc.), and the
optional user is the login name to be used on the remote system; if
not given, normal rsh(1C) semantics apply.
Tar can also be used to move hierarchies on the local machine with
the command
cd fromdir; tar cBf - . | (cd todir && tar xBf -)
To move hierarchies between machines, use the command
cd fromdir; tar cBf - . | rsh remote "(cd todir && tar xBf -)"
where remote is the host name of the remote machine.
b tar uses the next argument as the blocking factor for tape records.
The default is to use the results of the MTIOCGETBLKSIZE ioctl for
tape when creating a tape (and for reading on fixed blocksize
devices, such as QIC) and to determine the blocksize (for variable
blocksize devices) when reading. See the output of
mt blksize
for this information; the "recommended" default for SCSI tape
devices is set in /var/sysgen/master.d/tpsc. This default blocking
factor may be large enough that some non-SGI systems will either
not be able to determine the blocking factor automatically when
reading the tape, (thus requiring the b option be specified when
reading the tape), or in rare cases, to not be able to read the
tape at all. In the latter case, the b option with a smaller value
must be specified when writing the tape.
Page 4
TAR(1) TAR(1)
A blocking factor of 1 is normally used with standard input and
standard output, and 20 for files or devices not supporting the
ioctl (such as remote tape). If the tape was written with a
blocking factor that does not exceed the limit for that device, the
block size is determined automatically when reading a tape for
devices with variable block size.
When reading from fixed blocksize devices, tar cannot determine the
blocking factor used when the tape was created. This may lead to
tar incorrectly deciding that the tape is a multi-volume tape, if
the blocking factor when reading is not an integral divisor of the
block size used when the tape was written. If this occurs on tapes
that you believe are not multi-volume, simply press RETURN at the
"change tape" prompt, and tar will complete normally.
Due to the blocking algorithm, a tar tape created by writing to the
standard output should be read from standard input (if on the same
system; if on a different system, it may be necessary to specify a
blocking factor).
l If it cannot resolve all of the links to the files dumped, tar
prints error messages. If l is specified, no error messages are
printed.
m Do not restore the modification times. The modification time will
be the time of extraction.
e Force tar to continue reading past tape errors. tar continues
until no more data is left, or read returns an error; unlike some
other versions of tar, it does not stop when it sees the tar
internal EOF record (512 bytes of 0's).
L Force tar to follow symbolic links as if they were normal files or
directories.
h Force tar to not follow symbolic links, but to instead place the
symbolic link information in the archive. This is the default.
B Force input and output blocking to 20 blocks per record, and cause
the input processing to ignore input record boundaries,
concatenating all input into a contiguous stream. This option
allows tar to work through pipes, networks, and other
communications channels where the record blocking may not be
maintained.
E On output exclude non-local files, as defined by the statvfs(2)
ST_LOCAL flag. This applies to files and directories on the
command line, as well as those found descending the directory tree.
When the L key is also given, symbolic links to non-local files or
directories are also skipped. No message is issued for skipped
files unless the v key is given more than once.
Page 5
TAR(1) TAR(1)
R When extracting from tape, ignore leading slashes on file names,
i.e., extract all files relative to the current directory. This
also applies (as of IRIX 6.2) to any links that are restored (and
symbolic links if specified as RR). When specified as RRR, all
filenames (including the targets of symbolic links) are made
directory relative; that is, they are extracted as ./filename.
This mode is intended for the use of programs running as root, such
as tardist, that want to be sure that they do not overwrite system
files when extracting archives, either by accident, or through a
trojan horse attack. Since the t,x and other options referring to
specific files use pattern matching, you must omit the leading '/'
when specifying directory or filenames with those options when
using the R option. Thus, to extract /a/b/c with a relative
pathname, you would do:
tar xvR a/b/c
Earlier releases prepended a leading '.', requiring the use of:
tar xvR ./a/b/c
The way to check for sure is to use:
tar tvR | head -2
and then use whichever format is used in the output list.
If specified as RRR, all directory information is stripped from
pathnames in the archive, including the pathnames of symbolic
links. All files will be written to the current directory; no
directories will be created; symbolic links will only refer to
files in the current directory. Note that if two or more different
files in the archive have the same filename but have different
pathnames, the last file extracted will overwrite any earlier file
with the same filename.
U For each file extracted, unlink existing file (if any).
O Write old tapes in an older (pre-IRIX 4.0) format, as opposed to
the POSIX format. This will not archive or extract files with
pathnames > 99 characters (not including the string-terminating
NULL character), and store user and group ids by value rather than
by name. In addition, special files will be archived so that they
may be interpreted correctly by previous releases of tar that
understand only the old format. (Previous releases of tar will
understand the POSIX format, but will interpret special files as
regular files.)
o By default, tar will chown files to the owner (and group) stored in
the archive when invoked by the superuser. This flag will prevent
this behavior, leaving the newly created files owned by root. This
flag is ignored when tar is not invoked by the superuser.
S Use pre-IRIX 4.0 behavior, so that tar will perform a chown to the
owner (and group) specified in the archive, regardless of whether
the -o flag is specified, or whether tar is invoked by superuser.
Page 6
TAR(1) TAR(1)
V Variable blocking; the last tape block will not be filled to the
blocking size. Note that this may prevent the archive from being
updated with r or u. This option also prevents the blocksize from
being set to 1 when `-' is used as the archive name (i.e., the b
option will be honored).
a Reset access times of input files after they have been copied to
the archive.
q Turn on debugging and extra error diagnostics. Supplying this flag
multiple times increases debugging level.
K Required for files larger than 2 Gigabytes. Tar will issue a
warning and skip such files if an attempt is made to archive them
without the K option. Mutually exclusive with the O option.
Warning: Use of this option may result in the creation of an
archive that is not portable to other machines.
F Skip files named core and errs, and subdirectories named SCCS. If
specified as FF, also skip files with the .o suffix, and files
named a.out.
M By default extended attributes are not archived or restored using
tar (see attr(1)). The -M option allows files ACL's, capability
sets and MAC labels to be archived. The -M option must be be
specified with either the 'c', 't', or 'x' options and should be
specified during both archiving and restoring. Note that restoring
file capability sets will require the process to have the
capability of CAP_SETFCAP in the effective set, and restoring file
MAC labels may require the additional capability of CAP_MAC_UPGRADE
or CAP_MAC_DOWNGRADE (see capabilities(4)).
If a file name is preceded by -C, then tar will perform a chdir(2) to
that file name. This allows multiple directories not related by a close
common parent to be archived using short relative path names. This
provides a method to get around the limitation of filename length; note
that some care must be used when extracting a backup created in this
manner. For example, to archive files from /usr/include and from /etc,
one might use
tar c -C /usr include -C / etc
If a file name of - is given on the command line when making an archive
then tar will read its standard input for a list of files to back up, one
per line; files will be dumped in list order. For example, to back up
all files that have changed in the last week, one might use:
find / -local ! -type d -mtime -7 -type f -print | tar ca -
Are intended to be self-explanatory. For diagnostics other than those
about options, tar uses the perror(3) library routine to provide the
cause of the error. The message `Read-only file system' usually
indicates an attempt to write on a write-protected device.
Page 7
TAR(1) TAR(1)
Tar will now attempt to recognize byte swapped tapes, and will report
them with a message similar to:
tar: directory checksum error
tar: this appears to be a byte-swapped archive
In this case, if the byte swapping device is being used to read the tape,
the non-byteswapping device should be used instead, or vice-versa. If
the interface doesn't support driver byte swapping (as is typical on
non-SGI systems), a command similar to this should be used (with the
appropriate blocking factor):
dd if=/dev/rmt/tapedevice bs=20b conv=swab | tar vtf -
There is no way to ask for the n-th occurrence of a file.
The u option can be slow.
The data for a file with multiple links is output to tape with the first
link encountered. Thus, an attempt to extract a subsequent link by
itself will not have the desired result.
For the r and u options to work on multi-tapefile tapes (multiple
independent tar archives on the same tape). the tape must be positioned
to the last tapefile on the tape. This would typically be done with a
sequence such as:
mt feom; mt bsf 2; mt fsf 1; tar c ...
For multi-tapefile tapes there is no guarantee that after reading a
tapefile (c or t option) non-rewinding tape is positioned at the FM. In
this case, immediate execution of another tar may not succeed in reading
the next tapefile from the tape. One may need to use mt to position the
tape to the next tapefile before executing the next tar read. The surest
way to guarantee the position of the tape is to use mt rewind and mt fsf
to position the tape to the desired file before proceeding with the next
tar tapefile read.
The r and u options currently work only on tape drives that support the
MTAFILE ioctl; currently only 9 track and DAT (of the drives supported by
SGI) support this (see the MTCAN_APPEND capability for SCSI tape devices,
in /var/sysgen/master.d/tpsc). They are not supported on any variety of
quarter inch cartridge tape drive or on the Exabyte 8mm tape drive,
because the drive hardware does not allow this function to be
implemented, as they do not support data overwrite. These options are
supported on archives that are normal files, with the restriction that
the blocking factor must be the same when appending as when the archive
was created.
Since tar uses the MTBSR ioctl (for devices) to backspace over the last
Page 8
TAR(1) TAR(1)
record when appending, the blocksize used when updating must be the same
as that when creating the tape. In addition, if the fixed blocksize
device is being used (with SCSI tapes), the blocksize must be 1, in order
for the algorithm to work correctly.
If you open a remote tape device and receive an I/O error, it is possible
that the remote tape interface program is obsolete and not compatible
with the remote tape subroutine library that tar uses. It may also be
the case that shell startup files on the remote do output to the
terminal; see the notes on this on the rsh(1) man page (remote shell, not
restricted shell).
/dev/tape, /dev/tapens, /dev/rmt/*, /tmp/tar* (for r and u options).
$TAPE if set, is used instead of /dev/tape as the default when f not
given.
mtio(7), tps(7m), mt(1), attr(1), xfsdump(1m).
PPPPaaaaggggeeee 9999 [ Back ]
|