.\" Copyright 2015-2025 Leonid Yuriev . .\" Copyright 2015,2016 Peter-Service R&D LLC . .\" Copyright 2012-2015 Howard Chu, Symas Corp. All Rights Reserved. .\" Copying restrictions apply. See COPYRIGHT/LICENSE. .TH MDBX_COPY 1 "2025-01-14" "MDBX 0.14" .SH NAME mdbx_copy \- MDBX environment copy tool .SH SYNOPSIS .B mdbx_copy [\c .BR \-V ] [\c .BR \-q ] [\c .BR \-c ] [\c .BR \-d ] [\c .BR \-p ] [\c .BR \-n ] .B src_path [\c .BR dest_path ] .SH DESCRIPTION The .B mdbx_copy utility copies an MDBX environment. The environment can be copied regardless of whether it is currently in use. No lockfile is created, since it gets recreated at need. If .I dest_path is specified it must be the path of an empty directory for storing the backup. Otherwise, the backup will be written to stdout. .SH OPTIONS .TP .BR \-V Write the library version number to the standard output, and exit. .TP .BR \-q Be quiet. .TP .BR \-c Compact while copying. Only current data pages will be copied; freed or unused pages will be omitted from the copy. This option will slow down the backup process as it is more CPU-intensive. Currently it fails if the environment has suffered a page leak. .TP .BR \-d Alters geometry to enforce the copy to be a dynamic size DB, which could be growth and shrink by reasonable steps on the fly. .TP .BR \-p Use read transaction parking/ousting during copying MVCC-snapshot. This allows the writing transaction to oust the read transaction used to copy the database if copying takes so long that it will interfere with the recycling old MVCC snapshots and may lead to an overflow of the database. However, if the reading transaction is ousted the copy will be aborted until successful completion. Thus, this option allows copy the database without interfering with write transactions and a threat of database overflow, but at the cost that copying will be aborted to prevent such conditions. .TP .BR \-u Warms up the DB before copying via notifying OS kernel of subsequent access to the database pages. .TP .BR \-U Warms up the DB before copying, notifying the OS kernel of subsequent access to the database pages, then forcibly loads ones by sequential access and tries to lock database pages in memory. .TP .BR \-n Open MDBX environment(s) which do not use subdirectories. This is legacy option. For now MDBX handles this automatically. .SH DIAGNOSTICS Exit status is zero if no errors occur. Errors result in a non-zero exit status and a diagnostic message being written to standard error. .SH CAVEATS This utility can trigger significant file size growth if run in parallel with write transactions, because pages which they free during copying cannot be reused until the copy is done. .SH "SEE ALSO" .BR mdbx_dump (1), .BR mdbx_chk (1), .BR mdbx_stat (1), .BR mdbx_load (1) .BR mdbx_drop (1) .SH AUTHOR Howard Chu of Symas Corporation , Leonid Yuriev