Flume 将数据导入Hive

本文介绍如何使用Flume将数据导入Hive的过程。主要包括配置Flume的.conf文件、运行配置文件、复制Hive的jar包至Flume lib目录、启动Hive metastore、创建数据库和表、设置Hive属性并进行数据输入与查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Flume 将数据导入Hive

1:创建.conf文件

#cd   /usr/tmp

#mkdir  flumesrc

#vim  netcat_to_hive_user.conf

a1.sources=r1

a1.sinks=s1
a1.channels=c1

a1.sources.r1.type=netcat
a1.sources.r1.bind=master
a1.sources.r1.port=44444

a1.sinks.s1.type=hive
a1.sinks.s1.channel = c1
a1.sinks.s1.hive.metastore = thrift://master:9083
a1.sinks.s1.hive.database = bd18
a1.sinks.s1.hive.table = flume_user
a1.sinks.s1.useLocalTimeStamp = false
a1.sinks.s1.serializer = DELIMITED
a1.sinks.s1.serializer.delimiter = "\t"
a1.sinks.s1.serializer.serdeSeparator = '\t'
a1.sinks.s1.serializer.fieldnames=user_id,user_name,age

a1.channels.c1.type=memory
a1.channels.c1.capacity=1000


2:运行.conf文件

#flume-ng agent -c conf -f  netcat_to_hive_user.conf  --name a1 -Dflume.root.logger=INFO,console


3:将hive的四个jar包复制到flume安装目录的lib文件夹下



4:启动hive的metastore

#hive  --service metastore


5:进入hive,创建数据库和表

hive> create database bd18;

hive> create table flume_user(
    > user_id int,
    > user_name string,
    > age int
    > )
    > clustered by(user_id) into 2 buckets
    > stored as orc
    > tblproperties("transactional"='true');

hive> select * from flume_user;
FAILED: SemanticException [Error 10265]: This command is not allowed on an ACID table bd18.flume_user with a non-ACID transaction manager. Failed command: select * from flume_user

hive> set hive.support.concurrency=true;

hive> set hive.txn.manager=org.apache.hadoop.hive.ql.lockmgr.DbTxnManager;
hive> select * from flume_user;
OK
Time taken: 5.809 seconds


6:操作flume,向hive输入数据

[root@master ~]# telnet master 44444
Trying 192.168.2.100...
Connected to master.
Escape character is '^]'.
1     jim      18
OK

注:中间用Tab键隔开


7:查询Hive表中的内容

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值