Using BerkeleyDB to make a distributed database.
- Consistent hashing to balance load across Workers
- Server pushed client-side look ups similar to Google BigTable and EdgeBase
- Table support
- Client side caching
Make sure you have access to /tmp/ directory of your machine.
To compile and run the software:
- Run compile.sh script. (Do it on each host if using multiple hosts)
- Go to the directory /tmp/berkeleydb/
- On the master host, run runServer.sh script.
- On each worker host, run runWorker.sh <Database_Name> <IP_of_Master>.
- It is normal to see an exception about the already used port for rmi registry if more than one workers or the master is running on the same machine. However if the exception does not allow the program to start, please run killrmis.sh script and try the step 4 again.If this doesn't work either, run
ps aux | grep rmiregistry
andkill -9
the process.
- On each client, run runClient.sh <IP_of_Master>.
- Have fun!
- To turn off the system, please use Ctrl + c on each host running one of the runXX.sh scripts. For killing rmi registries, please run killrmis.sh script.
- Transactions
- Replication