blob: 1eb99c03067d6abd3e8d886d7940c3ac5da7cf43 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
:orphan:
=====================================================
ceph-kvstore-tool -- ceph kvstore manipulation tool
=====================================================
.. program:: ceph-kvstore-tool
Synopsis
========
| **ceph-kvstore-tool** <leveldb|rocksdb|bluestore-kv> <store path> *command* [args...]
Description
===========
:program:`ceph-kvstore-tool` is a kvstore manipulation tool. It allows users to manipulate
leveldb/rocksdb's data (like OSD's omap) offline.
Commands
========
:program:`ceph-kvstore-tool` utility uses many commands for debugging purpose
which are as follows:
:command:`list [prefix]`
Print key of all KV pairs stored with the URL encoded prefix.
:command:`list-crc [prefix]`
Print CRC of all KV pairs stored with the URL encoded prefix.
:command:`dump [prefix]`
Print key and value of all KV pairs stored with the URL encoded prefix.
:command:`exists <prefix> [key]`
Check if there is any KV pair stored with the URL encoded prefix. If key
is also specified, check for the key with the prefix instead.
:command:`get <prefix> <key> [out <file>]`
Get the value of the KV pair stored with the URL encoded prefix and key.
If file is also specified, write the value to the file.
:command:`crc <prefix> <key>`
Get the CRC of the KV pair stored with the URL encoded prefix and key.
:command:`get-size [<prefix> <key>]`
Get estimated store size or size of value specified by prefix and key.
:command:`set <prefix> <key> [ver <N>|in <file>]`
Set the value of the KV pair stored with the URL encoded prefix and key.
The value could be *version_t* or text.
:command:`rm <prefix> <key>`
Remove the KV pair stored with the URL encoded prefix and key.
:command:`rm-prefix <prefix>`
Remove all KV pairs stored with the URL encoded prefix.
:command:`store-copy <path> [num-keys-per-tx]`
Copy all KV pairs to another directory specified by ``path``.
[num-keys-per-tx] is the number of KV pairs copied for a transaction.
:command:`store-crc <path>`
Store CRC of all KV pairs to a file specified by ``path``.
:command:`compact`
Subcommand ``compact`` is used to compact all data of kvstore. It will open
the database, and trigger a database's compaction. After compaction, some
disk space may be released.
:command:`compact-prefix <prefix>`
Compact all entries specified by the URL encoded prefix.
:command:`compact-range <prefix> <start> <end>`
Compact some entries specified by the URL encoded prefix and range.
:command:`destructive-repair`
Make a (potentially destructive) effort to recover a corrupted database.
Note that in the case of rocksdb this may corrupt an otherwise uncorrupted
database--use this only as a last resort!
:command:`stats`
Prints statistics from underlying key-value database. This is only for informative purposes.
Format and information content may vary between releases. For RocksDB information includes
compactions stats, performance counters, memory usage and internal RocksDB stats.
Availability
============
**ceph-kvstore-tool** is part of Ceph, a massively scalable, open-source, distributed storage system. Please refer to
the Ceph documentation at http://ceph.com/docs for more information.
See also
========
:doc:`ceph <ceph>`\(8)
|