What

Create a Virtuoso RDF Graph Replication slave Subscriber node from a master Publisher node.

Why

If the master Publisher node is known to contain the current state of the database, Subscriber nodes can be created from a copy of it such that they start from this known good state and keep in sync from that point forward. This could be in the cases of a subscriber failing and needing to be rebuilt or if a new Subscriber node needs to be added the Farm (note this could also be done from a copy of a subscriber node if know to be in sync with the master Publisher).

How

  1. Stop/disable all updates to the publisher so its state remains constant when setting up the new subscriber(s)

  2. Run a checkpoint to commit any pending updates in the trx file to the database (db) file

  3. On each subscriber node if database files already exist then remove the following to ensure no remnants of the older subscriber node database exists:

    rm virtuoso.db virtuoso.trx virtuoso.log virtuoso.pxa

  4. Copy the publisher database file "virtuoso.db" to the subscriber node(s) using rsync or prefer copy method

  5. Start the copy of the publisher database and do the following to remove the information store in the database of it being a publisher:

    delete from sys_repl_accounts; delete from sys_repl_subscribers; registry_remove ('DB.DBA.RDF_REPL'); shutdown();

  6. Restart the database with virtuoso-start.sh and run the following command to set it up as a subscriber node:

    repl_server ('MASTER', 'MASTER_DSN'); repl_subscribe ('MASTER', '__rdf_repl', 'dav', 'dav', 'dba', 'dba'); shutdown();

  7. Restart the database again with virtuoso-start.sh and run the following command to continue setting it up as a subscriber node

    repl_sync_all (); DB.DBA.SUB_SCHEDULE ('MASTER', '__rdf_repl', 1);

  8. Run the following status commands to check it is in sync with the MASTER publisher:

    status(); repl_stat();

Trouble Shooting

There maybe occasions when Subscriber nodes are failing to sync with the master Publisher with errors of the following form being reported:

Thus the replication level on the master Publisher needs to be verified and the Subscriber set to be one less than it using the database sequence_set() function as follows:

  1. On the publisher determine the replication server name with the following command:

    SQL> select repl_this_server(); repl_this_server VARCHAR _______________________________________________________________________________ MASTER 1 Rows. -- 1 msec. SQL>

  2. On the publisher determine the "internal" replication server name to pass to the set_sequence function with the command:

    SQL> select concat ('repl_', repl_this_server(), '_', '__rdf_repl'); concat VARCHAR _______________________________________________________________________________ repl_MASTER___rdf_repl 1 Rows. -- 1 msec. SQL>

  3. Check the publisher replication level with the command:

    SQL> select sequence_set ('repl_MASTER___rdf_repl', 0, 2); sequence_set VARCHAR _______________________________________________________________________________ 1685 1 Rows. -- 0 msec. SQL>

  4. Switch to the subscriber and check the publisher replication level store:

    SQL> select sequence_set ('repl_MASTER___rdf_repl', 0, 2); sequence_set VARCHAR _______________________________________________________________________________ 939 1 Rows. -- 0 msec. SQL>

  5. Set the publisher replication level on the subscriber to be one less than its level on the publisher itself with command:

    SQL> sequence_set ('repl_MASTER___rdf_repl', 1684, 0); Done. -- 0 msec. SQL>

  6. Check the publisher replication level on the subscriber is one less than on the publisher:

    SQL> select sequence_set ('repl_MASTER___rdf_repl', 0, 2); sequence_set VARCHAR _______________________________________________________________________________ 1684 1 Rows. -- 0 msec. SQL>

  7. Back on the master Publisher, check Subscriber replication status is valid by ensuring its RS_VALID column of the SYS_REPL_SUBSCRIBERS table is set "1" and the RS_LEVEL column is set to one less than the replication level of the subscriber:

    SQL> select * from SYS_REPL_SUBSCRIBERS; RS_SERVER RS_ACCOUNT RS_SUBSCRIBER RS_LEVEL RS_VALID VARCHAR NOT NULL VARCHAR NOT NULL VARCHAR NOT NULL INTEGER INTEGER _______________________________________________________________________________ MASTER __rdf_repl SLAVE-1 939 0 1 Rows. -- 49 msec. SQL>

  8. If as above the RS_VALID is "0" then set it to "1" and set the RS_LEVEL column to one less than the replication level of the master Publisher as follows to activate replication from the slave subscriber node:

    SQL> update SYS_REPL_SUBSCRIBERS set RS_LEVEL = 1684 , RS_VALID = 1 ; 0 Rows. -- 2 msec. SQL> SQL> select * from SYS_REPL_SUBSCRIBERS; RS_SERVER RS_ACCOUNT RS_SUBSCRIBER RS_LEVEL RS_VALID VARCHAR NOT NULL VARCHAR NOT NULL VARCHAR NOT NULL INTEGER INTEGER _______________________________________________________________________________ MASTER __rdf_repl SLAVE-1 1684 1 1 Rows. -- 49 msec. SQL>

  9. Then restart master Publisher and the subscriber for the settings to take effect, and run the following on each subscriber to force them to sync:

    repl_sync_all ();

  10. Finally check the Subscriber node(s) is now IN SYNC and that there are no occurrences of the __rdf_repl' is not valid ... errors in the master Publisher database log.