Hbase - 之Phoenix-JDBC连接、命名空间映射

Hbase - 之Phoenix-JDBC连接、命名空间映射

1、在客户端本地添加hbase-site.xml

<configuration>
  <property>
    <name>hbase.zookeeper.quorum</name>
    <value>shufang101:2181,shufang102:2181,shufang103:2181</value>
    <description>外部zookeeper集群的ip:port
    </description>
  </property>
  <property>
    <name>hbase.zookeeper.property.dataDir</name>
    <value>/opt/module/zookeeper-3.7.0/data</value>
    <description>从外部zk的conf/zoo.cfg中配置的dataDir属性,快照存储在这个目录下面P
    </description>
  </property>
  <property>
    <name>hbase.rootdir</name>
    <value>hdfs://shufang101:9000/hbase</value>
    <description>这个目录被所有的RegionServer共享
    </description>
  </property>
  <property>
    <name>hbase.cluster.distributed</name>
    <value>true</value>
    <description>完全分布式集群模式必须指定的
      false: 通过内部的zk来设置单机模式和伪分布式模式
      true: 通过外部的zk的来管理完全分布式集群模式
    </description>
  </property>
   <property>
         <name>hbase.unsafe.stream.capability.enforce</name>
         <value>false</value>
         </property>
   <property>
         <name>hbase.wal.provider</name>
         <value>filesystem</value>
   </property>

   <!--Phoenix的相关的配置,hbase的master和regionserver节点都需要配置-->
   <property>
           <name>phoenix.schema.isNamespaceMappingEnabled</name>
           <value>true</value>
   </property>
   <property>
           <name>phoenix.schema.mapSystemTablesToNamespace</name>
           <value>true</value>
   </property>
   <property>
            <name>hbase.regionserver.wal.codec</name>
            <value>org.apache.hadoop.hbase.regionserver.wal.IndexedWALEditCodec</value>
  </property>

</configuration>

2、添加Phoenix的核心依赖

<dependency>
    <!-- https://mvnrepository.com/artifact/org.apache.phoenix/phoenix-core -->
    <groupId>org.apache.phoenix</groupId>
    <artifactId>phoenix-core</artifactId>
    <version>5.0.0-HBase-2.0</version>
    <exclusions>
        <exclusion>
            <groupId>org.glassfish</groupId>
            <artifactId>javax.el</artifactId>
        </exclusion>
        <!--为了与其它包下的版本保持一致,这里就不引入默认的3.0.0的common的依赖,手动使用2.7.7的-->
        <exclusion>
            <groupId>org.apache.hadoop</groupId>
            <artifactId>hadoop-common</artifactId>
        </exclusion>
    </exclusions>
</dependency>

3、编写代码

// 声明Phoenix的连接对象
Connection conn = null;
Class.forName("org.apache.phoenix.jdbc.PhoenixDriver");
conn = DriverManager.getConnection(CommonConfig.PHOENIX_URL);

//TODO 在拼接好建表语句之后,需要获取一个Phoenix连接,来执行建表语句,为了减少创建的次数,我们在Open方法中创建连接
PreparedStatement ps = null;
try {
    ps = conn.prepareStatement(ddl.toString());
    ps.execute();
    System.out.println("执行SQL :【" + ddl + "】建表语句成功");
} catch (SQLException throwables) {
    throwables.printStackTrace();
} finally {
    if (ps != null) {
        try {
            ps.close(); //关闭ps,conn不需要关闭,因为这个连接是一个长连接
        } catch (SQLException throwables) {
            throwables.printStackTrace();
            throw new RuntimeException("Phoenix 建表失败!~~~~~~");
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值