Provided by: lvm2_2.03.22-1ubuntu2_amd64 bug

NAME

       pvck — Check metadata on physical volumes

SYNOPSIS

       pvck option_args position_args
           [ option_args ]

           --commandprofile String
           --config String
        -d|--debug
           --devices PV
           --devicesfile String
           --driverloaded y|n
           --dump headers|metadata|metadata_all|metadata_search
        -f|--file String
        -h|--help
           --journal String
           --labelsector Number
           --lockopt String
           --longhelp
           --nohints
           --nolocking
           --profile String
           --[pv]metadatacopies 0|1|2
        -q|--quiet
           --repair
           --repairtype pv_header|metadata|label_header
           --settings String
        -t|--test
        -v|--verbose
           --version
        -y|--yes

DESCRIPTION

       pvck checks and repairs LVM metadata on PVs.

   Dump options
       headers
       Print  LVM  on-disk  headers  and  structures: label_header, pv_header, mda_header(s), and metadata text.
       Warnings are printed if any values are incorrect.  The label_header and pv_header both  exist  in  a  512
       byte  sector, usually the second sector of the device.  An mda_header exists in a 512 byte sector at off‐
       set 4096 bytes.  A second mda_header can optionally exist near the end of the device.  The metadata  text
       exists in an area (about 1MiB by default) immediately following the mda_header sector.  The metadata text
       is checked but not printed (see other options).

       metadata
       Print  the  current  LVM VG metadata text (or save to a file), using headers to locate the latest copy of
       metadata.  If headers are damaged, metadata may not  be  found  (see  metadata_search).   Use  --settings
       "mda_num=2"  to  look  in  mda2 (the second mda at the end of the device, if used).  The metadata text is
       printed to stdout or saved to a file with --file.

       metadata_all
       List all versions of VG metadata found in the metadata area, using  headers  to  locate  metadata.   Full
       copies  of all metadata are saved to a file with the --file option.  If headers are damaged, metadata may
       not be found (see metadata_search).  Use --settings "mda_num=2" as above.  Use -v to include descriptions
       and dates when listing metadata versions.

       metadata_search
       List all versions of VG metadata found in the metadata area, searching common locations so  metadata  can
       be found if headers are damaged.  Full copies of all metadata are saved to a file with the --file option.
       To  save one specific version of metadata, use --settings "metadata_offset=<offset>", where the offset is
       taken from the list of versions found.  Use -v to include descriptions and dates  when  listing  metadata
       versions.

       metadata_area
       Save the entire text metadata area to a file without processing.

   Repair options
       --repair
       Repair  headers and metadata on a PV.  This uses a metadata input file that was extracted by --dump, or a
       backup file (from /etc/lvm/backup).  When possible, use metadata saved by --dump from another PV  in  the
       same VG (or from a second metadata area on the PV).

       There are cases where the PV UUID needs to be specified for the PV being repaired.  It is specified using
       --settings  "pv_uuid=<UUID>".  In particular, if the device name for the PV being repaired does not match
       the previous device name of the PV, then LVM may not be able to determine  the  correct  PV  UUID.   When
       headers are damaged on more than one PV in a VG, it is important for the user to determine the correct PV
       UUID  and specify it in --settings.  Otherwise, the wrong PV UUID could be used if device names have been
       swapped since the metadata was last written.

       If a PV has no metadata areas and the pv_header is damaged, then the repair will not know  to  create  no
       metadata  areas  during  repair.  It will by default repair metadata in mda1.  To repair with no metadata
       areas, use --settings "mda_offset=0 mda_size=0".

       There are cases where repair should be run on all PVs in the VG (using the same metadata file):   if  all
       PVs  in  the VG are damaged, if using an old metadata version, or if a backup file is used instead of raw
       metadata (taken from pvck dump.)

       Using --repair is equivalent to running --repairtype pv_header followed by --repairtype metadata.

       --repairtype pv_header
       Repairs the header sector, containing the pv_header and label_header.

       --repairtype metadata
       Repairs the mda_header and metadata text.  It requires the headers to be correct (having  been  undamaged
       or already repaired).

       --repairtype label_header
       Repairs label_header fields, leaving the pv_header (in the same sector) unchanged.  (repairtype pv_header
       should usually be used instead.)

   Settings
       The --settings option controls or overrides certain dump or repair behaviors.  All offset and size values
       in settings are in bytes (units are not recognized.)  These settings are subject to change.

       mda_num=1|2
       Select  which metadata area should be used.  By default the first metadata area (1) is used.  mda1 is al‐
       ways located at offset 4096.  mda2, at the end of the device, often does not exist (it's not  created  by
       default.) If mda1 is erased, mda2, if it exists, will often still have metadata.

       metadata_offset=bytes
       Select  metadata  text  at  this offset.  Use with metadata_search to print/save one instance of metadata
       text.

       mda_offset=bytes mda_size=bytes
       Refers to a metadata area (mda) location and size.  An mda includes an mda_header and  circular  metadata
       text  buffer.   Setting  this  forces  metadata_search look for metadata in the given area instead of the
       standard locations.  When set to zero with repair, it indicates no metadata areas should exist.

       mda2_offset=bytes mda2_size=bytes
       When repairing a pv_header, this forces a specific offset and size for mda2 that should  be  recorded  in
       the pv_header.

       pv_uuid=uuid
       Specify  the  PV UUID of the device being repaired.  When not specified, repair will attempt to determine
       the correct PV UUID by matching a device name in the metadata.

       device_size=bytes
       data_offset=bytes
       When repairing a pv_header, the device_size, data_offset, and pvid can  all  be  specified  directly,  in
       which  case these values are not taken from a metadata file (where they usually come from), and the meta‐
       data file can be omitted.  data_offset is the starting location of  the  first  physical  extent  (data),
       which follows the first metadata area.

USAGE

       Check for metadata on a device

       pvck PV ...
           [ COMMON_OPTIONS ]

       —

       Check and print LVM headers and metadata on a device

       pvck --dump headers|metadata|metadata_all|metadata_search PV
           [ -f|--file String ]
           [    --settings String ]
           [    --[pv]metadatacopies 0|1|2 ]
           [ COMMON_OPTIONS ]

       —

       Repair LVM headers or metadata on a device

       pvck --repairtype pv_header|metadata|label_header PV
           [ -f|--file String ]
           [    --settings String ]
           [ COMMON_OPTIONS ]

       —

       Repair LVM headers and metadata on a device

       pvck --repair -f|--file String PV
           [    --settings String ]
           [ COMMON_OPTIONS ]

       —

       Common options for command:
           [    --labelsector Number ]

       Common options for lvm:
           [ -d|--debug ]
           [ -h|--help ]
           [ -q|--quiet ]
           [ -t|--test ]
           [ -v|--verbose ]
           [ -y|--yes ]
           [    --commandprofile String ]
           [    --config String ]
           [    --devices PV ]
           [    --devicesfile String ]
           [    --driverloaded y|n ]
           [    --journal String ]
           [    --lockopt String ]
           [    --longhelp ]
           [    --nohints ]
           [    --nolocking ]
           [    --profile String ]
           [    --version ]

OPTIONS


       --commandprofile String
              The  command profile to use for command configuration.  See lvm.conf(5) for more information about
              profiles.

       --config String
              Config settings for the command. These override lvm.conf(5) settings.  The  String  arg  uses  the
              same format as lvm.conf(5), or may use section/field syntax.  See lvm.conf(5) for more information
              about config.

       -d|--debug ...
              Set  debug level. Repeat from 1 to 6 times to increase the detail of messages sent to the log file
              and/or syslog (if configured).

       --devices PV
              Restricts the devices that are visible and accessible to the command.  Devices not listed will ap‐
              pear to be missing. This option can be repeated, or accepts a comma  separated  list  of  devices.
              This overrides the devices file.

       --devicesfile String
              A  file listing devices that LVM should use.  The file must exist in /etc/lvm/devices/ and is man‐
              aged with the lvmdevices(8) command.  This overrides the lvm.conf(5) devices/devicesfile  and  de‐
              vices/use_devicesfile settings.

       --driverloaded y|n
              If set to no, the command will not attempt to use device-mapper.  For testing and debugging.

       --dump headers|metadata|metadata_all|metadata_search
              Dump  headers  and metadata from a PV for debugging and repair.  Option values include: headers to
              print and check LVM headers, metadata to print or save the current text metadata, metadata_all  to
              list  or  save all versions of metadata, metadata_search to list or save all versions of metadata,
              searching standard locations in case of damaged headers, metadata_area  to  save  an  entire  text
              metadata area to a file.

       -f|--file String
              Metadata file to read or write.

       -h|--help
              Display help text.

       --journal String
              Record information in the systemd journal.  This information is in addition to information enabled
              by  the  lvm.conf  log/journal  setting.   command: record information about the command.  output:
              record the default command output.  debug: record full command debugging.

       --labelsector Number
              By default the PV is labelled with an LVM2 identifier in its second sector (sector 1).  This  lets
              you  use  a  different  sector  near  the  start  of the disk (between 0 and 3 inclusive - see LA‐
              BEL_SCAN_SECTORS in the source). Use with care.

       --lockopt String
              Used to pass options for special cases to lvmlockd.  See lvmlockd(8) for more information.

       --longhelp
              Display long help text.

       --nohints
              Do not use the hints file to locate devices for PVs. A command may read more devices to  find  PVs
              when  hints are not used. The command will still perform standard hint file invalidation where ap‐
              propriate.

       --nolocking
              Disable locking. Use with caution, concurrent commands may produce incorrect results.

       --profile String
              An alias for --commandprofile or --metadataprofile, depending on the command.

       --[pv]metadatacopies 0|1|2
              The number of metadata areas to set aside on a PV for storing VG metadata.  When 2,  one  copy  of
              the  VG metadata is stored at the front of the PV and a second copy is stored at the end.  When 1,
              one copy of the VG metadata is stored at the front of the PV.  When 0, no copies of the VG metada‐
              ta are stored on the given PV.  This may be useful in VGs containing many PVs (this places limita‐
              tions on the ability to use vgsplit later.)

       -q|--quiet ...
              Suppress output and log messages. Overrides --debug and --verbose.  Repeat once to  also  suppress
              any prompts with answer 'no'.

       --repair
              Repair headers and metadata on a PV.

       --repairtype pv_header|metadata|label_header
              Repair headers and metadata on a PV. See command description.

       --settings String
              Specifies  command  specific settings in "Key = Value" form.  Combine multiple settings in quotes,
              or repeat the settings option for each.

       -t|--test
              Run in test mode. Commands will not update metadata.  This is implemented by disabling all metada‐
              ta writing but nevertheless returning success to the calling function. This may  lead  to  unusual
              error messages in multi-stage operations if a tool relies on reading back metadata it believes has
              changed but hasn't.

       -v|--verbose ...
              Set  verbose level. Repeat from 1 to 4 times to increase the detail of messages sent to stdout and
              stderr.

       --version
              Display version information.

       -y|--yes
              Do not prompt for confirmation interactively but always assume the answer yes.  Use  with  extreme
              caution.  (For automatic no, see -qq.)

VARIABLES

       PV     Physical  Volume name, a device path under /dev.  For commands managing physical extents, a PV po‐
              sitional arg generally accepts a suffix indicating a range (or multiple ranges)  of  physical  ex‐
              tents  (PEs).  When  the first PE is omitted, it defaults to the start of the device, and when the
              last PE is omitted it defaults to end.  Start and end range (inclusive): PV[:PE-PE]...  Start  and
              length range (counting from 0): PV[:PE+PE]...

       String See the option description for information about the string content.

       Size[UNIT]
              Size is an input number that accepts an optional unit.  Input units are always treated as base two
              values, regardless of capitalization, e.g. 'k' and 'K' both refer to 1024.  The default input unit
              is  specified  by  letter,  followed by |UNIT.  UNIT represents other possible input units: b|B is
              bytes, s|S is sectors of 512 bytes, k|K is KiB, m|M is MiB, g|G is GiB, t|T is TiB,  p|P  is  PiB,
              e|E  is  EiB.  (This should not be confused with the output control --units, where capital letters
              mean multiple of 1000.)

ENVIRONMENT VARIABLES

       See lvm(8) for information about environment variables used by lvm.  For example, LVM_VG_NAME can  gener‐
       ally be substituted for a required VG parameter.

EXAMPLES

       If  the  partition  table is corrupted or lost on /dev/sda, and you suspect there was an LVM partition at
       approximately 100 MiB, then this area of the disk can be scanned using the --labelsector parameter with a
       value of 204800 (100 * 1024 * 1024 / 512 = 204800).
       pvck --labelsector 204800 /dev/sda

SEE ALSO

       lvm(8), lvm.conf(5), lvmconfig(8), lvmdevices(8),

       pvchange(8), pvck(8), pvcreate(8), pvdisplay(8), pvmove(8), pvremove(8), pvresize(8), pvs(8), pvscan(8),

       vgcfgbackup(8), vgcfgrestore(8), vgchange(8), vgck(8), vgcreate(8), vgconvert(8), vgdisplay(8),
       vgexport(8), vgextend(8), vgimport(8), vgimportclone(8), vgimportdevices(8), vgmerge(8), vgmknodes(8),
       vgreduce(8), vgremove(8), vgrename(8), vgs(8), vgscan(8), vgsplit(8),

       lvcreate(8), lvchange(8), lvconvert(8), lvdisplay(8), lvextend(8), lvreduce(8), lvremove(8), lvrename(8),
       lvresize(8), lvs(8), lvscan(8),

       lvm-fullreport(8), lvm-lvpoll(8), blkdeactivate(8), lvmdump(8),

       dmeventd(8), lvmpolld(8), lvmlockd(8), lvmlockctl(8), cmirrord(8), lvmdbusd(8), fsadm(8),

       lvmsystemid(7), lvmreport(7), lvmcache(7), lvmraid(7), lvmthin(7), lvmvdo(7), lvmautoactivation(7)

Red Hat, Inc.                           LVM TOOLS 2.03.22(2) (2023-08-02)                                PVCK(8)