Replication Example: 2-node Bi-directional Topology
Introduction
The following Guide demonstrates the Virtuoso RDF Bi-directional Graph Replication, e.g.,
data:image/s3,"s3://crabby-images/c2b09/c2b09d944bf42e9452714be1142abbaf672d593d" alt=""
Prerequisites
Database INI Parameters
Suppose there are 2 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
...
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 db1 and db2 with names db1 and db2 respectively.
Install Conductor package
On each of the 2 Virtuoso instances install the conductor_dav.vad package.
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/85cef/85cefdfe6ad0bafba6228e1087cf0bd5b39c5ea7" alt=""
- Click Enable RDF Publishing
- As result publication with the name RDF Publication should be created
data:image/s3,"s3://crabby-images/14459/14459c46b39ebcad17f070fc0337a2061dfd3e8a" alt=""
- Click the link which is the publication name.
- You will be shown the publication items page
data:image/s3,"s3://crabby-images/db7b9/db7b923f2c543a3a65cd4491ee40639178503882" alt=""
- Enter for Graph IRI:
http://example.org
data:image/s3,"s3://crabby-images/c755d/c755d5a8ac286e1217f0902d28d5a80ae392b0b6" 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/e58b9/e58b90e7e578eba4197fe77a8a59bf01620df56f" alt=""
Create subscription from db1 to db2's Publication
- Log in at http://localhost:8891/conductor
- Go to Replication -> Transactional -> Subscriptions
data:image/s3,"s3://crabby-images/b6d6b/b6d6bd76501dd57c2e5742378c60021ca90b0d2d" alt=""
- Click New Subscription
data:image/s3,"s3://crabby-images/ae044/ae044f2dc79cbc39b75324bc72d66289665ccae7" alt=""
- From the list of "Specify new data source" select Data Source db2
data:image/s3,"s3://crabby-images/642ed/642ede29c57e75b35d1b1de881388a326e66b8d0" alt=""
- Enter for db2 dba user credentials
data:image/s3,"s3://crabby-images/129cb/129cbf26371e8a2931ccc63f870ecbed61d57515" alt=""
- Click "Add Data Source"
- As result db2 will be shown in the "Connected Data Sources" list.
data:image/s3,"s3://crabby-images/6cca5/6cca577ad02337072e0e6a6c89117d88686eeac0" alt=""
- Select db2 the "Connected Data Sources" list and click "Publications list"
data:image/s3,"s3://crabby-images/b0aff/b0aff8e4981ad60c5f4793db14f933dbcc726a7b" 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/2f8b9/2f8b97ba1daeb319750e1399d31846e59b0bc6ad" alt=""
- As result will be shown the "Confirm subscription" page.
data:image/s3,"s3://crabby-images/f1788/f1788d772d7b84816afa335331b68b16a8d8a7ae" 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/3467b/3467bf3d236365a9ef4d3e147c6266252729869a" alt=""
- Click "Subscribe"
- The subscription will be created.
data:image/s3,"s3://crabby-images/98eba/98eba226be9029a1dd82ecf8b03bca7597212cf2" alt=""
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/5867a/5867a9ed7fa02a8fb7fdd54b4939023571f2e646" alt=""
- Click Enable RDF Publishing
- As result publication with the name RDF Publication should be created
data:image/s3,"s3://crabby-images/918d9/918d991b2bd3f05a5f77978611a83865a7784074" alt=""
- Click the link which is the publication name.
- You will be shown the publication items page
data:image/s3,"s3://crabby-images/76943/76943a1dc417bb80362258408aea393d375730c2" alt=""
- Enter for Graph IRI:
http://example.org
data:image/s3,"s3://crabby-images/a2523/a252393067a1f2d680aba1fd75afd9ecee871830" 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/6aade/6aade079e5a2f82f51f71ce82e39736cadda0e5e" 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/69509/695092e00fe46f6e5948cee71e1d52f480e78518" alt=""
- Click New Subscription
data:image/s3,"s3://crabby-images/b51f8/b51f857191ef327c095313aa069dbd79a3365387" alt=""
- From the list of "Specify new data source" select Data Source db1
data:image/s3,"s3://crabby-images/9f8de/9f8ded5b788ecf5797d0c52feac840c24551956e" alt=""
- Enter for db1 dba user credentials
data:image/s3,"s3://crabby-images/3e965/3e965e13a547de283722631a0f70fe5e1bc18dce" alt=""
- Click "Add Data Source"
data:image/s3,"s3://crabby-images/bbabf/bbabf8bf36d8f4914f1b9a1f60c755e2481cfc91" alt=""
- As result db1 will be shown in the "Connected Data Sources" list.
Select it and click "Publications list"
data:image/s3,"s3://crabby-images/55bd9/55bd947871c16b3ebb46d2c630b53fc0fdc372e7" 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/0a9ac/0a9acb10a69b87683b79d5349112ef6d4c2fff9b" alt=""
- As result will be shown the "Confirm subscription" page.
data:image/s3,"s3://crabby-images/92084/92084ed549859e8e00000c69fad3432debb717fd" 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/040b0/040b07b27985296ce659fffb9077a78f69a3d5f5" alt=""
- Click "Subscribe"
- The subscription will be created.
data:image/s3,"s3://crabby-images/f43c4/f43c4a8b8dd5d3143b3ac3e531207efdce4d6fdc" alt=""
Insert Data into a Named Graph on the db2 Virtuoso Instance
- Log in at http://localhost:8892/conductor
- Go to Linked Data -> Quad Store Upload
data:image/s3,"s3://crabby-images/ca86b/ca86b6b668fdaf8a39bb46c2ad5a20fc49c7e2c7" 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/9b2ad/9b2ad44173cb51d0f9378ddb207dd3bc42aa4b46" alt=""
- Click Upload
- A successful upload will result in a shown message.
data:image/s3,"s3://crabby-images/2e8cf/2e8cf23505323922f3c635890f21b515bf14f6d0" alt=""
- Check the count of the inserted triples by executing a query like the following against the SPARQL endpoint, http://localhost:8892/sparql:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
data:image/s3,"s3://crabby-images/994d1/994d1918b8fbbc117560481cd82e22d0f0331280" alt=""
- Should return 57 as total.
data:image/s3,"s3://crabby-images/aa922/aa9224e240c9a795b9fbd85acf44e86c6f08da0c" alt=""
Check data on the Destination instance db1
- To check the starting count, execute from db1's SPARQL Endpoint:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
- Should return 57 as total.
data:image/s3,"s3://crabby-images/aa922/aa9224e240c9a795b9fbd85acf44e86c6f08da0c" alt=""
Add new data on db2
- Disconnect db1.
- On the Host Virtuoso Instance db2 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>
} ;
data:image/s3,"s3://crabby-images/de923/de9232fcac8afde4fd3a1de3510e7e0c2cada013" alt=""
- Click "Execute"
- As result the triples will be inserted
data:image/s3,"s3://crabby-images/82c8c/82c8cab63f75e19ea866407bf439df738e89a193" alt=""
- Check the count of the destination instance graph's triples by executing the following query like against the SPARQL endpoint, http://localhost:8892/sparql:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
- Should return 58 as total.
data:image/s3,"s3://crabby-images/2ba76/2ba767bbbf0923729e8d5dc14d8dc7b3b5a8907a" alt=""
Check data on the Destination instance db1
- Start instance db1
- To confirm that the triple count has increased by the number of inserted triples, execute the following statement on db1's SPARQL Endpoint:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
- Should return 58 as total.
data:image/s3,"s3://crabby-images/2ba76/2ba767bbbf0923729e8d5dc14d8dc7b3b5a8907a" alt=""
Add new data on db1
- Disconnect db2.
- 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_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/91e8e/91e8efd86d6cdea1d006b1a9b335b6a77550f5bf" alt=""
- Click "Execute"
- As result the triples will be inserted
data:image/s3,"s3://crabby-images/ca67d/ca67dd04b8159230443c53ce7e9db3b04b0fd0d9" 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 return 60 as total.
data:image/s3,"s3://crabby-images/8ce9c/8ce9c7cba8c14ac056d3db09991e641bed6f8af4" alt=""
Check data on the Destination instance db2
- Start instance db2
- To confirm that the triple count has increased by the number of inserted triples, execute the following statement on db2's SPARQL Endpoint:
SELECT COUNT(*)
FROM <http://example.org>
WHERE { ?s ?p ?o }
- Should return 60 as total.
data:image/s3,"s3://crabby-images/8ce9c/8ce9c7cba8c14ac056d3db09991e641bed6f8af4" alt=""
Related