Move from a standalone deployment to a cluster
It is possible to move from a standalone deployment with a single system
database to a cluster with multiple system
primaries.
In essence, this is done by dumping the system
database from the standalone server and loading it into the other servers that are to form the cluster.
The following example shows how to move from a standalone server with a single system
primary to a cluster with three system
primaries.
Another deployment with a single |
system
database to a cluster with three system
primariesIn this example, a standalone server named server01
is running and two additional servers, server02
and server03
, are to be added to form a cluster.
The two additional servers are configured according to Configure a cluster with three servers and are not running.
Neo4j Enterprise Edition is installed on all three servers.
Start by stopping the standalone server and once it is stopped, edit the neo4j.conf file to include the discovery endpoints of itself and the servers that will form the cluster.
server.default_listen_address=0.0.0.0
server.default_advertised_address=server01.example.com
dbms.cluster.discovery.endpoints=server01.example.com:5000,server02.example.com:5000,server03.example.com:5000
initial.dbms.default_primaries_count=3
(The neo4j.conf file looks identical except for the server.default_advertised_address
on all three servers. Please refer to Configure a cluster with three servers for more information.)
On server01
(the standalone server) dump the system
database using the neo4j-admin database dump
command.
bin/neo4j-admin database dump system --to-path=/full/path/to/dumps/
See Back up an offline database for more information on the dump command.
Use the neo4j-admin database load
command to load the system
database dump from server01
to server02
and server03
.
bin/neo4j-admin database load --from-path=/full-path/data/dumps system
See Restore a database dump for more information on the load command.
Once the system
database has been loaded on server02
and server03
, start all servers.
The newly added servers should be in the Free
state (server02
and server03
) and this can be verified using SHOW SERVERS
.
SHOW SERVERS;
+-----------------------------------------------------------------------------------------------------------+ | name | address | state | health | hosting | +-----------------------------------------------------------------------------------------------------------+ | "d6fbe54b-0c6a-4959-9bcb-dcbbe80262a4" | "server01:7687" | "Enabled" | "Available" | ["system", "neo4j"] | | "e56b49ea-243f-11ed-861d-0242ac120002" | "server02:7687" | "Free" | "Available" | ["system"] | | "73e9a990-0a97-4a09-91e9-622bf0b239a4" | "server03:7687" | "Free" | "Available" | ["system"] | +-----------------------------------------------------------------------------------------------------------+
On server01
(the previously standalone server) verify that all user databases are still running using SHOW DATABASES
.
The last step is to enable the Free
servers using ENABLE SERVER
(see Managing servers in a cluster for more information on server states).
Once all servers are enabled, you can scale up user databases using ALTER DATABASE
, if desired.
In this example, a standalone server named server01
is running and two additional servers, server02
and server03
, are to be added to form a cluster.
The two additional servers are configured according to Configure a cluster with three servers and are not running.
Neo4j Enterprise Edition is installed on all three servers.
Start by stopping the standalone server. Once it is stopped, edit the neo4j.conf file to include the discovery endpoints of itself and the servers that will form the cluster.
Starting with Neo4j 5.23, it is recommended to use v2 of the discovery service. For more details on discovery services, see Cluster server discovery.
To use the discovery service v2:
-
You have to set the configuration of
dbms.cluster.discovery.version
toV2_ONLY
. -
Instead of
dbms.cluster.discovery.endpoints
, usedbms.cluster.discovery.v2.endpoints
.
The example below uses dbms.cluster.discovery.resolver_type=LIST
.
server.default_listen_address=0.0.0.0
server.default_advertised_address=server01.example.com
dbms.cluster.discovery.v2.endpoints=server01.example.com:6000,server02.example.com:6000,server03.example.com:6000
dbms.cluster.discovery.version=V2_ONLY
initial.dbms.default_primaries_count=3
(The neo4j.conf file looks identical except for the server.default_advertised_address
on all three servers. Please refer to Configure a cluster with three servers for more information.)
On server01
(the standalone server) dump the system
database using the neo4j-admin database dump
command.
bin/neo4j-admin database dump system --to-path=/full/path/to/dumps/
See Back up an offline database for more information on the dump command.
Use the neo4j-admin database load
command to load the system
database dump from server01
to server02
and server03
.
bin/neo4j-admin database load --from-path=/full-path/data/dumps system
See Restore a database dump for more information on the load command.
Once the system
database has been loaded on server02
and server03
, start all servers.
The newly added servers should be in the Free
state (server02
and server03
) and this can be verified using SHOW SERVERS
.
SHOW SERVERS;
+-----------------------------------------------------------------------------------------------------------+ | name | address | state | health | hosting | +-----------------------------------------------------------------------------------------------------------+ | "d6fbe54b-0c6a-4959-9bcb-dcbbe80262a4" | "server01:7687" | "Enabled" | "Available" | ["system", "neo4j"] | | "e56b49ea-243f-11ed-861d-0242ac120002" | "server02:7687" | "Free" | "Available" | ["system"] | | "73e9a990-0a97-4a09-91e9-622bf0b239a4" | "server03:7687" | "Free" | "Available" | ["system"] | +-----------------------------------------------------------------------------------------------------------+
On server01
(the previously standalone server) verify that all user databases are still running using SHOW DATABASES
.
The last step is to enable the Free
servers using ENABLE SERVER
(see Managing servers in a cluster for more information on server states).
Once all servers are enabled, you can scale up user databases using ALTER DATABASE
, if desired.