Tables are replicated when the table is designated as replicating and there is subscription between the nodes.
Tables designated as replicating by default, but can be changed by setting replicate
to false
in the table definition:
type Product @table(replicate: false) {
id: ID!
name: String!
}
Or in your harperdb-config.yaml, you can set the default replication behavior for databases, and indicate which databases should be replicated by default:
replication:
databases: data
If a table is not in the list of databases to be replicated, it will not be replicated unless the table is specifically set to replicate:
type Product @table(replicate: true) {
id: ID!
name: String!
}
Reading hdb_nodes (what we do to the node, not what the node does).
The subscription can be set to publish, subscribe, or both.
Subscriptions can be added, updated, or removed through the API.
Note: The databases and tables in the subscription must exist on either the local or the remote node. Any databases or tables that do not exist on one particular node, for example, the local node, will be automatically created on the local node.
To add a single node and create one or more subscriptions use set_node_replication
.
{
"operation": "set_node_replication",
"node_name": "Node2",
"subscriptions": [
{
"database": "data",
"table": "dog",
"publish": false,
"subscribe": true
},
{
"database": "data",
"table": "chicken",
"publish": true,
"subscribe": true
}
]
}
This is an example of adding Node2 to your local node. Subscriptions are created for two tables, dog and chicken.
To update one or more subscriptions with a single node you can also use set_node_replication
, however this will behave as a PATCH/upsert, where only the subscription(s) changing will be inserted/update while the others will be left untouched.
{
"operation": "set_node_replication",
"node_name": "Node2",
"subscriptions": [
{
"schema": "dev",
"table": "dog",
"publish": true,
"subscribe": true
}
]
}
This call will update the subscription with the dog table. Any other subscriptions with Node2 will not change.
To add or update subscriptions with one or more nodes in one API call use configure_cluster
.
{
"operation": "configure_cluster",
"connections": [
{
"node_name": "Node2",
"subscriptions": [
{
"database": "dev",
"table": "chicken",
"publish": false,
"subscribe": true
},
{
"database": "prod",
"table": "dog",
"publish": true,
"subscribe": true
}
]
},
{
"node_name": "Node3",
"subscriptions": [
{
"database": "dev",
"table": "chicken",
"publish": true,
"subscribe": false
}
]
}
]
}
Note: configure_cluster
will override any and all existing subscriptions defined on the local node. This means that before going through the connections in the request and adding the subscriptions, it will first go through all existing subscriptions the local node has and remove them. To get all existing subscriptions use cluster_status
.
There is an optional property called start_time
that can be passed in the subscription. This property accepts an ISO formatted UTC date.
start_time
can be used to set from what time you would like to source transactions from a table when creating or updating a subscription.
{
"operation": "set_node_replication",
"node_name": "Node2",
"subscriptions": [
{
"database": "dev",
"table": "dog",
"publish": false,
"subscribe": true,
"start_time": "2022-09-02T20:06:35.993Z"
}
]
}
This example will get all transactions on Node2’s dog table starting from 2022-09-02T20:06:35.993Z
and replicate them locally on the dog table.
If no start time is passed it defaults to the current time.
Note: start time utilizes clustering to back source transactions. For this reason it can only source transactions that occurred when clustering was enabled.
To remove a node and all its subscriptions use remove_node
.
{
"operation":"remove_node",
"node_name":"Node2"
}
To get the status of all connected nodes and see their subscriptions use cluster_status
.
{
"node_name": "Node1",
"is_enabled": true,
"connections": [
{
"node_name": "Node2",
"status": "open",
"ports": {
"clustering": 9932,
"operations_api": 9925
},
"latency_ms": 65,
"uptime": "11m 19s",
"subscriptions": [
{
"schema": "dev",
"table": "dog",
"publish": true,
"subscribe": true
}
],
"system_info": {
"hdb_version": "4.0.0",
"node_version": "16.17.1",
"platform": "linux"
}
}
]
}