2005-12-08 12:14:33 +00:00
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
salvager - Initializes the Salvager component of the fs process
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
2006-03-01 05:02:29 +00:00
|
|
|
=for html
|
|
|
|
<div class="synopsis">
|
|
|
|
|
|
|
|
B<salvager> [I<initcmd>] S<<< [B<-partition> <I<name of partition to salvage>>] >>>
|
|
|
|
S<<< [B<-volumeid> <I<volume id to salvage>>] >>> [B<-debug>] [B<-nowrite>]
|
2005-12-13 19:21:13 +00:00
|
|
|
[B<-inodes>] [B<-force>] [B<-oktozap>] [B<-rootinodes>]
|
|
|
|
[B<-salvagedirs>] [B<-blockreads>]
|
2006-03-01 05:02:29 +00:00
|
|
|
S<<< [B<-parallel> <I<# of max parallel partition salvaging>>] >>>
|
|
|
|
S<<< [B<-tmpdir> <I<name of dir to place tmp files>>] >>>
|
2005-12-13 19:21:13 +00:00
|
|
|
[B<-showlog>] [B<-showsuid>] [B<-showmounts>]
|
2006-03-01 05:02:29 +00:00
|
|
|
S<<< [B<-orphans> (ignore | remove | attach)] >>> [B<-help>]
|
|
|
|
|
|
|
|
=for html
|
|
|
|
</div>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
The B<salvager> command initializes the Salvager component of the C<fs>
|
|
|
|
process. In the conventional configuration, its binary file is located in
|
|
|
|
the F</usr/afs/bin> directory on a file server machine.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
The Salvager restores internal consistency to corrupted read/write volumes
|
2005-12-13 19:21:13 +00:00
|
|
|
on the local file server machine where possible. For read-only or backup
|
|
|
|
volumes, it inspects only the volume header:
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item *
|
|
|
|
|
|
|
|
If the volume header is corrupted, the Salvager removes the volume
|
|
|
|
completely and records the removal in its log file,
|
2005-12-13 19:21:13 +00:00
|
|
|
F</usr/afs/logs/SalvageLog>. Issue the B<vos release> or B<vos backup>
|
|
|
|
command to create the read-only or backup volume again.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=item *
|
|
|
|
|
|
|
|
If the volume header is intact, the Salvager skips the volume (does not
|
2005-12-13 19:21:13 +00:00
|
|
|
check for corruption in the contents). However, if the File Server notices
|
|
|
|
corruption as it initializes, it sometimes refuses to attach the volume or
|
|
|
|
bring it online. In this case, it is simplest to remove the volume by
|
|
|
|
issuing the B<vos remove> or B<vos zap> command. Then issue the B<vos
|
|
|
|
release> or B<vos backup> command to create it again.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Unlike other server process initialization commands, the B<salvager>
|
|
|
|
command is designed to be issued at the command shell prompt, as well as
|
|
|
|
being placed into a file server machine's F</usr/afs/local/BosConfig> file
|
|
|
|
with the B<bos create> command. It is also possible to invoke the Salvager
|
|
|
|
remotely by issuing the B<bos salvage> command.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Combine the command's options as indicated to salvage different numbers of
|
|
|
|
read/write volumes:
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item *
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
To salvage all volumes on the file server machine, provide no arguments.
|
|
|
|
No volumes on the machine are accessible to Cache Managers during the
|
|
|
|
salvage, because the BOS Server stops the File Server and Volume Server
|
|
|
|
processes while the Salvager runs.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=item *
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
To salvage all of the volumes on one partition, provide the B<-partition>
|
|
|
|
argument. As for a salvage of all volumes on the machine, no volumes on
|
|
|
|
the machine are accessible to Cache Managers during the salvage operation.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=item *
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
To salvage only one volume, combine the B<-partition> and B<-volumeid>
|
|
|
|
arguments. Only that volume is inaccessible to Cache Managers, because the
|
|
|
|
BOS Server does not shutdown the File Server and Volume Server processes.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
The Salvager normally salvages only those read/write volumes that are
|
2005-12-13 19:21:13 +00:00
|
|
|
marked as having been active when a crash occurred. To have it salvage all
|
|
|
|
relevant read/write volumes, add the B<-force> flag.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
The Salvager normally creates new inodes as it repairs damage. If the
|
|
|
|
partition is so full that there is no room for new inodes, use the
|
2005-12-08 12:14:33 +00:00
|
|
|
B<-nowrite> argument to bringing undamaged volumes online without
|
2005-12-13 19:21:13 +00:00
|
|
|
attempting to salvage damaged volumes. Then use the B<vos move> command to
|
|
|
|
move one or more of the undamaged volumes to other partitions, freeing up
|
|
|
|
the space that the Salvager needs to create new inodes.
|
|
|
|
|
|
|
|
By default, multiple Salvager subprocesses run in parallel: one for each
|
|
|
|
partition up to four, and four subprocesses for four or more
|
|
|
|
partitions. To increase or decrease the number of subprocesses running in
|
|
|
|
parallel, provide a positive integer value for the B<-parallel> argument.
|
|
|
|
|
|
|
|
If there is more than one server partition on a physical disk, the
|
|
|
|
Salvager by default salvages them serially to avoid the inefficiency of
|
|
|
|
constantly moving the disk head from one partition to another. However,
|
|
|
|
this strategy is often not ideal if the partitions are configured as
|
|
|
|
logical volumes that span multiple disks. To force the Salvager to salvage
|
2009-02-02 01:19:00 +00:00
|
|
|
logical volumes in parallel as if they were on separate disks, provide the
|
|
|
|
string C<all> as the value for the B<-parallel> argument.
|
|
|
|
|
|
|
|
To set both parameters at the same time, append the number of Salvager
|
|
|
|
processes to the string C<all>. For example, C<-parallel all5> treats
|
|
|
|
each partition as a separate disk and runs five Salvager processes, thus
|
|
|
|
salvaging five partitions at a time.
|
2005-12-13 19:21:13 +00:00
|
|
|
|
|
|
|
The Salvager creates temporary files as it runs, by default writing them
|
|
|
|
to the partition it is salvaging. The number of files can be quite large,
|
|
|
|
and if the partition is too full to accommodate them, the Salvager
|
|
|
|
terminates without completing the salvage operation (it always removes the
|
|
|
|
temporary files before exiting). Other Salvager subprocesses running at
|
|
|
|
the same time continue until they finish salvaging all other partitions
|
|
|
|
where there is enough disk space for temporary files. To complete the
|
|
|
|
interrupted salvage, reissue the command against the appropriate
|
|
|
|
partitions, adding the B<-tmpdir> argument to redirect the temporary files
|
|
|
|
to a local disk directory that has enough space.
|
|
|
|
|
|
|
|
The B<-orphans> argument controls how the Salvager handles orphaned files
|
|
|
|
and directories that it finds on server partitions it is salvaging. An
|
|
|
|
I<orphaned> element is completely inaccessible because it is not
|
|
|
|
referenced by the vnode of any directory that can act as its parent (is
|
|
|
|
higher in the filespace). Orphaned objects occupy space on the server
|
|
|
|
partition, but do not count against the volume's quota.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
To generate a list of all mount points that reside in one or more volumes,
|
2005-12-13 19:21:13 +00:00
|
|
|
rather than actually salvaging them, include the B<-showmounts> flag.
|
|
|
|
|
|
|
|
This command does not use the syntax conventions of the AFS command
|
|
|
|
suites. Provide the command name and all option names in full.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=head1 OPTIONS
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item [I<initcmd>]
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Accommodates the command's use of the AFS command parser, and is optional.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-partition> <I<name of partition to salvage>>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Specifies the name of the partition to salvage. Specify the full partition
|
|
|
|
name using the form F</vicepI<x>> or F</vicepI<xx>>. Omit this argument to
|
|
|
|
salvage every partition on the file server machine.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-volumeid> <I<volume id to salvage>>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Specifies the volume ID of a specific read/write volume to salvage. The
|
|
|
|
B<-partition> argument must be provided along with this one and specify
|
|
|
|
the volume's actual site.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-debug>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
Allows only one Salvager subprocess to run at a time, regardless of the
|
2005-12-13 19:21:13 +00:00
|
|
|
setting of the B<-parallel> option. Include it when running the Salvager
|
|
|
|
in a debugger to make the trace easier to interpret.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-nowrite>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
Brings all undamaged volumes online without attempting to salvage any
|
|
|
|
damaged volumes.
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-inodes>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Records in the F</usr/afs/logs/SalvageLog> file a list of all AFS inodes
|
|
|
|
that the Salvager modified.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-force>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
Inspects all volumes for corruption, not just those that are marked as
|
|
|
|
having been active when a crash occurred.
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-oktozap>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Removes a volume that is so damaged that even issuing the B<vos zap>
|
|
|
|
command with the B<-force> flag is ineffective. Use this argument only in
|
|
|
|
consultation with AFS Development or Product Support. Combine it with the
|
|
|
|
B<-partition> and B<-volumeid> arguments to identify the volume to remove.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-rootinodes>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Records in the F</usr/afs/logs/SalvageLog> file a list of all AFS inodes
|
|
|
|
owned by the local superuser C<root>.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-salvagedirs>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
Salvages entire directory structures, even if they do not appear to be
|
|
|
|
damaged. By default, the Salvager salvages a directory only if it is
|
|
|
|
flagged as corrupted.
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-blockreads>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
Forces the Salvager to read a partition one disk block (512 bytes) at a
|
|
|
|
time and to skip any blocks that are too badly damaged to be salvaged.
|
|
|
|
This allows it to salvage as many volumes as possible. By default, the
|
2005-12-13 19:21:13 +00:00
|
|
|
Salvager reads large disk blocks, which can cause it to exit prematurely
|
|
|
|
if it encounters disk errors. Use this flag if the partition to be
|
|
|
|
salvaged has disk errors.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-parallel> <I<# of max parallel partition salvaging>>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Specifies the maximum number of Salvager subprocesses to run in parallel.
|
|
|
|
Provide one of three values:
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item *
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
An integer from the range C<1> to C<32>. A value of C<1> means that a
|
|
|
|
single Salvager process salvages the partitions sequentially.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=item *
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
The string C<all> to run up to four Salvager subprocesses in parallel on
|
|
|
|
partitions formatted as logical volumes that span multiple physical
|
|
|
|
disks. Use this value only with such logical volumes.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=item *
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
The string C<all> followed immediately (with no intervening space) by an
|
|
|
|
integer from the range C<1> to C<32>, to run the specified number of
|
|
|
|
Salvager subprocesses in parallel on partitions formatted as logical
|
|
|
|
volumes. Use this value only with such logical volumes.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
The BOS Server never starts more Salvager subprocesses than there are
|
|
|
|
partitions, and always starts only one process to salvage a single
|
2005-12-13 19:21:13 +00:00
|
|
|
volume. If this argument is omitted, up to four Salvager subprocesses run
|
2009-02-02 01:19:00 +00:00
|
|
|
in parallel but partitions on the same device are salvaged serially.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-tmpdir> <I<name of dir to place tmp files>>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
Names a local disk directory in which the Salvager places the temporary
|
2005-12-13 19:21:13 +00:00
|
|
|
files it creates during a salvage operation, instead of writing them to
|
|
|
|
the partition being salvaged (the default). If the Salvager cannot write
|
|
|
|
to the specified directory, it attempts to write to the partition being
|
2005-12-08 12:14:33 +00:00
|
|
|
salvaged.
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-showlog>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
Displays on the standard output stream all log data that is being written
|
2005-12-13 19:21:13 +00:00
|
|
|
to the F</usr/afs/logs/SalvageLog> file.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-showsuid>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
Displays a list of the pathnames for all files that have the setuid or
|
|
|
|
setgid mode bit set.
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-showmounts>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Records in the F</usr/afs/logs/SalvageLog> file all mount points found in
|
|
|
|
each volume. The Salvager does not repair corruption in the volumes, if
|
|
|
|
any exists.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-orphans> (ignore | remove | attach)
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Controls how the Salvager handles orphaned files and directories. Choose
|
|
|
|
one of the following three values:
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item ignore
|
|
|
|
|
|
|
|
Leaves the orphaned objects on the disk, but prints a message to the
|
2005-12-13 19:21:13 +00:00
|
|
|
F</usr/afs/logs/SalvageLog> file reporting how many orphans were found and
|
|
|
|
the approximate number of kilobytes they are consuming. This is the
|
2005-12-08 12:14:33 +00:00
|
|
|
default if the B<-orphans> argument is omitted.
|
|
|
|
|
|
|
|
=item remove
|
|
|
|
|
|
|
|
Removes the orphaned objects, and prints a message to the
|
2005-12-13 19:21:13 +00:00
|
|
|
F</usr/afs/logs/SalvageLog> file reporting how many orphans were removed
|
|
|
|
and the approximate number of kilobytes they were consuming.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=item attach
|
|
|
|
|
|
|
|
Attaches the orphaned objects by creating a reference to them in the vnode
|
2005-12-13 19:21:13 +00:00
|
|
|
of the volume's root directory. Since each object's actual name is now
|
|
|
|
lost, the Salvager assigns each one a name of the following form:
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item C<__ORPHANFILE__.I<index>> for files.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item C<__ORPHANDIR__.I<index>> for directories.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
where I<index> is a two-digit number that uniquely identifies each
|
2005-12-13 19:21:13 +00:00
|
|
|
object. The orphans are charged against the volume's quota and appear in
|
|
|
|
the output of the B<ls> command issued against the volume's root
|
|
|
|
directory.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
=item B<-help>
|
2005-12-08 12:14:33 +00:00
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
Prints the online help for this command. All other valid options are
|
|
|
|
ignored.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 EXAMPLES
|
|
|
|
|
|
|
|
The following command instructs the Salvager to attempt to salvage the
|
2005-12-13 19:21:13 +00:00
|
|
|
volume with volume ID 258347486 on F</vicepg> on the local machine.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
% /usr/afs/bin/salvager -partition /vicepg -volumeid 258347486
|
|
|
|
|
|
|
|
=head1 PRIVILEGE REQUIRED
|
|
|
|
|
|
|
|
To issue the command at the shell prompt, the issuer must be logged in as
|
2005-12-13 19:21:13 +00:00
|
|
|
the local superuser C<root>.
|
2005-12-08 12:14:33 +00:00
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2005-12-13 19:21:13 +00:00
|
|
|
L<BosConfig(5)>,
|
|
|
|
L<SalvageLog(5)>,
|
|
|
|
L<bos_create(8)>,
|
|
|
|
L<bos_getlog(8)>,
|
|
|
|
L<bos_salvage(8)>,
|
2005-12-08 12:14:33 +00:00
|
|
|
L<vos_move(1)>
|
|
|
|
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
|
|
|
IBM Corporation 2000. <http://www.ibm.com/> All Rights Reserved.
|
|
|
|
|
|
|
|
This documentation is covered by the IBM Public License Version 1.0. It was
|
|
|
|
converted from HTML to POD by software written by Chas Williams and Russ
|
|
|
|
Allbery, based on work by Alf Wachsmann and Elizabeth Cassell.
|