实验二 HBase编程实践(centos7)
链接:https://pan.baidu.com/s/1Pp7fgEEN3ABc4QXkCxGI6w?pwd=5566提取码:5566
1.zookeeper环境搭建
1.1压缩文件
tar -zxvf zookeeper-3.4.10.tar.gz
sudo mkdir -p /usr/zookeeper#创建文件
sudo cp -r zookeeper-3.4.10 /usr/zookeeper/
1.2修改配置文件
ZooKeeper的核心折务器属性配置文件是zoo.cfg。在主安装目次下的conf子目次内,体系为用户准备了一个模板文件zoo_sample.cfg,我们可以将这个文件拷贝一份,命名为zoo.cfg,然后修改配置文件。起首我们进入到conf子目次,执行以下命令:
cd /usr/zookeeper/zookeeper-3.4.10/conf
cp zoo_sample.cfg zoo.cfg
vim zoo.cfg 然后,我们进入到zoo.cfg文件中修改配置信息,tickTime:这个时间是作为ZooKeeper服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个tickTime时间就会发送一个心跳;dataDir:顾名思义就是ZooKeeper保存数据的目次,默认情况下,ZooKeeper将数据的日志文件也保存在这个目次里;clientPort:这个端口就是客户端连接ZooKeeper服务器的端口,ZooKeeper会监听这个端口,接收客户端的请求。按如下配置修改tickTime、dataDate、clientPort的值(别的内容不做修改):
tickTime=2000
dataDir=/usr/zookeeper/zookeeper-3.4.10/tmp/zookeeper#自己创建tmp/zookeeper
clientPort=2181
1.3配置环境变量
vim~/.bashrc 在文件末端增加下面内容:
export ZOOKEEPER_HOME=/usr/zookeeper/zookeeper-3.4.10/
export PATH=$ZOOKEEPER_HOME/bin:$PATH 使环境变量生效:
source~/.bashrc 1.4启动 zookeeper
zkServer.sh start https://i-blog.csdnimg.cn/direct/9b33cf48b9b3498083a3a1987793f9e2.png
2.Hbase环境配置
1.1压缩Hbase
tar -zxvf hbase-1.2.6-bin.tar.gz
sudo mkdir -p /usr/hbase#创建文件
sudo cp -r hbase-1.2.6 /usr/hbase/ 1.2配置环境变量
vim~/.bashrc 在打开文件的末端添加以下两行代码,保存并退出。
export HBASE_HOME=/usr/hbase/hbase-1.2.6/
export PATH=$HBASE_HOME/bin:$PATH https://i-blog.csdnimg.cn/direct/f478b55f34ef46d58bc7a73ca03379e8.png
使环境变量生效,执行下面命令:
source ~/.bashrc 进入hbase文件后创建data目次
mkdir zookeeper 进入hbase中的conf文件后修改配置文件hbase-env.sh
cd /usr/hbase/hbase-1.2.6/conf
vim hbase-env.sh 在打开的文件中,找到“# export JAVA_HOME”开头的文件,去掉前面的“#”,修改为:
export JAVA_HOME=/usr/java/jdk1.8.0_212 另外,找到“# export HBASE_MANAGES_ZK”开头的文件,去掉前面的“#”,修改为:
export HBASE_MANAGES_ZK=true 1.3修改配置文件hbase-site.xml
cd /usr/hbase/hbase-1.2.6/conf
vimhbase-site.xml 在打开的文件中编辑内容,如下:
<configuration>
<!--HBase的数据保存在HDFS对应目录-->
<property>
<name>hbase.rootdir</name>
<value>hdfs://node1:9000/hbase</value>
</property>
<!--是否是分布式环境-->
<property>
<name>hbase.cluster.distributed</name>
<value>true</value>
</property>
<!--配置ZK的地址-->
<property>
<name>hbase.zookeeper.quorum</name>
<value>node1</value>
</property>
<!--冗余度-->
<property>
<name>dfs.replication</name>
<value>1</value>
</property>
<!--zookeeper数据目录-->
<property>
<name>hbase.zookeeper.property.dataDir</name>
<value>file:/usr/hbase/hbase-1.2.6/zookeeper</value>
</property>
</configuration> 1.4 修改配置文件regionservers
vim regionservers 在打开的文件中,将内里的内容修改为(本身主机名):
node1 https://i-blog.csdnimg.cn/direct/1b3c883739504f7e9480148aa31d89bb.png
1.5启动hbase
cd /usr/hbase/hbase-1.2.6/conf
start-hbase.sh jps检察进程
https://i-blog.csdnimg.cn/direct/5310051661494f60b5f94c7d38ffb22c.png访问http://192.168.159.128:16010 (换成本身的ip地址)
https://i-blog.csdnimg.cn/direct/c1ae509275fd4d42bbfe0309de445f26.png
3.HBase Java API编程实践
1)createTable(String tableName, String[] fields)
创建表,参数tableName为表的名称,字符串数组fields为存储记录各个字段名称的数组。要求当HBase已经存在名为tableName的表的时间,先删除原有的表,然后再创建新的表。
2)addRecord(String tableName, String row, String[] fields, String[] values)
向表tableName、行row(用S_Name表现)和字符串数组fields指定的单位格中添加对应的数据values。其中,fields中每个元素如果对应的列族下另有相应的列限定符的话,用“columnFamily:column”表现。例如,同时向“Math”、“Computer Science”、“English”三列添加成绩时,字符串数组fields为{“Score:Math”, ”Score:Computer Science”, ”Score:English”},数组values存储这三门课的成绩。
3)modifyData(String tableName, String row, String column)
修改表tableName,行row(可以用门生姓名S_Name表现),列column指定的单位格的数据。
4)deleteRow(String tableName, String row)
删除表tableName中row指定的行的记录。
本实例接纳Eclipse开发工具。
启动Eclipse,启动以后,出现如下图所示界面,点击ok按钮。
https://i-blog.csdnimg.cn/direct/f85851e7b35d436e9bf844d60a0d0cd2.png
https://i-blog.csdnimg.cn/direct/ea0e4e78778d4bfb9719b448647036cd.png
https://i-blog.csdnimg.cn/direct/7c0b3cbf007743ca9e81a3f4a82fdd85.png
https://i-blog.csdnimg.cn/direct/1700c1cc85c14962b84e5b0e978ed6e3.png
添加hbase安装包下的所有jar包
https://i-blog.csdnimg.cn/direct/fe1da2857e624917a9756e1b1f5a3027.png
https://i-blog.csdnimg.cn/direct/6562509f5cb94c2aab3181dfa9f79d6d.png
https://i-blog.csdnimg.cn/direct/5d70caf5e8054e74b8a06b42fc75002b.png
https://i-blog.csdnimg.cn/direct/0d88a3394bcc4b0aabd30cdee5fc2563.png
在开始运行步伐之前,需要启动HDFS和HBase。我的已经运行了
https://i-blog.csdnimg.cn/direct/7317647a60d948f796e44258cf47232d.png
HBaseTest.java代码内容详细如下
import java.io.IOException;
import java.util.HashSet;
import java.util.Set;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.Admin;
import org.apache.hadoop.hbase.client.Connection;
import org.apache.hadoop.hbase.client.ConnectionFactory;
import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;
import org.apache.hadoop.hbase.client.ColumnFamilyDescriptorBuilder;
import org.apache.hadoop.hbase.client.TableDescriptorBuilder;
import org.apache.hadoop.hbase.util.Bytes;
public class HBaseTest {
private Configuration conf = null; // 用于配置 HBase 连接的配置对象
private Connection conn = null; // 用于连接 HBase 的连接对象
// 初始化连接
public void init() throws Exception {
conf = HBaseConfiguration.create();
conf.set("hbase.zookeeper.quorum", "node1:2181");
conn = ConnectionFactory.createConnection(conf);
}
// 创建表,若表已存在则先删除再创建
public void createTable(String tableName, String[] fields) throws Exception {
try (Admin admin = conn.getAdmin()) {
TableName table = TableName.valueOf(tableName);
if (admin.tableExists(table)) {
admin.disableTable(table);
admin.deleteTable(table);
System.out.println("Old table deleted.");
}
// 创建列族
Set<String> families = new HashSet<>();
for (String field : fields) {
String columnFamily = field.split(":");
families.add(columnFamily);
}
// 创建表描述符并添加列族
TableDescriptorBuilder builder = TableDescriptorBuilder.newBuilder(table);
for (String family : families) {
ColumnFamilyDescriptor cfDesc = ColumnFamilyDescriptorBuilder.of(family);
builder.setColumnFamily(cfDesc);
}
admin.createTable(builder.build());
System.out.println("Table created successfully.");
} catch (Exception e) {
e.printStackTrace();
}
}
// 添加记录
public void addRecord(String tableName, String row, String[] fields, String[] values) throws Exception {
try (Table table = conn.getTable(TableName.valueOf(tableName))) {
Put put = new Put(Bytes.toBytes(row));
for (int i = 0; i < fields.length; i++) {
String[] parts = fields.split(":");
String family = parts;
String qualifier = parts.length > 1 ? parts : "";
put.addColumn(Bytes.toBytes(family), Bytes.toBytes(qualifier), Bytes.toBytes(values));
}
table.put(put);
System.out.println("Data inserted successfully.");
} catch (Exception e) {
e.printStackTrace();
}
}
// 修改数据
public void modifyData(String tableName, String row, String column, String value) throws Exception {
try (Table table = conn.getTable(TableName.valueOf(tableName))) {
Put put = new Put(Bytes.toBytes(row));
String[] parts = column.split(":");
String family = parts;
String qualifier = parts.length > 1 ? parts : "";
put.addColumn(Bytes.toBytes(family), Bytes.toBytes(qualifier), Bytes.toBytes(value));
table.put(put);
System.out.println("Data modified successfully.");
} catch (Exception e) {
e.printStackTrace();
}
}
// 删除行
public void deleteRow(String tableName, String row) throws Exception {
try (Table table = conn.getTable(TableName.valueOf(tableName))) {
Delete delete = new Delete(Bytes.toBytes(row));
table.delete(delete);
System.out.println("Row deleted successfully.");
} catch (Exception e) {
e.printStackTrace();
}
}
// 主程序
public static void main(String[] args) {
HBaseTest demo = new HBaseTest();
try {
demo.init();
// 创建表
demo.createTable("student", new String[]{
"Info:S_No", "Info:S_Name", "Info:S_Sex", "Info:S_Age",
"Score:Math", "Score:Computer Science", "Score:English"
});
// 添加记录
demo.addRecord("student", "2015001",
new String[]{
"Info:S_No", "Info:S_Name", "Info:S_Sex", "Info:S_Age",
"Score:Math", "Score:Computer Science", "Score:English"
},
new String[]{"2015001", "ZhangQuanDe", "man", "21", "90", "92", "66"}
);
// 修改数据
demo.modifyData("student", "2015001", "Score:Math", "60");
// 删除行
demo.deleteRow("student", "2015001");
} catch (Exception e) {
e.printStackTrace();
}
}
}
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]