Replication Example: Chain Topology
Introduction
The following How-To walks you through setting up Virtuoso RDF Graph Replication in a Chain Topology.
data:image/s3,"s3://crabby-images/e1b7d/e1b7d8dbf4f955f62df65308c110b5cc1f75e814" alt=""
Prerequisites
Database INI Parameters
Suppose there are 3 Virtuoso instances respectively with the following ini parameters values:
- virtuoso1.ini:
...
[Database]
DatabaseFile = virtuoso1.db
TransactionFile = virtuoso1.trx
ErrorLogFile = virtuoso1.log
...
[Parameters]
ServerPort = 1111
SchedulerInterval = 1
...
[HTTPServer]
ServerPort = 8891
...
[URIQA]
DefaultHost = localhost:8891
...
[Replication]
ServerName = db1
...
- virtuoso2.ini:
...
[Database]
DatabaseFile = virtuoso2.db
TransactionFile = virtuoso2.trx
ErrorLogFile = virtuoso2.log
...
[Parameters]
ServerPort = 1112
SchedulerInterval = 1
...
[HTTPServer]
ServerPort = 8892
...
[URIQA]
DefaultHost = localhost:8892
...
[Replication]
ServerName = db2
...
- virtuoso3.ini:
...
[Database]
DatabaseFile = virtuoso3.db
TransactionFile = virtuoso3.trx
ErrorLogFile = virtuoso3.log
...
[Parameters]
ServerPort = 1113
SchedulerInterval = 1
...
[HTTPServer]
ServerPort = 8893
...
[URIQA]
DefaultHost = localhost:8893
...
[Replication]
ServerName = db3
...
Database DSNs
Use the ODBC Administrator on your Virtuoso host (e.g., on Windows, Start menu -> Control Panel -> Administrative Tools -> Data Sources (ODBC); on Mac OS X, /Applications/Utilities/OpenLink ODBC Administrator.app
) to create a System DSN for each of db1, db2, db3, with names db1, db2 and db3, respectively.
Install Conductor package
On each of the 3 Virtuoso instances install the conductor_dav.vad package.
Create Publication on db1
- Go to http://localhost:8891/conductor and log in as dba
- Go to Conductor -> Replication -> Transactional -> Publications
data:image/s3,"s3://crabby-images/f1e35/f1e35976f2cec30d46b0b9e6e5c0a8ae52ed2747" alt=""
- Click Enable RDF Publishing
- As result publication with the name RDF Publication should be created
data:image/s3,"s3://crabby-images/0ba8c/0ba8caaa9fee0ace4edb5f43abf5ec88140e68fd" alt=""
- Click the link which is the publication name.
- The publication items page will be shown:
data:image/s3,"s3://crabby-images/4c9a6/4c9a6404e0d1148c08a7fc0db7812d3899ef6145" alt=""
- Enter for Graph IRI:
http://example.org
data:image/s3,"s3://crabby-images/97f07/97f079dba7991def0fadf53a6463192416794720" alt=""
- Click Add New
- The item will be created and shown in the list of items for the currently viewed publication.
data:image/s3,"s3://crabby-images/22b57/22b5708181b1902c54e1029b4343151cd242aa9c" alt=""
Create subscription from db2 to db1's Publication
- Log in at http://localhost:8892/conductor.
- Go to Replication -> Transactional -> Subscriptions:
data:image/s3,"s3://crabby-images/1fdff/1fdff7d16a492f61384530a4be44e18dc9892e9e" alt=""
- Click New Subscription:
data:image/s3,"s3://crabby-images/d55aa/d55aa1360b3071b9382966031bd23f42f45feb8f" alt=""
- From the list of "Specify new data source" select Data Source db1:
data:image/s3,"s3://crabby-images/6ebf9/6ebf98a66e84629d3aa003fe1612eda917b0ccbc" alt=""
- Enter for db1 dba user credentials:
data:image/s3,"s3://crabby-images/4114c/4114c84124b4ed6796b22fa620957529aa157df9" alt=""
- Click "Add Data Source":
- As result db1 will be shown in the "Connected Data Sources" list.
data:image/s3,"s3://crabby-images/bb3e3/bb3e355e31609a081db694f1dd3be1ddb58d3b5a" alt=""
- Click "Publications list":
data:image/s3,"s3://crabby-images/d239f/d239ff7aa426413d8857882a8799fc9e7b0dc615" alt=""
- As result will be shown the list of available publications for the selected data source.
Select the one with name "RDF Publication" and click "List Items".
data:image/s3,"s3://crabby-images/2742a/2742a9603c3b435539f3e1c323ee064329644c4a" alt=""
- As result will be shown the "Confirm subscription" page.
data:image/s3,"s3://crabby-images/57351/57351f2cabb17d4235105ee1c9cabbb6d53637c8" alt=""
- The sync interval by default is 10 minutes.
For the testing purposes, we will change it to 1 minute.
data:image/s3,"s3://crabby-images/71e91/71e916650227a603de524aa64530783da42d0b14" alt=""
- Click "Subscribe".
- The subscription will be created.
data:image/s3,"s3://crabby-images/7ea2c/7ea2c4e8292f2c4745131dc3dacab111d1cdd81b" alt=""
Create Publication on db2
- Go to http://localhost:8892/conductor and log in as dba,
- Go to Conductor -> Replication -> Transactional -> Publications:
data:image/s3,"s3://crabby-images/682a5/682a5accad984cc2cc1980615b72b18c07755afc" alt=""
- Click Enable RDF Publishing:
- As result publication with the name RDF Publication should be created:
data:image/s3,"s3://crabby-images/6c873/6c873e59e7e30a85d68a11d10659603de78e3128" alt=""
- Click the link which is the publication name.
- The publication items page will be shown:
data:image/s3,"s3://crabby-images/f8114/f81145ad7b7e96af47309c58bb6db479bf1aed0e" alt=""
- Enter for Graph IRI:
http://example.org
data:image/s3,"s3://crabby-images/e5c0b/e5c0bf9e9fec704dd67d03417c6c0dce48e54f40" alt=""
- Click Add New.
- The item will be created and shown in the list of items for the currently viewed publication.
data:image/s3,"s3://crabby-images/ece59/ece59cede937bb1fa53f119925815635c3ccad86" alt=""
Create subscription from db3 to db2's Publication
- Log in at http://localhost:8893/conductor.
- Go to Replication -> Transactional -> Subscriptions:
data:image/s3,"s3://crabby-images/37a06/37a0656a17817ed87ab2a3e12c13d99bf66afcef" alt=""
- Click New Subscription:
data:image/s3,"s3://crabby-images/6ba14/6ba14995e277a2c325ba1e6f2637a983544f69fd" alt=""
- From the list of "Specify new data source" select Data Source db2:
data:image/s3,"s3://crabby-images/51132/51132d90641f4d932e6d8f431fca45ce2f6279fa" alt=""
- Enter for db2 dba user credentials:
data:image/s3,"s3://crabby-images/59e20/59e202fa3beac875bcb9505ae4d791d168abf72b" alt=""
- Click "Add Data Source":
data:image/s3,"s3://crabby-images/d4fdf/d4fdf4ade780aba0372cc9b97438e421a2b5d521" alt=""
- As result db2 will be shown in the "Connected Data Sources" list.
Select it and click "Publications list":
data:image/s3,"s3://crabby-images/d51a8/d51a892a904652db94d5c083ecc22b6405373654" alt=""
- As result will be shown the list of available publications for the selected data source.
Select the one with name "RDF Publication" and click "List Items".
data:image/s3,"s3://crabby-images/e1eea/e1eeae53dd125cd94bd7633b9e2b7eb4884d5c55" alt=""
- As result will be shown the "Confirm subscription" page.
data:image/s3,"s3://crabby-images/b3c3f/b3c3f43fa24a3f6fbc77e48dae2ece62860114ce" alt=""
- The sync interval by default is 10 minutes.
For the testing purposes, we will change it to 1 minute.
data:image/s3,"s3://crabby-images/7920d/7920ddebc9275c7aa877c78c363e8d29958f708c" alt=""
- Click "Subscribe".
- The subscription will be created.
data:image/s3,"s3://crabby-images/caadd/caadde2a6f73023565f4a2e34672ebc80d03b8f1" alt=""
Insert Data into a Named Graph on the db1 Virtuoso Instance
- Log in at http://localhost:8891/conductor.
- Go to Linked Data-> Quad Store Upload:
data:image/s3,"s3://crabby-images/e5a89/e5a899ec1c59be4e4c5c9a54dbbb9ef3457cafa0" alt=""
- In the shown form:
- Tick the box for Resource URL and enter your resource URL, e.g.:
http://www.openlinksw.com/dataspace/person/kidehen@openlinksw.com#this
- Enter for Named Graph IRI:
http://example.org
data:image/s3,"s3://crabby-images/10495/1049512efdc8411b88a04e9d6ae806aa672cb03f" alt=""
- Click Upload.
- Should be shown message for successful upload:
data:image/s3,"s3://crabby-images/c6779/c67794f40312a834a0683df8457d003334fa8aaf" alt=""
- Check the count of the inserted triples by executing a query like the following against the SPARQL endpoint, http://localhost:8891/sparql:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
data:image/s3,"s3://crabby-images/61e99/61e9934e8992109927c6c55a1a495d600db229ff" alt=""
- Should be shown 57 as total.
data:image/s3,"s3://crabby-images/b1f8f/b1f8f20abb69c0b6abdb47572790a44fae6697f7" alt=""
Check data on the Destination instances db2 and db3
- To check the starting count, on each of the Destination Virtuoso Instances db2 and db3 from SPARQL Endpoint execute:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
- Should return 57 as total.
data:image/s3,"s3://crabby-images/b1f8f/b1f8f20abb69c0b6abdb47572790a44fae6697f7" alt=""
Add new data on db1
- Disconnect db2 and db3.
- On the Host Virtuoso Instance db1 go to Conductor -> Database -> Interactive SQL enter the following statement:
SPARQL INSERT INTO GRAPH <http://example.org>
{
<http://www.openlinksw.com/dataspace/person/kidehen@openlinksw.com#this>
<http://xmlns.com/foaf/0.1/interest>
<http://dbpedia.org/resource/Web_Services>
} ;
SPARQL INSERT INTO GRAPH <http://example.org>
{
<http://www.openlinksw.com/dataspace/person/kidehen@openlinksw.com#this>
<http://xmlns.com/foaf/0.1/interest>
<http://dbpedia.org/resource/Web_Clients>
} ;
SPARQL INSERT INTO GRAPH <http://example.org>
{
<http://www.openlinksw.com/dataspace/person/kidehen@openlinksw.com#this>
<http://xmlns.com/foaf/0.1/interest>
<http://dbpedia.org/resource/SPARQL>
} ;
data:image/s3,"s3://crabby-images/be126/be1264bef1a8bd1a0532d3a159d02330bb21f48e" alt=""
- Click "Execute".
- As result the triples will be inserted:
data:image/s3,"s3://crabby-images/6ed03/6ed030e92d3d92225e83357e83195cfe76c21c2e" alt=""
- Check the count of the destination instance graph's triples by executing the following query like against the SPARQL endpoint, http://localhost:8891/sparql:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
- Should be shown 60 as total.
data:image/s3,"s3://crabby-images/fbcf8/fbcf8f47bd6b83e02d4185dab424f68725240442" alt=""
Check again data on the Destination instances db2 and db3
- Start instances db2 and db3.
- To confirm that the triple count has increased by the number of inserted triples, execute the following on the Destination Virtuoso Instance db2 and db3 SPARQL Endpoint:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
- Should be shown 60 as total:
data:image/s3,"s3://crabby-images/fbcf8/fbcf8f47bd6b83e02d4185dab424f68725240442" alt=""
Related