Copy a database storeEnterprise Edition
You can use the neo4j-admin database copy command to copy a database, create a compacted/defragmented copy of a database, clean up database inconsistencies, or do a direct migration from Neo4j 4.4 to any 5.x version.
neo4j-admin database copy reclaims the unused space, creates a defragmented copy of the data store, and creates the node label and relationship type lookup indexes.
| Command limitations 
 | 
Command
neo4j-admin database copy copies the data store of an existing offline database to a new database.
Syntax
neo4j-admin database copy [-h] [--copy-schema] [--expand-commands] [--force] [--verbose] [--compact-node-store[=true|false]]
                             [--additional-config=<file>] [--from-pagecache, --max-off-heap-memory=<size>]
                             [--temp-path=<path>] [--to-format=<format>]
                             [--to-path-schema=<path>] [--copy-only-node-properties=<label.property>[,<label.property>...]]...
                             [--copy-only-nodes-with-labels=<label>[,<label>...]]... [--copy-only-relationship-properties=<relationship.
                             property>[,<relationship.property>...]]... [--copy-only-relationships-with-types=<type>[,<type>...]]...
                             [--ignore-nodes-with-labels=<label>[,<label>...]]... [--ignore-relationships-with-types=<type>[,<type>...]]...
                             [--skip-labels=<label>[,<label>...]]... [--skip-node-properties=<label.property>[,<label.property>...]]...
                             [--skip-properties=<property>[,<property>...]]... [--skip-relationship-properties=<relationship.property>[,
                             <relationship.property>...]]... [--from-path-data=<path> --from-path-txn=<path>] [--to-path-data=<path>
                             --to-path-txn=<path>] <fromDatabase> <toDatabase>Description
This command creates a copy of a database.
If your labels, properties, or relationships contain dots or commas, you can use backticks to quote them, e.g. My,label, My.property.
A file named <database-name>-schema.cypher, containing the schema commands needed to recreate indexes/constraints on the copy, will be created.
You can use the --copy-schema option to automatically copy the schema.
Indexes will be built the first time the database is started.
This option can copy the schema from any 4.4 and 5.x version to 5.26 LTS and later versions.
Parameters
| Parameter | Description | 
|---|---|
| 
 | Name of the source database. | 
| 
 | Name of the target database.
If the same as  | 
You can use the same values for <fromDatabase> and <toDatabase> if you do not need an actual copy of the database.
The command will replace the original database with the newly created copy.
Options
The neo4j-admin database copy command has the following options:
| Option | Description | Default | ||
|---|---|---|---|---|
| 
 | Configuration file with additional configuration. | |||
| 
 | By default node store is not compacted on copy since that changes node ids. Please use this option to enforce node store compaction. | 
 | ||
| 
 | A comma-separated list of property keys to include in the copy for nodes with the specified label.
Any labels not explicitly mentioned will have all their properties included in the copy.
Cannot be combined with  | |||
| 
 | A comma-separated list of labels. All nodes that have ANY of the specified labels will be included in the copy.
Cannot be combined with  | |||
| 
 | A comma-separated list of property keys to include in the copy for relationships with the specified type.
Any relationship types not explicitly mentioned will have all their properties included in the copy. Cannot be combined with  | |||
| 
 | A comma-separated list of relationship types.
All relationships with any of the specified types will be included in the copy.
Cannot be combined with  | |||
| 
 | Copy the schema instead of generating schema statements, meaning index and constraint definitions. The indexes will be built the first time the database is started. | |||
| 
 | Allow command expansion in config value evaluation. | |||
| 
 | Force the command to run even if the integrity of the database cannot be verified. | |||
| 
 | Path to the databases directory, containing the database directory to source from. It can be used to target databases outside of the installation. | 
 | ||
| 
 | Path to the transactions directory, containing the transaction directory for the database to source from. | 
 | ||
| 
 | Show this help message and exit. | |||
| 
 | A comma-separated list of labels.
Nodes that have ANY of the specified labels will not be included in the copy.
Cannot be combined with  | |||
| 
 | A comma-separated list of relationship types. Relationships with any of the specified
relationship types will not be included in the copy.
Cannot be combined with  | |||
| 
 | Introduced in 2025.01 Maximum memory that neo4j-admin can use for various data structures and caching to improve performance. Values can be plain numbers, such as 10000000, or 20G for 20 gigabytes. It can also be specified as a percentage of the available memory, for example 70%. | 
 | ||
| 
 | A comma-separated list of labels to ignore. | |||
| 
 | A comma-separated list of property keys to ignore for nodes with the specified label. Cannot be combined with  | |||
| 
 | A comma-separated list of property keys to ignore.
Cannot be combined with  | |||
| 
 | A comma-separated list of property keys to ignore for relationships with the specified
type.
Cannot be combined with  | |||
| 
 | Path to a directory to be used as a staging area when the source and target databases are the same. Default is the current directory. | |||
| 
 | Set the format for the new database.
Must be one of  
 | 
 | ||
| 
 | Path to the databases directory, containing the database directory to target from. | 
 | ||
| 
 | Path to directory to create the schema commands file in. Default is the current directory. | |||
| 
 | Path to the transactions directory containing the transaction directory for the database to target from. | 
 | ||
| 
 | Enable verbose output. | |||
| 
1. See Neo4j Admin and Neo4j CLI → Configuration for details.
 | ||||
| Enterprise Edition The block format is the default format for all newly created databases as long as they do not have the  | 
| Neo4j 2025.01 introduces a dual-named option  The new option determines the maximum amount of off-heap memory available during the copy process for reading and writing, instead of specifying how much cache to allocate when reading the source. For details, see Improving the performance. Note that the  | 
Examples
Copying the data store of a database
You can use neo4j-admin database copy to copy the data store of a database, for example, neo4j.
- 
Stop the database named neo4j:STOP DATABASE neo4j
- 
Copy the data store from neo4jto a new database calleddatabase-copy.If you do not need an actual copy of the database, you can use the same values for <fromDatabase>and<toDatabase>. The command replaces the original database with the newly created copy.You can use the --copy-schemaoption to automatically copy the schema. Indexes will be built the first time the database is started. This option copies the schema from any 4.4 and 5.x version to 5.26 LTS and later versions.For previous versions, you need to manually recreate the schema using the Cyher statements saved in the file <database-name>-schema.cypher. bin/neo4j-admin database copy neo4j database-copy
- 
Verify that the database has been successfully copied: ls -al ../data/databasesCopying a database does not automatically create it. Therefore, it will not be visible if you do SHOW DATABASESat this point.
- 
Create the copied database. CREATE DATABASE database-copy
- 
Verify that the new database is online. SHOW DATABASES
Filtering data while copying a database
You can use neo4j-admin database copy to filter out any unwanted data while copying a database, for example, by removing nodes, labels, properties, and relationships.
bin/neo4j-admin database copy neo4j copy --ignore-nodes-with-labels="Cat,Dog"The command creates a copy of the database neo4j but without the nodes with the labels :Cat and :Dog.
| Labels are processed independently, i.e., the filter ignores any node with a label  | 
| For a detailed example of how to use  | 
Further compacting an existing database
You can use the command neo4j-admin database copy with the argument -compact-node-store to further compact the store of an existing database.
This example uses the same values for <toDatabase> and <fromDatabase>, which means that the command will compact the database in place by creating a new version of the database.
After running the command, you need to recreate the indexes using the generated script.
If the database belongs to a cluster, you also need to reseed the cluster from that server.
For more information, see Designated seeder.
| Note that even though there is only one database copy in the end, you still need double the space during the operation. | 
- 
Stop the database named neo4j:STOP DATABASE neo4j
- 
Compact the neo4jdatabase using the command:bin/neo4j-admin database copy neo4j neo4j --compact-node-store --temp-path=<my-prefered-staging-area>--temp-pathcan be used to specify a different directory to use as a temporary staging area. If omitted, the current working directory will be used.You can use the --copy-schemaoption to automatically copy the schema. Indexes will be built the first time the database is started. This option can copy the schema from any 4.4 and 5.x to 5.26 LTS and later versions.For previous versions, you need to manually recreate the schema using the Cyher statements saved in the file <database-name>-schema.cypher. 
- 
Start the neo4jdatabase. This is the newly created version of the database.START DATABASE neo4j
| For a detailed example of how to reclaim unused space, see Reclaim unused space. | 
Estimating the processing time
Estimations for how long the neo4j-admin database copy command takes can be made based on the following:
- 
Neo4j, like many other databases, does IO in 8K pages. 
- 
Your disc manufacturer will have a value for the maximum IOPS it can process. 
For example, if your disc manufacturer has provided a maximum of 5000 IOPS, you can reasonably expect up to 5000 such page operations a second.
Therefore, the maximal theoretical throughput you can expect is 40MB/s (or 144 GB/hour) on that disc.
You may then assume that the best-case scenario for running neo4j-admin database copy on that 5000 IOPS disc is that it takes at least 1 hour to process a 144 GB database. [2]
However, it is important to remember that the process must read 144 GB from the source database, and must also write to the target store (assuming the target store is of comparable size).
Additionally, there are internal processes during the copy that reads/modifies/writes the store multiple times.
Therefore, with an additional 144 GB of both read and write, the best-case scenario for running neo4j-admin database copy on a 5000 IOPS disc is that it takes at least 3 hours to process a 144 GB database.
Finally, it is also important to consider that in almost all Cloud environments, the published IOPS value may not be the same as the actual value, or be able to continuously maintain the maximum possible IOPS. The real processing time for this example could be well above that estimation of 3 hours.
Improving the performance
You can improve the performance of the copy process by specifying the memory limit.
Neo4j 2025.01 introduces an option --from-pagecache, --max-off-heap-memory=<size> to replace the old --from-pagecache=<size> option.
The new option controls how much off-heap memory the copy process may use in addition to the heap size the JVM is given. Values can be plain numbers, such as 10000000, or 20G for 20 gigabytes. It can also be specified as a percentage of the available memory, for example 70%.
Starting from 2025.01, to configure the off-heap memory value, you can use either the old name --from-pagecache=<size> or the new one --max-off-heap-memory=<size>.
--from-pagecache=<size>bin/neo4j-admin database copy neo4j copy --from-pagecache=95%--max-off-heap-memory=<size>bin/neo4j-admin database copy neo4j copy --max-off-heap-memory=95%MB/s = (IOPS * B) ÷ 10^6, where B is the block size in bytes; in the case of Neo4j, this is 8000. GB/hour can then be calculated from (MB/s * 3600) ÷ 1000.