flume mysql to hbase_04 flume将数据导入到Hbase

本文档详细介绍了如何使用Flume将数据从MySQL导入到HBase。首先,介绍了系统的环境配置,包括CentOS 7、HBase服务的启动和表的创建。然后,展示了Flume配置文件`flume-conf.properties`的具体内容,用于从指定文件读取数据并将其发送到HBase。接着,指导如何拷贝必要的HBase库到Flume的lib目录,启动Flume服务,并创建测试数据。最后,验证数据已成功导入到HBase表中。
摘要由CSDN通过智能技术生成

我们已经了解了使用flume监听端口以及文件内容,本节将展示使用flume导入数据到hbase。

1 系统、软件以及前提约束

CentOS 7 64 工作站 作者的机子ip是192.168.100.200,请读者根据自己实际情况设置

xshell客户端

为去除权限对操作的影响,所有操作都以root进行

2 操作

1 使用xshell登录到192.168.100.200

2 启动hbase服务,登录到hbase客户端,创建表

# 进到hbase启动目录

cd /root/hbase-1.2.6/bin

# 启动hbase服务

./start-hbase.sh

# 登录到hbase客户端

./hbase shell

# 在hbase命令行创建一个表

hbase(main):001:0> create 't2','f2'

3 修改flume-conf.properties,其中a1为flume的服务名称

a1.sources = r1

a1.sinks = k1

a1.channels = c1 # Describe/configure the source

a1.sources.r1.type = exec

a1.sources.r1.command = tail -F /root/hbase.txt

a1.sources.r1.channels = c1 # Describe the sink

a1.sinks.k1.type = logger

a1.sinks.k1.type = hbase

# 与hbase中创建的表名相同

a1.sinks.k1.table = t2

# 与hbase中创建的表的列簇相同

a1.sinks.k1.columnFamily = f2

a1.sinks.k1.serializer = org.apache.flume.sink.hbase.RegexHbaseEventSerializer

a1.sinks.k1.channel = memoryChannel # Use a channel which buffers events in memory

a1.channels.c1.type = memory

a1.channels.c1.capacity = 1000

a1.channels.c1.transactionCapacity = 100 # Bind the source and sink to the channel

a1.sources.r1.channels = c1

a1.sinks.k1.channel = c1

4 拷贝jar包

# 如有jar包已经存在,选择y予以覆盖

cp /root/hbase-1.2.6/lib/* /root/apache-flume-1.8.0-bin/lib/

5 启动flume服务

# 进入flume的启动目录

cd /root/apache-flume-1.8.0-bin/bin

# 启动flume

./flume-ng agent -c ../conf -f ../conf/flume-conf.properties -n a1 -Dflume.root.logger=INFO,console

6 测试

# 创建flume监听的文件

touch /root/hbase.txt

# 向hbase.txt中写入字符串

echo 'Iamzhangli'>>/root/hbase.txt

echo 'jiangsuwanhe'>>/root/hbase.txt

7 查看hbase中t2表的内容

# 登录到hbase客户端

./hbase shell

# 查看t2表,我们会看到刚才加入到hbase.txt中的数据已经进入hbase

hbase(main):001:0> scan 't2'

以上就是flume将数据导入Hbase的过程。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值