阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Hive自定义函数的使用——useragent解析

216次阅读
没有评论

共计 3803 个字符,预计需要花费 10 分钟才能阅读完成。

想要从日志数据中分析一下操作系统、浏览器、版本使用情况,但是 hive 中的函数不能直接解析 useragent, 于是可以写一个 UDF 来解析。useragent 用于表示用户的当前操作系统,浏览器版本信息,形如:

Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36 180.173.196.29

其中解析 ua 可以用一个开源的工具包, 叫做 useragentutils.jar 来处理,但是不能直接引入这个包,因为 Hadoop 和 hive 都不支持直接引用第三方的包,要导入源码。项目结构应该如下图

Hive 自定义函数的使用——useragent 解析

下面的代码用来打印出操作系统、浏览器版本信息:

import org.apache.hadoop.hive.ql.exec.UDF;
import org.apache.hadoop.io.Text;

import eu.bitwalker.useragentutils.UserAgent;

public class ParseUserAgent_UDF extends UDF{
 public Text evaluate(final Text userAgent){
  StringBuilder builder = new StringBuilder();
  UserAgent ua = new UserAgent(userAgent.toString());
  builder.append(ua.getOperatingSystem()+”\t”+ua.getBrowser()+”\t”+ua.getBrowserVersion());
  return new Text(builder.toString());
 }
}

使用:打成 jar 包,hive 中 add jar xx.jar;

create temporary function ua_parse as ‘com.xx.ParseUserAgent_UDF’;

select ua_parse(ua) from table_name limit 3;

结果:

WINDOWS_7      CHROME21        21.0.1180.89
WINDOWS_7      CHROME33        33.0.1750.146
WINDOWS_7      CHROME21        21.0.1180.89

此种方式只能处理一行,生成一行,无法进行统计分析。

下面使用 UDTF(User Defined Table Generating Function), 处理一行,生成多列。

import java.util.ArrayList;

import org.apache.hadoop.hive.ql.exec.UDFArgumentException;
import org.apache.hadoop.hive.ql.exec.UDFArgumentLengthException;
import org.apache.hadoop.hive.ql.metadata.HiveException;
import org.apache.hadoop.hive.ql.udf.generic.GenericUDTF;
import org.apache.hadoop.hive.serde2.objectinspector.ObjectInspector;
import org.apache.hadoop.hive.serde2.objectinspector.ObjectInspectorFactory;
import org.apache.hadoop.hive.serde2.objectinspector.StructObjectInspector;
import org.apache.hadoop.hive.serde2.objectinspector.primitive.PrimitiveObjectInspectorFactory;

import eu.bitwalker.useragentutils.UserAgent;

public class ParseUserAgent_UDTF extends GenericUDTF{
 @Override
 public StructObjectInspector initialize(ObjectInspector[] args) throws UDFArgumentException {
  if (args.length != 1) {
   throw new UDFArgumentLengthException(“ExplodeMap takes only one argument”);
  }
  if (args[0].getCategory() != ObjectInspector.Category.PRIMITIVE) {
   throw new UDFArgumentException(“ExplodeMap takes string as a parameter”);
  }
  ArrayList<String> fieldNames = new ArrayList<String>();
  ArrayList<ObjectInspector> fieldOIs = new ArrayList<ObjectInspector>();
  fieldNames.add(“system”);
  fieldOIs.add(PrimitiveObjectInspectorFactory.javaStringObjectInspector);
  fieldNames.add(“browser”);
  fieldOIs.add(PrimitiveObjectInspectorFactory.javaStringObjectInspector);
  fieldNames.add(“version”);
  fieldOIs.add(PrimitiveObjectInspectorFactory.javaStringObjectInspector);
  return ObjectInspectorFactory.getStandardStructObjectInspector(fieldNames, fieldOIs);
 }
 @Override
 public void process(Object[] arg){
  try {
   if(arg == null || arg.length == 0)
    return;
   String input = arg[0].toString();
   String result[] = ua_parse(input).split(“\t”);
   forward(result);
  } catch (Exception e) {
   e.printStackTrace();
  }
 }
 
 @Override
 public void close() throws HiveException {
 
 }
 public String ua_parse(String userAgent){
  StringBuilder builder = new StringBuilder();
  UserAgent ua = new UserAgent(userAgent.toString());
  builder.append(ua.getOperatingSystem()+”\t”+ua.getBrowser()+”\t”+ua.getBrowserVersion());
  return builder.toString();
 }
}

select t.browser,count(*) c from (select ua_parse(ua) as (system,browser,version) from table_name) t group by t.browser order by c desc;

前十名:

CHROME31        987220571
UNKNOWN 708890045
IE8    420021677
IE7    411500373
MOBILE_SAFARI  291920740
IE6    217574865
IE11    179582201
IE9    165160040
CHROME30        158623163
CHROME21        155192489

未识别的还是很多!

基于 Hadoop 集群的 Hive 安装 http://www.linuxidc.com/Linux/2013-07/87952.htm

Hive 内表和外表的区别 http://www.linuxidc.com/Linux/2013-07/87313.htm

Hadoop + Hive + Map +reduce 集群安装部署 http://www.linuxidc.com/Linux/2013-07/86959.htm

Hive 本地独立模式安装 http://www.linuxidc.com/Linux/2013-06/86104.htm

Hive 学习之 WordCount 单词统计 http://www.linuxidc.com/Linux/2013-04/82874.htm

Hive 运行架构及配置部署 http://www.linuxidc.com/Linux/2014-08/105508.htm

Hive 的详细介绍 :请点这里
Hive 的下载地址 :请点这里

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-20发表,共计3803字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中