大数据IMF传奇行动绝密课程第94课:SparkStreaming实现广告计费系统中在线黑名单过滤实战

SparkStreaming实现广告计费系统中在线黑名单过滤实战

1、在线广告黑名单过滤实现解析
2、SparkStreaming实现在线黑名单过滤实战

package com.tom.spark.sparkstreaming

import org.apache.spark.SparkConf
import org.apache.spark.streaming.{Durations, StreamingContext}

/**
  * 使用Scala开发集群运行的Spark在线黑名单过滤程序
  *
  * 背景描述:在广告点击计费系统中我们在线过滤掉黑名单的点击,进而保护广告商的利益,只进行
  * 有效的广告点击计费,或者在防刷评分(或者流量)系统,过滤掉无效的投票或者评分或者流量;
  * 实现技术:使用Transform API直接基于RDD编程,进行join操作
  */
object OnlineBlackListFilter {
  def main(args: Array[String]): Unit = {
    val conf = new SparkConf().setAppName("OnlineBlackListFilter").setMaster("local[2]")
    val ssc = new StreamingContext(conf, Durations.seconds(30))
    //黑名单数据准备,实际上黑名单一般都是动态的,例如在Redis或者数据库中,黑名单的生成
    //往往有复杂的业务逻辑,具体情况算法不同,但是在Spark Streaming进行处理的时候每次都
    //能够访问完整的信息
    val blackList = Array(("hadoop", true),("mahout", true))
    val blackListRDD = ssc.sparkContext.parallelize(blackList, 3)
    val addClickStream = ssc.socketTextStream("Master", 9999)
    //此处模拟的广告点击的每条数据的格式为time, name
    //此处map操作的结果是name,(time,name)的格式
    val adsClickStreamFormatted = addClickStream.map(ads => {
      (ads.split(" ")(1), ads)
    })
    adsClickStreamFormatted.transform(userClickRDD => {
      // 通过leftOuterJoin操作既保留了左侧用户广告点击内容的RDD的所有内容,又获得了响应点击的内容是否在黑名单中
      val joinedBlackListRDD = userClickRDD.leftOuterJoin(blackListRDD)
      // 通过filter过滤的时候,其输入元素是一个Tuple,(name,((time,name), boolean))
      // 其中第一个元素是黑名单的名称,第二个元素的第二个元素是进行leftOuterJoin的时候
      // 是否存在值,如果存在的话,表明当前元素广告点击是黑名单,需要过滤掉,否则的话
      // 则是有效点击内容
      val validClicked = joinedBlackListRDD.filter(joinedItem => {
        !joinedItem._2._2.getOrElse(false)
      })
      validClicked.map(_._2._1)
    }).print
    //计算后的有效数据一般都会写入Kafka中,下游的计费系统会从Kafka中Pull到有效数据进行计费
    ssc.start()
    ssc.awaitTermination()
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值