Spark练习之通过Spark Streaming实时计算wordcount程序

Spark练习之通过Spark Streaming实时计算wordcount程序

  • Java版本
  • Scala版本
  • pom.xml

Java版本

import org.apache.spark.SparkConf;
import org.apache.spark.api.java.function.FlatMapFunction;
import org.apache.spark.api.java.function.Function2;
import org.apache.spark.api.java.function.PairFunction;
import org.apache.spark.streaming.Durations;
import org.apache.spark.streaming.api.java.JavaDStream;
import org.apache.spark.streaming.api.java.JavaPairDStream;
import org.apache.spark.streaming.api.java.JavaReceiverInputDStream;
import org.apache.spark.streaming.api.java.JavaStreamingContext;
import scala.Tuple2;

import java.util.Iterator;

/**
 * 实时wordcount程序
 */
public class JavaSparkStreaming {

    public static void main(String[] args) throws InterruptedException {
        //创建SparkConf对象
        //要给它设置一个Master属性,但是我们测试的时候使用local模式
        //local后面必须跟一个方括号,里面填写一个数字,数字代表了我们用几个线程来执行
        //我们的spark streaming程序
        SparkConf conf = new SparkConf().setMaster("local[2]").setAppName("JavaSparkStreaming");
        //创建JavaStreamingContext对象
        //类似于Spark Core中的JavaSparkContext,类似于Spark SQL中的SQLContext
        //该对象除了接收SparkConf对象外
        //还必须接收一个batch interval参数,就是说,每手机多长时间的数据,划分为一个batch进行处理
        //当前设置为1秒
        JavaStreamingContext jssc = new JavaStreamingContext(conf, Durations.seconds(1));

        //首先,创建输入DStream,代表了一个从数据源(比如kafka、socket)来的持续不断的实时数据流
        //调用JavaStreamingContext的socketTextStream()方法,创建一个数据源为socket网络端口的数据流
        //JavaReceiverInputDStream代表了一个输入的DStream
        //socketTextStream()方法接收两个基本参数,第一个是监听那个主机上的端口,第二个是监听哪个端口
        JavaReceiverInputDStream lines = jssc.socketTextStream("localhost", 9999);

        //至此,可以理解为JavaReceiverInputDStream中的,每隔一秒,会有一个RDD
        //其中封装了这一秒发送过来的数据
        //RDD的元素类型为String,即一行一行的文本
        //所以,这里JavaReceiverInputDStream的泛型类型为,其实代表了底层的RDD的泛型类型

        //开始对接收到的数据,执行计算,使用Spark Core提供的算子,执行应用在DStream中即可
        //在底层,实际上是会对DStream中的一个一个的RDD,执行我们应用在DStream上的算子
        //产生新的RDD,会作为新DStream中的RDD

        JavaDStream words = lines.flatMap(
                new FlatMapFunction() {
                    @Override
                    public Iterator call(String s) throws Exception {
                        return null;
                        //return Arrays.asList(line.spilt(" "));
                    }
                }
        );

        //此时,每秒的数据,一行一行的文本,就会被拆分为多个单词,words DStream中的RDD的元素类型
        //即为一个一个的单词

        //接着,开始进行flatMap、reduceByKey操作
        JavaPairDStream pairs = words.mapToPair(
                new PairFunction() {
                    @Override
                    public Tuple2 call(String word) throws Exception {
                        return new Tuple2(word, 1);
                    }
                }
        );
        //用Java Streaming开发程序和Java Core很像
        //唯一不同的是,Spark Core中的JavaRDD、JavaPairRDD,都变成了JavaDStream、JavaPairDStream

        JavaPairDStream wordCounts = pairs.reduceByKey(
                new Function2() {
                    @Override
                    public Integer call(Integer v1, Integer v2) throws Exception {
                        return v1 + v2;
                    }
                }
        );

        //每秒中发送到指定socket端口上的数据,都会被line DStream接收到
        //然后lines DStream会把每秒的数据,也就是一行一行的文本,诸如hello world,封装为一个RDD
        //然后,就会对每秒中对应的RDD,执行后续的一系列算子操作
        //比如,对Lines RDD执行了flatMap之后,得到了一个words RDD,作为words DStream中的一个RDD
        //以此类推,直到生成最后一个wordCount RDD,作为wordCounts DStream中的一个RDD
        //此时,就得到了每秒钟发送过来的数据的单词统计
        //注意:Spark Streaming的计算模型,决定了我们必须自己来进行中间缓存的控制
        //比如写入redis等缓存
        //它的计算模型跟storm是完全不同的,storm是自己编写的一个一个的程序,运行在节点上
        //相当于一个一个的对象,可以自己在对象中控制缓存
        //但是Spark本身是函数式编程的计算模型,所以,比如在words或pairs DStream中
        //没法实例变量进行缓存
        //此时,就只能将最后计算出的wordCounts中的一个一个的RDD,写入外部的缓存,或者持久化DB

        //最后,每次计算完,都打印一下这一秒钟的单词技术情况
        //并休眠5秒钟,以便于我们测试和观察

        Thread.sleep(5000);
        wordCounts.print();

        //对JavaStreamingContext进行后续处理
        //必须调用JavaStreamingContext的start()方法,整个Spark Steaming Application才会启动执行
        //否则不会执行
        jssc.start();
        jssc.awaitTermination();
        jssc.close();

    }
}

Scala版本

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

/**
  * wordcount
  */
object ScalaSparkStreaming {

  def main(args: Array[String]): Unit = {
    val conf = new SparkConf().setMaster("local[2]").setMaster("ScalaSparkStreaming")

    //scala中,创建的是StreamingContext
    val ssc = new StreamingContext(conf, Seconds(1))

    val lines = ssc.socketTextStream("localhost", 9999)
    val words = lines.flatMap {
      _.split(" ")
    }
    val pairs = words.map {
      word => (word, 1)
    }
    val wordCounts = pairs.reduceByKey {
      _ + _
    }

    Thread.sleep(5000)
    wordCounts.print()

    ssc.start()
    ssc.awaitTermination()

  }
}

pom.xml

切记要对应好Spark 和 Scala的版本。



    4.0.0

    spark
    com.spark
    1.0-SNAPSHOT

    SparkTest
    http://maven.apache.org

    
        1.8
        1.8
        2.3.0
        2.6.4
        UTF-8
    

    
        
        
            org.apache.spark
            spark-core_2.11
            ${spark.version}
        
        
            org.apache.spark
            spark-sql_2.11
            
        
        
            org.apache.spark
            spark-streaming_2.11
            ${spark.version}
        
        
        
            org.apache.hadoop
            hadoop-client
            ${hadoop.version}
        
    
    
        
            
                
                
                    org.apache.maven.plugins
                    maven-compiler-plugin
                    3.5.1
                
            
        
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                
                    
                        compile
                        
                            compile
                        
                    
                
            
            
            
                org.apache.maven.plugins
                maven-shade-plugin
                2.4.3
                
                    
                        package
                        
                            shade
                        
                        
                            
                                
                                    *:*
                                    
                                        META-INF/*.SF
                                        META-INF/*.DSA
                                        META-INF/*.RSA
                                    
                                
                            
                        
                    
                
            
        
    


你可能感兴趣的:(大数据,➹➹➹⑤Spark)