如何让 Tomcat 访问 HBase

让Tomcat启动时加载所有hbase的jar包,避免出现NoClassDefFoundError错误
编辑${catalina.home}/conf目录下的catalina.properties
修改common.loader项
原:
common.loader=${catalina.base}/lib,${catalina.base}/lib/*.jar,${catalina.home}/lib,${catalina.home}/lib/*.jar
添加 /home/myhbase/hbase/lib,/home/myhbase/hbase/lib/*.jar
变为:
common.loader=${catalina.base}/lib,${catalina.base}/lib/*.jar,${catalina.home}/lib,${catalina.home}/lib/*.jar,/home/myhbase/hbase/lib,/home/myhbase/hbase/lib/*.jar
重启Tomcat
service tomcat stop
service tomcat start

以上内容来自:http://www.xuebuyuan.com/2017724.html

一个查询的例子
一个JSP页面

<%@ page language="java" %>
<%@ page contentType="text/html;charset=UTF-8" pageEncoding="utf-8" %>
<%@ page import="java.io.IOException,org.apache.hadoop.hbase.MasterNotRunningException,org.apache.hadoop.hbase.ZooKeeperConnectionException,org.apache.hadoop.conf.Configuration,org.apache.hadoop.hbase.client.*" %>

<%!
    public String query(String keyword)
        throws MasterNotRunningException, ZooKeeperConnectionException, IOException
    {
        Configuration conf = new Configuration();
        HTable table = new HTable(conf, "recommend");
        Get get = new Get(keyword.getBytes());
        get.addFamily("f".getBytes());
        Result result = table.get(get);
        byte[] val = result.getValue("f".getBytes(), "c".getBytes());
        if(val==null) return null;
        else return new String(val);
    }
%>
<%
    String keyword = request.getParameter("wd");
    if(keyword == null || keyword == "") {
        out.print("无效输入");
        return;
    }
    String result = query(keyword);
    if(result == null) {
        out.print("数据库中无此数据");
        return;
    }
    out.print("<table border=1 cellspacing=0><tr><th width=50>Num.<th width=80>ID<th width=180>Pref.");
    int counter=1;
    String[] rev = result.split(":|,");
    for(int i=0;i<rev.length;++i)
    {
        out.print("<tr><td align=\"center\">"+counter);
        ++counter;
        out.print("<td align=\"center\">"+rev[i]+"<td align=\"center\">"+rev[++i]);
    }
%>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值