一、大數(shù)據(jù)是什么?
大數(shù)據(jù),big data,《大數(shù)據(jù)》一書對大數(shù)據(jù)這么定義,大數(shù)據(jù)是指不能用隨機分析法(抽樣調查)這樣捷徑,而采用所有數(shù)據(jù)進行分析處理。
這句話至少傳遞兩種信息:
1、大數(shù)據(jù)是海量的數(shù)據(jù)
2、大數(shù)據(jù)處理無捷徑,對分析處理技術提出了更高的要求
二、大數(shù)據(jù)的處理流程
下圖是數(shù)據(jù)處理流程:關注作者:需要大數(shù)據(jù)學習視頻資料,其他文章可以找到大神
1、底層是數(shù)以千億計的數(shù)據(jù)源,數(shù)據(jù)源可以是SCM(供應鏈數(shù)據(jù)),4PL(物流數(shù)據(jù)),CRM(客戶數(shù)據(jù)),網(wǎng)站日志以及其他的數(shù)據(jù)
2、第二層是數(shù)據(jù)加工層,數(shù)據(jù)工程師對數(shù)據(jù)源按照標準的統(tǒng)計口徑和指標對數(shù)據(jù)進行抽取、清洗、轉化、裝載(整個過程簡稱ELT)
3、第三層是數(shù)據(jù)倉庫,加工后的數(shù)據(jù)流入數(shù)據(jù)倉庫,進行整合和存儲,形成一個又一個數(shù)據(jù)集市。
數(shù)據(jù)集市,指分類存儲數(shù)據(jù)的集合,即按照不同部門或用戶的需求存儲數(shù)據(jù)。
4、第四層是BI(商業(yè)智能),按照業(yè)務需求,對數(shù)據(jù)進行分析建模、挖掘、運算,輸出統(tǒng)一的數(shù)據(jù)分析平臺
5、第五層是數(shù)據(jù)訪問層,對不同的需求方開放不同的數(shù)據(jù)角色和權限,以數(shù)據(jù)驅動業(yè)務。
大數(shù)據(jù)的量級,決定了大數(shù)據(jù)處理及應用的難度,需要利用特定的技術工具去處理大數(shù)據(jù)。
三、大數(shù)據(jù)處理技術
以最常使用的Hadoop為例:
Hadoop是Apache公司開發(fā)的一個開源框架,它允許在整個集群使用簡單編程模型計算機的分布式環(huán)境存儲并處理大數(shù)據(jù)。
集群是指,2臺或2臺以上服務器構建節(jié)點,提供數(shù)據(jù)服務。單臺服務器,無法處理海量的大數(shù)據(jù)。服務器越多,集群的威力越大。
Hadoop類似于一個數(shù)據(jù)生態(tài)圈,不同的模塊各司其職。下圖是Hadoop官網(wǎng)的生態(tài)圖。
Hadoop的LOGO是一只靈活的大象。關于LOGO的來源,網(wǎng)上眾說紛紜,有人說,是因為大象象征龐然大物,指代大數(shù)據(jù),Hadoop讓大數(shù)據(jù)變得靈活。而官方蓋章,LOGO來源于創(chuàng)始人Doug Cutting的孩子曾為一個大象玩具取名hadoop。
從上圖可以看出,Hadoop的核心是HDFS,YARN和Map Reduce,下面和大家講一講,幾個主要模塊的含義和功能。
1、HDFS(分布式文件存儲系統(tǒng))
數(shù)據(jù)以塊的形式,分布在集群的不同節(jié)點。在使用HDFS時,無需關心數(shù)據(jù)是存儲在哪個節(jié)點上、或者是從哪個節(jié)點從獲取的,只需像使用本地文件系統(tǒng)一樣管理和存儲文件系統(tǒng)中的數(shù)據(jù)。
2、Map Reduce(分布式計算框架)
分布式計算框架將復雜的數(shù)據(jù)集分發(fā)給不同的節(jié)點去操作,每個節(jié)點會周期性的返回它所完成的工作和最新的狀態(tài)。大家可以結合下圖理解Map Reduce原理:
計算機要對輸入的單詞進行計數(shù):
如果采用集中式計算方式,我們要先算出一個單詞如Deer出現(xiàn)了多少次,再算另一個單詞出現(xiàn)了多少次,直到所有單詞統(tǒng)計完畢,將浪費大量的時間和資源。
如果采用分布式計算方式,計算將變得高效。我們將數(shù)據(jù)隨機分配給三個節(jié)點,由節(jié)點去分別統(tǒng)計各自處理的數(shù)據(jù)中單詞出現(xiàn)的次數(shù),再將相同的單詞進行聚合,輸出最后的結果。
3、YARN(資源調度器)
相當于電腦的任務管理器,對資源進行管理和調度。
4、HBASE(分布式數(shù)據(jù)庫)
HBase是非關系型數(shù)據(jù)庫(Nosql),在某些業(yè)務場景下,數(shù)據(jù)存儲查詢在Hbase的使用效率更高。
關于關系型數(shù)據(jù)庫和菲關系型數(shù)據(jù)庫的區(qū)別,會在以后的文章進行詳述。
5、HIVE(數(shù)據(jù)倉庫)
HIVE是基于Hadoop的一個數(shù)據(jù)倉庫工具,可以用SQL的語言轉化成Map Reduce任務對hdfs數(shù)據(jù)的查詢分析。HIVE的好處在于,使用者無需寫Map Reduce任務,只需要掌握SQL即可完成查詢分析工作。
6、 Spark(大數(shù)據(jù)計算引擎)
Spark是專為大規(guī)模數(shù)據(jù)處理而設計的快速通用的計算引擎
7、Mahout(機器學習挖掘庫)
Mahout是一個可擴展的機器學習和數(shù)據(jù)挖掘庫