基本介紹
Apache Spark是專為大規模數據處理而設計的快速通用的計算引擎 。現在形成一個高速發展套用廣泛的生態系統。
特點
Spark 主要有三個特點 :
首先,高級 API 剝離了對集群本身的關注,Spark 套用開發者可以專注於套用所要做的計算本身。
其次,Spark 很快,支持互動式計算和複雜算法。
最後,Spark 是一個通用引擎,可用它來完成各種各樣的運算,包括 SQL 查詢、文本處理、機器學習等,而在 Spark 出現之前,我們一般需要學習各種各樣的引擎來分別處理這些需求。
性能特點
•更快的速度
記憶體計算下,Spark 比 Hadoop 快100倍。
•易用性
Spark 提供了80多個高級運算符。
•通用性
Spark 提供了大量的庫,包括SQL、DataFrames、MLlib、GraphX、Spark Streaming。 開發者可以在同一個應用程式中無縫組合使用這些庫。
•支持多種資源管理器
Spark 支持 Hadoop YARN,Apache Mesos,及其自帶的獨立集群管理器
•Spark生態系統
•Shark:Shark基本上就是在Spark的框架基礎上提供和Hive一樣的HiveQL命令接口,為了最大程度的保持和Hive的兼容性,Spark使用了Hive的API來實現query Parsing和 Logic Plan generation,最後的PhysicalPlan execution階段用Spark代替HadoopMapReduce。通過配置Shark參數,Shark可以自動在記憶體中快取特定的RDD,實現數據重用,進而加快特定數據集的檢索。同時,Shark通過UDF用戶自定義函式實現特定的數據分析學習算法,使得SQL數據查詢和運算分析能結合在一起,最大化RDD的重複使用。
•SparkR:SparkR是一個為R提供了輕量級的Spark前端的R包。 SparkR提供了一個分散式的data frame數據結構,解決了 R中的data frame只能在單機中使用的瓶頸,它和R中的data frame 一樣支持許多操作,比如select,filter,aggregate等等。(類似dplyr包中的功能)這很好的解決了R的大數據級瓶頸問題。 SparkR也支持分散式的機器學習算法,比如使用MLib機器學習庫。 SparkR為Spark引入了R語言社區的活力,吸引了大量的數據科學家開始在Spark平台上直接開始數據分析之旅。
基本原理
Spark Streaming:構建在Spark上處理Stream數據的框架,基本的原理是將Stream數據分成小的時間片斷(幾秒),以類似batch批量處理的方式來處理這小部分數據。Spark Streaming構建在Spark上,一方面是因為Spark的低延遲執行引擎(100ms+),雖然比不上專門的流式數據處理軟體,也可以用於實時計算,另一方面相比基於Record的其它處理框架(如Storm),一部分窄依賴的RDD數據集可以從源數據重新計算達到容錯處理目的。此外小批量處理的方式使得它可以同時兼容批量和實時數據處理的邏輯和算法。方便了一些需要歷史數據和實時數據聯合分析的特定套用場合。
計算方法
•Bagel: Pregel on Spark,可以用Spark進行圖計算,這是個非常有用的小項目。Bagel自帶了一個例子,實現了Google的PageRank算法。
•當下Spark已不止步於實時計算,目標直指通用大數據處理平台,而終止Shark,開啟SparkSQL或許已經初見端倪。
•近幾年來,大數據機器學習和數據挖掘的並行化算法研究成為大數據領域一個較為重要的研究熱點。早幾年國內外研究者和業界比較關注的是在 Hadoop 平台上的並行化算法設計。然而, HadoopMapReduce 平台由於網路和磁碟讀寫開銷大,難以高效地實現需要大量疊代計算的機器學習並行化算法。隨著 UC Berkeley AMPLab 推出的新一代大數據平台 Spark 系統的出現和逐步發展成熟,近年來國內外開始關注在 Spark 平台上如何實現各種機器學習和數據挖掘並行化算法設計。為了方便一般套用領域的數據分析人員使用所熟悉的 R 語言在 Spark 平台上完成數據分析,Spark 提供了一個稱為 SparkR 的編程接口,使得一般套用領域的數據分析人員可以在 R 語言的環境裡方便地使用 Spark 的並行化編程接口和強大計算能力。