mapreduce对日志数据上下行流量汇总

原创 2017年07月17日 18:39:45

Mapreduce中的排序初步
4.1.1 需求
对日志数据中的上下行流量信息汇总,并输出按照总流量倒序排序的结果
数据如下:
1363157985066 13726230503 00-FD-07-A4-72-B8:CMCC 120.196.100.82 24 27 2481 24681 200
1363157995052 13826544101 5C-0E-8B-C7-F1-E0:CMCC 120.197.40.4 4 0 264 0 200
1363157991076 13926435656 20-10-7A-28-CC-0A:CMCC 120.196.100.99 2 4 132 1512 200
1363154400022 13926251106 5C-0E-8B-8B-B1-50:CMCC 120.197.40.4 4 0 240 0 200

4.1.2 分析
基本思路:实现自定义的bean来封装流量信息,并将bean作为map输出的key来传输

MR程序在处理数据的过程中会对数据排序(map输出的kv对传输到reduce之前,会排序),排序的依据是map输出的key
所以,我们如果要实现自己需要的排序规则,则可以考虑将排序因素放到key中,让key实现接口:WritableComparable然后重写key的compareTo方法

4.1.3 实现
1、 自定义的bean
public class FlowBean implements WritableComparable{

long upflow;
long downflow;
long sumflow;

//如果空参构造函数被覆盖,一定要显示定义一下,否则在反序列时会抛异常
public FlowBean(){}

public FlowBean(long upflow, long downflow) {
    super();
    this.upflow = upflow;
    this.downflow = downflow;
    this.sumflow = upflow + downflow;
}

public long getSumflow() {
    return sumflow;
}

public void setSumflow(long sumflow) {
    this.sumflow = sumflow;
}

public long getUpflow() {
    return upflow;
}
public void setUpflow(long upflow) {
    this.upflow = upflow;
}
public long getDownflow() {
    return downflow;
}
public void setDownflow(long downflow) {
    this.downflow = downflow;
}

//序列化,将对象的字段信息写入输出流
@Override
public void write(DataOutput out) throws IOException {

    out.writeLong(upflow);
    out.writeLong(downflow);
    out.writeLong(sumflow);

}

//反序列化,从输入流中读取各个字段信息
@Override
public void readFields(DataInput in) throws IOException {
    upflow = in.readLong();
    downflow = in.readLong();
    sumflow = in.readLong();

}


@Override
public String toString() {
    return upflow + "\t" + downflow + "\t" + sumflow;
}
@Override
public int compareTo(FlowBean o) {
    //自定义倒序比较规则
    return sumflow > o.getSumflow() ? -1:1;
}

}

2、 mapper 和 reducer
public class FlowCount {

static class FlowCountMapper extends Mapper<LongWritable, Text, FlowBean,Text > {

    @Override
    protected void map(LongWritable key, Text value, Context context) throws IOException, InterruptedException {

        String line = value.toString();
        String[] fields = line.split("\t");
        try {
            String phonenbr = fields[0];

            long upflow = Long.parseLong(fields[1]);
            long dflow = Long.parseLong(fields[2]);

            FlowBean flowBean = new FlowBean(upflow, dflow);

            context.write(flowBean,new Text(phonenbr));
        } catch (Exception e) {

            e.printStackTrace();
        }

    }

}

static class FlowCountReducer extends Reducer<FlowBean,Text,Text, FlowBean> {

    @Override
    protected void reduce(FlowBean bean, Iterable<Text> phonenbr, Context context) throws IOException, InterruptedException {

        Text phoneNbr = phonenbr.iterator().next();

        context.write(phoneNbr, bean);

    }

}

public static void main(String[] args) throws Exception {

    Configuration conf = new Configuration();

    Job job = Job.getInstance(conf);

    job.setJarByClass(FlowCount.class);

    job.setMapperClass(FlowCountMapper.class);
    job.setReducerClass(FlowCountReducer.class);

     job.setMapOutputKeyClass(FlowBean.class);
     job.setMapOutputValueClass(Text.class);

    job.setOutputKeyClass(Text.class);
    job.setOutputValueClass(FlowBean.class);

    // job.setInputFormatClass(TextInputFormat.class);

    FileInputFormat.setInputPaths(job, new Path(args[0]));
    FileOutputFormat.setOutputPath(job, new Path(args[1]));

    job.waitForCompletion(true);

}

}

第二个MapReduce程序----flowcount(流量统计,自定义排序,自定义分区)

感谢段海涛老师 FlowBean.java通用的 package club.drguo.mapreduce.flowcount; import java.io.DataInput; import j...
  • Dr_Guo
  • Dr_Guo
  • 2016年03月19日 22:02
  • 1092

对日志数据中的上下行流量信息汇总

需求:对日志数据中的上下行流量信息汇总 例如数据如下: 1363157985066 13726230503 00-FD-07-A4-72-B8:CMCC 120.196.100.82   ...
  • tian_qing_lei
  • tian_qing_lei
  • 2017年07月10日 23:51
  • 99

Hadoop2.4.1 简单的用户手机流量统计的MapReduce程序(二)

接着Hadoop2.4.1 简单的用户手机流量统计的MapReduce程序(一),现在我们 又有了新的需求,我们需要根据用户的总流量升序排列。 1.环境:Centos 6.5  32位, 在linux...
  • pfnie
  • pfnie
  • 2016年07月03日 09:29
  • 886

对日志数据中的上下行流量信息汇总---分区统计

需求: 对日志数据中的上下行流量信息汇总---分区统计 根据归属地输出流量统计数据结果到不同文件,以便于在查询统计结果时可以定位到省级范围进行 分析: Mapreduce中会将map输出的...
  • tian_qing_lei
  • tian_qing_lei
  • 2017年07月11日 00:11
  • 271

Android测量指定应用程序的上下行流量

参考:http://xlover.iteye.com/blog/1358301  Android2.3之后把数据流量监控封装到了Android.net.TrafficStats类中,原理是读取系...
  • u010037124
  • u010037124
  • 2014年08月10日 11:48
  • 1184

Android Wi-Fi StatusBar(状态栏)流量上下行图标显示流程

一、背景介绍 打开wifi连接上ap在状态栏里面期望图标显示如下: 以下图片所在的目录为:LINUX/android/base/packages/SystemUI/res/draw...
  • xiaoxiangyuhai
  • xiaoxiangyuhai
  • 2017年07月27日 12:38
  • 1174

用MapReduce处理一组流量数据,并按总流量排序

用MapReduce处理一组流量数据、并排序
  • jiang0426
  • jiang0426
  • 2016年05月13日 14:40
  • 901

【Android】性能测试之获取Android流量数据

流量: android4.0以上版本可以用/proc/uid_stat/$uid/tcp_rcv和/proc/uid_stat/$uid/tcp_snd来获取某个程序的上下行流量;而4.0以下版本要用...
  • u013948858
  • u013948858
  • 2017年07月25日 15:57
  • 671

mapreduce流量汇总程序

Demo地址flow.log文件 1363157985066 13726230503 00-FD-07-A4-72-B8:CMCC 120.196.100.82 i02.c.aliim...
  • G290095142
  • G290095142
  • 2017年10月20日 14:26
  • 106

利用iptables命令监控端口流量

端口流量监控
  • ikacarrot
  • ikacarrot
  • 2017年10月24日 21:57
  • 319
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:mapreduce对日志数据上下行流量汇总
举报原因:
原因补充:

(最多只允许输入30个字)