here is a quick tutorial to setup hbase instance and hook up with a basic coprocessor.
Download the tar file and unzip it from http://mirror.tcpdiag.net/apache/hbase/hbase-0.94.11/
Change the Hbase-site.xml, point the hbase.rootdir to the local folder, by default Hbase will load the default one embedded in the hbase-x.jar, and default setting is local temp folder,
change it to a folder you fell comfortable,
also change the hbase.temp.dir to a well know folder, you can see all the underlying folder it used,
My final change,
data:image/s3,"s3://crabby-images/6a0fe/6a0fe6b54cd816f156aed884367fc9123116bff6" alt="image image"
then you can start the hbase server ./bin/start-hbase.sh
check the port it listened, should be a port called 60030
then you can go the http://ip:60030 to see the hbase console of the given region. and 60010 for the hbase master
data:image/s3,"s3://crabby-images/64e08/64e08bd7f321ba2ffccb20524b975e6efeb35329" alt="image image"
data:image/s3,"s3://crabby-images/a08d7/a08d76e44570f7b82c1651da641674a572c7f77f" alt="image image"
then create a table and put a record
data:image/s3,"s3://crabby-images/2ad76/2ad76763ae1216624ee97d3eeedc403ede8a1a15" alt="image image"
check the folder
data:image/s3,"s3://crabby-images/0b9d2/0b9d2c7ad6c1cc1062ce462cfcce994d1aba341f" alt="image image"
Now let’s write a basic java program to read the data in hbase.
Create a new maven project by clicking the eclipse wizard,
Click the pom.xml, right click to add one dependency hbase.
![image_thumb[3] image_thumb[3]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhE_rGzsBWm4Zz7sxcelRQKYwbUmJrsyS3SJ90L63IAFlDozirfmNm_G_uZJPVGM78O7jXTbubsAYnlmjDfS4OdO2l_aFvR2TXV7nDWRrd4ZY5zvosWqmtCIA69kzRfxhIt7hsYaUl3gYo/?imgmax=800)
Simple Query in another server, make sure the zookeeper ip and host name are accessible from client machine,
data:image/s3,"s3://crabby-images/a372b/a372b5ba4ee945c5ba6d96451bc92ee4d079bf71" alt="image image"
for the coprocessor, they are bascailly observers in 3 levels.
Master level, you can hookup with all the DDL like create table,update column,etc (check BaseMasterObserver)
and DML level in the region servers,
data:image/s3,"s3://crabby-images/0c09b/0c09b11cc43093fffe1b29bec1fa9a4c594bd55a" alt="image image"
And WAL level, all changes going to WAL, basically you can see all the changes. you can even reject the change
I will put the WALobserver as a example, just dump out any changes to the cluseter, we can send the changeset to another server do secondary indexing, or for logging /auditing purpose.
data:image/s3,"s3://crabby-images/98d9b/98d9b6d92871c706257f59a6e7e298c5a7d0d1fb" alt="image image"
compile and package it to a jar file,then copy to the hbase lib folder, or any folder which is in the HBASE_CLASSPATH
then change hbase-site.xml, point to our WALobserver
data:image/s3,"s3://crabby-images/0f04d/0f04d1065ac2e2dc9a7f45b2c56e0a9af14951b0" alt="image image"
then restart the instance, from the region server, you can see our WAL is loaded,
data:image/s3,"s3://crabby-images/ebfb6/ebfb6169fc26250de39e5145939e6792bb53f5b6" alt="image image"
then make some changes to the data,
from the log, you should see our logging , data changes captured here
data:image/s3,"s3://crabby-images/ab899/ab899a33cbe4adffdc57854ff56afc76c22c134b" alt="image image"
Please note the WALobserver runs in the same JVM of the hbase, make sure not fail safe and no huge extra performance hit.