http://couchdb.apache.org/
Running multiple instance of couchdb:
The following has to be changed in the instance-x.ini:
database_dir = some_location/couchdb-x (data location for the couchdb instance)
view_index_dir = some_location/couchdb-x
.....
[httpd]
port = new-port-no (assume instance1 runs on 5984 and instance2 runs on 5985)
....
[log]
file = some_location/log/couch-x.log
Assuming that both the instances are going to run on the same host. Running first instance of couchdb
couchdb -a some_location/instance1.ini -p instance1.pid
Running second instance of couchdb
couchdb -a some_location/instance2.ini -p instance2.pid
Make sure that both the instance of the database is running using the 'ps -ef | grep couch' command.
Data Replication:
Run the following command to replicate the data between multiple instances (in our case from instance1 to instance2 and the other way).
Replication from instance1 to instance 2
curl -X POST -H "Content-Type: application/json" -d '{"source":"http://localhost:5984/test-db", "target":"test-db", "continuous":true, "doc_ids":["doc1", "doc2"]}' http://localhost:5985/_replicate
Reverse the port no's in the above command (change 5984 to 5985 and viceversa) for the replication from instance 2 to instance1. Optional parameter "continuous":true tells couchdb to replicate continuously whenever there is a change in the db. Leaving this parameter would do the replication once when the command is executed. Couchdb is famous for filtered replication. There are multiple ways to do filtered replication. In the above command the optional parameter "doc_ids":["doc1", "doc2"] tells couchdb to replicate only the doc1 and doc2 documents. If there are other documents for eg: doc3, doc4, etc they won't be replicated. Couchdb is very powerful in filtered replication and works very nicely on the mobile devices which might go online and offline very frequently due to coverage issues.
Some useful considerations for couchdb:
1 - Lightweight (around 23M resident size)
2 - MVCC - Multi Version Concurrency Control - would be a natural fit for the products that need to track multiple updates to the same document
3 - Filtered data replication
4 - NoSQL,Document based,schema-free design - No relational data and the data could vary during updates at various intervals
5 - For a embeddable solution take a look at touchdb
6 - Offline web applications - pouchDB
7 - Clustering Big Couch
Cassandra vs MongoDB vs CouchDb vs Redis vs Riak vs HBase vs Membase vs Neo4j
The above are some of the main features apart from plethora of benefits couchdb provides.
Couchdb is supported by cloudant team - http://blog.cloudant.com/the-future-of-couchdb/
couchdb doesn't stop here ... there are lot more ....
Sunday, July 15, 2012
Tuesday, July 3, 2012
JBoss 7 - Caused by: org.dom4j.DocumentException: org.dom4j.DocumentFactory cannot be cast to org.dom4j.DocumentFactory Nested exception: org.dom4j.DocumentFactory cannot be cast to org.dom4j.DocumentFactory
Simple solution to fix this issue:
You do not need to do any of the following:
If you do not want to read the above URL, which is really not giving the straight forward solution:
1 - Open {your war}/META-INF/MANIFEST.MF
2 - Add this line at the end - Dependencies: org.dom4j export
You do not need to do any of the following:
1 - jboss-deployment-structure.xml - exclussions
2 - Adding subsystem to include org.dom4j as global modules
3 - Remove your dom4j-1.6.1.jar from your WEB-INF/lib directory
Most of the time you hit this problem when you try to deploy a war that has hibernate 4 included in it. In this case you may want to do the following for JBoss 7:
To your persistence.xml add the following properties, which is not need for tomcat (assuming you are using oracle > 10g).
<properties >
<property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect"/ >
<property name="hibernate.listeners.envers.autoRegister" value="false"/ >
</properties >
<property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect"/ >
<property name="hibernate.listeners.envers.autoRegister" value="false"/ >
</properties >
Labels:
dom4j,
hibernate4,
hibernate4 issue,
hibernate4 jboss,
jboss
Subscribe to:
Posts (Atom)