Warning: These documents are under active 
      development and subject to change (version 2.1.0-beta).
      The latest release documents are at:
      https://purl.dataone.org/architecture
      
| Author: | Dave Vieglas | 
|---|
This document contains notes about replication that may be of some use in DataONE.
- Reduce complex transactions to be written by a single server
- Monitor the server log
- Be prepared for failure. The more data is distributed and scaled, the more likely failure will be encountered.
CNs need to keep a copy of all science metadata, and it is expected that each CN will be replicated with the others, so that each will appear the same.
There will be three CNs to start with.
There’s basically three models for dealing with replication in this case:
- single master, two slaves
- ring - write one, it writes to the next, and so on
- multi-master. Write to any, replication to others
Multi-master replication would be the ideal option, as each CN would then offer identical functionality rather than the alternative of redirecting (presumably) 2/3 of requests to the master node.
There are basically two categories of information that are replicated:
- science metadata, which is information about a data set
- system metadata, which is information that is used to keep track of things such as the science metadata, MN capabilities and state, perhaps groups and access control lists, identity mappings
Replication of data is achieved by copying content between Member Nodes until sufficient copies have been made to address concerns of access (x% of MNs may be offline and the content can still be reached) and efficiency of access (Internet distance between client and the MN).
The CN object store (CN-OS) is responsible for holding a copy of all science and system metadata, enabling retrieval of objects by an identifier and for ensuring that the local copy is synchronized with the other CNs. The CN-OS is analogous to a replicated dictionary with the identifiers being keys and the science or system metadata documents being the values.
The CN-OS should support operations:
Metacat is a flexible metadata database that utilizes XML as a common syntax for representing various types of metadata. In general, Metacat can be considered functionally equivalent to an XML database.
Metacat supports replication of documents between instances, with replication being triggered by several events:
With Metacat filling the role of the Coordinating Node Object Store, each CN Metacat instance would replicate with the other instances on the CNs. The configuration for DataONE CNs would be something like:
| host | server | replicate | datareplicate | hub | 
|---|---|---|---|---|
| cn1 | localhost | 0 | 0 | 1 | 
| . | cn2 | 1 | 0 | 1 | 
| . | cn3 | 1 | 0 | 1 | 
| cn2 | localhost | 0 | 0 | 1 | 
| . | cn1 | 1 | 0 | 1 | 
| . | cn3 | 1 | 0 | 1 | 
| cn3 | localhost | 0 | 0 | 1 | 
| . | cn1 | 1 | 0 | 1 | 
| . | cn2 | 1 | 0 | 1 | 
Apache Zookeeper can be used as a distributed lock manager to assist with synchronization of records, especially across the CNs. Zookeeper is interesting because it can potentially scale to many more than three CNs.
In this case we would create a globally synchronous lock on a specific PID (essentially the same as the Lock operation of Metacat). The basic procedure is described in the Zookeeper recipes.
For example, hazelcast. These types of solutions are typically developed with LAN clusters in mind, and may run into problems with higher latency networks. Interesting product though.
These notes describe a strategy of utilizing the Linux file system and a distributed version control system (DVC) such as Git or Mercurial as the science and system metadata store for the Coordinating Nodes.
The basic approach is to treat all primary instances of science and system metadata as files that are stored on the Linux file system. The files are located in one or more folders that are under revision control using the DVC. As a new metadata file is added to a CN, it is replicated to the other CNs on a scheduled basis (e.g. every 10 minutes or when n files have been changed or added). Change notification hooks (e.g. commit scripts) are used to update local databases that are used to search science metadata (e.g. the Mercury index) or the local system metadata database.