提及大數據,不少人都能聊上一會,但要是問大數據核心技術有哪些,估計不少人就說不上一二來了。ios
從機器學習到數據可視化,大數據發展至今已經擁有了一套至關成熟的技術樹,不一樣的技術層面有着不一樣的技術架構,並且每一年還會涌現出新的技術名詞。面對如此龐雜的技術架構,不少第一次接觸大數據的小白幾乎都是望而生畏的。算法
其實想要知道大數據有哪些核心技術很簡單,無非三個過程:取數據、算數據、用數據。這麼說可能仍是有人以爲太空泛,簡單來講從大數據的生命週期來看,無外乎四個方面:大數據採集、大數據預處理、大數據存儲、大數據分析,共同組成了大數據生命週期裏最核心的技術,下面分開來講:數據庫
1、大數據採集
大數據採集,即對各類來源的結構化和非結構化海量數據,所進行的採集。編程
數據庫採集:流行的有Sqoop和ETL,傳統的關係型數據庫MySQL和Oracle 也依然充當着許多企業的數據存儲方式。固然了,目前對於開源的Kettle和Talend自己,也集成了大數據集成內容,可實現hdfs,hbase和主流Nosq數據庫之間的數據同步和集成。
網絡數據採集:一種藉助網絡爬蟲或網站公開API,從網頁獲取非結構化或半結構化數據,並將其統一結構化爲本地數據的數據採集方式。
文件採集:包括實時文件採集和處理技術flume、基於ELK的日誌採集和增量採集等等。
推薦大數據學習交流裙 606八五九705天天晚上20:10會有大數據直播課程,專一大數據開發課程,數據分析方法,大數據編程,大數據倉庫,大數據案例,人工智能,數據挖掘都是純乾貨分享,天天學一點技術知識。
2、大數據預處理
大數據預處理,指的是在進行數據分析以前,先對採集到的原始數據所進行的諸如「清洗、填補、平滑、合併、規格化、一致性檢驗」等一系列操做,旨在提升數據質量,爲後期分析工做奠基基礎。數據預處理主要包括四個部分:服務器
數據清理、數據集成、數據轉換、數據規約。網絡
數據清理:指利用ETL等清洗工具,對有遺漏數據(缺乏感興趣的屬性)、噪音數據(數據中存在着錯誤、或偏離指望值的數據)、不一致數據進行處理。
數據集成:是指將不一樣數據源中的數據,合併存放到統一數據庫的,存儲方法,着重解決三個問題:模式匹配、數據冗餘、數據值衝突檢測與處理。
數據轉換:是指對所抽取出來的數據中存在的不一致,進行處理的過程。它同時包含了~數據清洗的工做,即根據業務規則對異常數據進行清洗,以保證後續分析結果準確性
數據規約:是指在最大限度保持數據原貌的基礎上,最大限度精簡數據量,以獲得較小數據集的操做,包括:數據方彙集、維規約、數據壓縮、數值規約、概念分層等。
3、大數據存儲
大數據存儲,指用存儲器,以數據庫的形式,存儲採集到的數據的過程,包含三種典型路線:架構
一、基於MPP架構的新型數據庫集羣框架
採用Shared Nothing架構,結合MPP架構的高效分佈式計算模式,經過列存儲、粗粒度索引等多項大數據處理技術,重點面向行業大數據所展開的數據存儲方式。具備低成本、高性能、高擴展性等特色,在企業分析類應用領域有着普遍的應用。機器學習
較之傳統數據庫,其基於MPP產品的PB級數據分析能力,有着顯著的優越性。天然,MPP數據庫,也成爲了企業新一代數據倉庫的最佳選擇。分佈式
二、基於Hadoop的技術擴展和封裝
基於Hadoop的技術擴展和封裝,是針對傳統關係型數據庫難以處理的數據和場景(針對非結構化數據的存儲和計算等),利用Hadoop開源優點及相關特性(善於處理非結構、半結構化數據、複雜的ETL流程、複雜的數據挖掘和計算模型等),衍生出相關大數據技術的過程。
伴隨着技術進步,其應用場景也將逐步擴大,目前最爲典型的應用場景:經過擴展和封裝 Hadoop來實現對互聯網大數據存儲、分析的支撐,其中涉及了幾十種NoSQL技術。
三、大數據一體機
這是一種專爲大數據的分析處理而設計的軟、硬件結合的產品。它由一組集成的服務器、存儲設備、操做系統、數據庫管理系統,以及爲數據查詢、處理、分析而預安裝和優化的軟件組成,具備良好的穩定性和縱向擴展性。
4、大數據分析挖掘
從可視化分析、數據挖掘算法、預測性分析、語義引擎、數據質量管理等方面,對雜亂無章的數據,進行萃取、提煉和分析的過程。
一、可視化分析
可視化分析,指藉助圖形化手段,清晰並有效傳達與溝通訊息的分析手段。主要應用於海量數據關聯分析,即藉助可視化數據分析平臺,對分散異構數據進行關聯分析,並作出完整分析圖表的過程。
FineBI可視化
二、數據挖掘算法
數據挖掘算法,即經過建立數據挖掘模型,而對數據進行試探和計算的,數據分析手段。它是大數據分析的理論核心。
數據挖掘算法多種多樣,且不一樣算法因基於不一樣的數據類型和格式,會呈現出不一樣的數據特色。但通常來說,建立模型的過程倒是類似的,即首先分析用戶提供的數據,而後針對特定類型的模式和趨勢進行查找,並用分析結果定義建立挖掘模型的最佳參數,並將這些參數應用於整個數據集,以提取可行模式和詳細統計信息。
三、預測性分析
預測性分析,是大數據分析最重要的應用領域之一,經過結合多種高級分析功能(特別統計分析、預測建模、數據挖掘、文本分析、實體分析、優化、實時評分、機器學習等),達到預測不肯定事件的目的。
幫助分用戶析結構化和非結構化數據中的趨勢、模式和關係,並運用這些指標來預測未來事件,爲採起措施提供依據。
四、語義引擎
語義引擎,指經過爲已有數據添加語義的操做,提升用戶互聯網搜索體驗。
五、數據質量管理
指對數據全生命週期的每一個階段(計劃、獲取、存儲、共享、維護、應用、消亡等)中可能引起的各種數據質量問題,進行識別、度量、監控、預警等操做,以提升數據質量的一系列管理活動。
————————分割線————————
以上是從大的方面來說,具體來講大數據的框架技術有不少,這裏列舉其中一些:
文件存儲:Hadoop HDFS、Tachyon、KFS
離線計算:Hadoop MapReduce、Spark
流式、實時計算:Storm、Spark Streaming、S四、Heron
K-V、NOSQL數據庫:HBase、Redis、MongoDB
資源管理:YARN、Mesos
日誌收集:Flume、Scribe、Logstash、Kibana
消息系統:Kafka、StormMQ、ZeroMQ、RabbitMQ
查詢分析:Hive、Impala、Pig、Presto、Phoenix、SparkSQL、Drill、Flink、Kylin、Druid
分佈式協調服務:Zookeeper
集羣管理與監控:Ambari、Ganglia、Nagios、Cloudera Manager
數據挖掘、機器學習:Mahout、Spark MLLib
數據同步:Sqoop
任務調度:Oozie
·····