学习大数据必须掌握的核心技术
大数据技术的体系庞大且复杂,基础的技术包含数据的采集、数据预处理、分布式存储、NoSQL数据库、数据仓库、机器学习、并行计算以及可视化等各种技术范畴和不同的技术层面。首先给出一个通用化的大数据处理框架,主要分为下面几个方面:数据采集与预处理、数据存储、数据清洗、数据查询分析和数据可视化。
1.数据采集与预处理
对于各种来源的数据,包括移动互联网数据、社交网络的数据等,这些结构化和非结构化的海量数据是零散的,也就是所谓的“数据孤岛”,此时的这些数据并没有什么意义。数据采集就是将这些数据写入数据仓库中,把零散的数据整合在一起,对这些数据综合起来进行分析。数据采集包括文件日志的采集、数据库日志的采集、关系型数据库的接入和应用程序的接入等。在数据量比较小的时候,可以写个定时的脚本将日志写入存储系统,但随着数据量的增长,这些方法无法提供数据安全保障,并且运维困难,需要更强壮的解决方案。
Flume NG作为实时日志收集系统,支持在日志系统中定制各类数据发送方,用于收集数据,同时,
对数据进行简单处理,并写到各种数据接收方(比如文本,HDFS,Hbase等)。Flume NG采用的是三层架构:Agent层、Collector层和Store 层,每一层均可水平拓展。其中Agent包含Source,Channel, Sink,Source用来消费(收集)数据源到Channel组件中,Channel作为中间临时存储,保存所有Source的组件信息,Sink从Channel中读取数据,读取成功之后会删除Channel中的信息。
Netease Data Canal(NDC)直译为网易数据运河系统,是网易针对结构化数据库的数据实时迁移、同步和订阅的平台化解决方案。它整合了网易过去在数据传输领域的各种工具和经验,将单机数据库、分布式数据库、OLAP系统以及下游应用通过数据链路串在一起。除了保障高效的数据传输外,NDC的设计遵循了单元化和平台化的设计哲学。
Logstash是开源的服务器端数据处理管道,能够同时从多个来源采集数据、转换数据,然后将数据发送到您最喜欢的“存储库”中。一般常用的存储库是Elasticsearch。Logstash支持各种输入选择,可以在同一时间从众多常用的数据来源中捕捉事件,能够以连续的流式传输方式,轻松地从您的日志、指标、Web 应用、数据存储以及各种AWS服务采集数据。
Sqoop用来将关系型数据库和Hadoop中的数据相互转
移,可以将一个关系型数据库(例如Mysql、Oracle)中的数据导入到Hadoop(例如HDFS,Hive,Hbase)中,也可以将Hadoop中的数据导入到关系型数据库(例如Mysql,Oracle)中。Sqoop启用
了一个MapReduce作业(极其容错的分布式并行计算)来执行任务。Sqoop的另一大优势是其传输大量结构化或半结构化数据的过程是完全自动化的。
流式计算是行业研究的一个热点,流式计算对多个高吞吐量的数据源进行实时的清洗、聚合和分析,可以对存在于社交网站、新闻等的数据信息流进行快速的处理并反馈,目前大数据流分析工具有很多,比如开源的Strom,Spark Streaming等。
Strom集结构是有一个主节点(nimbus)和多个工作节点(supervisor)组成的主从结构,主节点通过配置静态指定或者在运行时动态选举,nimbus与supervisor都是Storm提供的后台守护进程,之间的通信是结合Zookeeper的状态变更通知和监控通知来处理。nimbus进程的主要职责是管理、协调和监控集上运行的topology(包括topology的发布、任务指派、事件处理时重新指派任务等)。supervisor进程等待nimbus分配任务后生成并监控worker(jvm进程)执行任务。supervisor与worker 运行在不同的jvm上,如果由supervisor启动的某个worker因为错误异常退出(或被kill掉),supervisor会尝试重新生成新的worker进程。
使用上游模块的数据进行计算、统计、分析时,就可以使用消息系统,尤其是分布式消息系统。Kafka使用Scala进行编写,是一种分布式的、基于发布/订阅的消息系统。Kafka的设计理念之一就是同时提供离线处理和实时处理,以及将数据实时备份到另一个数据中心,Kafka可以有许多的生产者
和消费者分享多个主题,将消息以topic为单位进行归纳;Kafka发布消息的程序称为producer,也叫生产者,预订topics并消费消息的程序称为Consumer,也叫消费者;当Kafka以集的方式运行时,可以由一个服务或者多个服务组成,每个服务叫做一个broker,运行过程中producer通过网络将消息发送到Kafka集,集向消费者提供消息。Kafka通过Zookeeper管理集配置,选举leader,以及在ConsumerGroup发生变化时进行rebalance。Producer使用push模式将消息发布到broker,Consumer使用pull模式从broker订阅并消费消息。可以和Flume一起工作,如果需要将流式数据从Kafka转移到hadoop,可以使用Flume 代理Agent,将Kafka当做一个来源Source,这样可以从Kafka 读取数据到Hadoop。
Zookeeper是一个分布式的、开放源码的分布式应用程序协调服务,提供数据同步服务。它的作用主要有配置管理、名字服务、分布式锁和集管理。配置管理指的是在一个地方修改了配置,那么和这个地方配置相同的所有地方都可以获得变更,省去了手动拷贝配置的繁琐,还很好地保证了数据的可靠和一致性,同时它可以通过名字来获取资源或者服务的地址等信息,可以监控集中机器的变化,实现了类似于心跳机制的功能。
2.数据存储
Hadoop作为一个开源的框架,专为离线和大规模数据分析而设计,HDFS作为其核心的存储引擎,已被广泛用于数据存储。
HBase,是一个分布式的、面向列的开源数据库,可以认为是hdfs的封装,本质是数据存储、NoSQL数据库。HBase是一种Key/Value系统,部署在hdfs上,克服了hdfs在随机读写这个方面的缺点,与Hadoop一样,Hbase目标主要依靠横向扩展,通过不断增加廉价的商用服务器,来增加计算和存储能力。
Phoenix相当于一个Java中间件,帮助开发工程师能够像使用JDBC访问关系型数据库一样访问NoSQL数据库HBase。
Yarn是一种Hadoop资源管理器,可为上层应用提供统一的资源管理和调度,它的引入为集在利用率、资源统一管理和数据共享等方面带来了巨大好处。Yarn由几大组件构成:一个全局的资源管理器ResourceManager、ResourceManager的每个节点代理NodeManager、表示每个应用的Application以及每一个ApplicationMaster拥有多个Container在NodeManager上运行。
Mesos是一款开源的集管理软件,支持Hadoop,Elastic Search,Spark,Storm,Kafka等应用架构。
Redis是一种速度非常快的非关系数据库,可以存储键与5种不同类型的值之间的映射,可以将存储在内存的键值对数据持久化到硬盘中,使用复制特性来扩展性能,还可以使用客户端分片来扩展写性能。
延安市人民政府网站
Atlas是一个位于应用程序与MySQL之间的中间件。在后端DB看来,Atlas相当于连接它的客户端,在前端应用看来,Atlas相当于一个DB。Atlas作为服务端与应用程序通讯,它实现了MySQL的客户端和服务端协议,同时作为客户端与MySQL通信。它对应用程序屏蔽了DB的细节,同时为了降低MySQL负担,它还维护了连接池。Atlas启动后会创建多个线程,其中一个为主线程,其余为工作线程。主线程负责监听所有的客户端连接请求,工作线程只监听主线程的命令请求。
Kudu是围绕Hadoop生态圈建立的存储引擎,Kudu拥有和Hadoop生态圈共同的设计理念,它运行在普通的服务器上,可分布式规模化部署、并且满足工业界的高可用要求。其设计理念为fast analytics on fast data。作为一个开源的存储引擎,可以同时提供低延迟的随机读写和高效的数据分析能力。Kudu不但提供了行级的插入、更新和删除API,同时也提供了接近Parquet性能的批量扫描操作。使用同一份存储,既可以进行随机读写,也可以满足数据分析的要求。Kudu的应用场景很广泛,比如可以进行实时的数据分析,用于数据可能会存在变化的时序数据应用等。
在数据存储过程中,涉及到的数据表都是成千上百列,包含各种复杂的Query,推荐使用列式存储方
法,比如Parquent,ORC 等对数据进行压缩。Parquet可以支持灵活的压缩选项,显著减少磁盘上的存储。
3.数据清洗
MapReduce作为Hadoop的查询引擎,用于大规模数据集的并行计算,映射(Map)和归约(Reduce),是它的主要思想。它极大的方便了编程人员在不会分布式并行编程的情况下,将自己的程序运行在分布式系统中。
随着业务数据量的增多,需要进行训练和清洗的数据会变得越来越复杂,这个时候就需要任务调度系统,比如oozie或者azkaban,对关键任务进行调度和监控。
Oozie是用于Hadoop平台的一种工作流调度引擎,提供了RESTful API接口来接受用户的提交请求(提交工作流作业),当提交了Workflow后,由工作流引擎负责Workflow的执行以及状态的转换。用户在HDFS上部署好作业(MR作业),然后向Oozie提交Workflow,Oozie以异步方式将作业(MR作业)提交给Hadoop。这也是为什么当调用Oozie的RESTful接口提交作业之后能立即返回一个JobId的原因,用户程序不必等待作业执行完成(因为有些大作业可能会执行很久,几个小时甚至几天)。Oozie在后台以异步方式,再将workflow对应的Action提交给hadoop执行。
Azkaban也是一种工作流的控制引擎,可以用来解决有多个Hadoop或者Spark等离线计算任务之间的依赖关系问题。azkaban主要是由三部分构成:Relational Database,Azkaban Web Server和Azkaban Executor Server。Azkaban将大多数的状态信息都保存在MySQL中,Azkaban Web Server提供了Web UI,是Azkaban主要的管理者,包括project的管理、认证、调度以及对工作流执行过程中的监控等;Azkaban Executor Server用来调度工作流和任务,记录工作流或者任务的日志。
流计算任务的处理平台Sloth,是网易首个自研流计算平台,旨在解决公司内各产品日益增长的流计算需求。其特点是易用、实时和可靠,为用户节省技术方面(开发、运维)的投入,帮助用户专注于解决产品本身的流计算需求。
4.数据查询分析
Hive的核心工作就是把SQL语句翻译成MR程序,可以
将结构化的数据映射为一张数据库表,并提供HQL(Hive SQL)查询功能。Hive本身不存储和计算数据,它完全依赖于HDFS 和MapReduce。可以将Hive理解为一个客户端工具,将SQL操作转换为相应的MapReduce jobs,然后在Hadoop上面运行。Hive支持标准的SQL语法,免去了用户编写MapRedu
银行招聘考试内容ce程序的过程,它的出现可以让那些精通SQL技能,但是不熟悉MapReduce,编程能力较弱与不擅长Java语言的用户能够在HDFS大规模数据集上很方便地利用SQL语言查询、汇总、分析数据。
Hive是为大数据批量处理而生的,Hive的出现解决了传统的关系型数据库(MySql,Oracle)在大数据处理上的瓶颈。Hive 将执行计划分成map->shuffle->reduce->map->shuffle->reduce …的模型。如果一个Query会被编译成多轮MapReduce,则会有更多的写中间结果。由于MapReduce执行框架本身的特点,过多的中间过程会增加整个Query的执行时间。在Hive的运行过程中,用户只需要创建表,导入数据,编写SQL分析语句即可。剩下的过程由Hive框架自动的完成。
Impala是对Hive的一个补充,可以实现高效的SQL查询。使用Impala来实现SQL on Hadoop,用来进行大数据实时查询分析。通过熟悉的传统关系型数据库SQL风格来操作大数据,同时数据也是可以存储到HDFS和HBase中的。Impala没有再使用缓慢的Hive+MapReduce批处理,而是通过使用与商用并行关系数据库中类似的分布式查询引擎(由Query Planner,Query Coordinator,Query Exec Engine三部分组成),可以直接从HDFS或HBase中用SELECT,JOIN和统计函数查询数据,从而大大降低了延迟。Impala将整个查询分成一执行计划树,而不是一连串的MapReduce任务,相比Hive没了MapReduce 启动时间。
Hive适合于长时间的批处理查询分析,而Impala适合于实时交互式SQL查询,Impala给数据人员提供
了快速实验,验证想法的大数据分析工具,可以先使用Hive进行数据转换处理,之后使用Impala在Hive处理好后的数据集上进行快速的数据分析。总的来说:Impala把执行计划表现为一棵完整的执行计划树,可以更自然地分发执行计划到各个Impalad执行查询,而不用像Hive那样把它组合成管道型的map->reduce模式,以此
保证Impala有更好的并发
性和避免不必要的中间
sort与shuffle。但是Impala
不支持UDF,能处理的问
题有一定的限制。
Spark拥有Hadoop
MapReduce所具有的特
点,它将Job中间输出结果保存在内存中,从而不需要读取HDFS。Spark启用了内存分布数据集,除
辽宁工业大学
了能够提供交互式查询外,它还可以优化迭代工作负载。Spark是在Scala语言中实现的,它将Scala用作其应用程序框架。与Hadoop不同,Spark和Scala能够紧密集成,其中的Scala可以像操作本地集合对象一样轻松地操作分布式数据集。
Nutch是开源Java实现的搜索引擎。它提供了我们运行自己的搜索引擎所需的全部工具,包括全文搜索和Web爬虫。
Solr是用Java编写,运行在Servlet容器(如Apache Tomcat 或Jetty)的一个独立的企业级搜索应用的全文搜索服务器。它对外提供类似于Web-service的API接口,用户可以通过http 请求,向搜索引擎服务器提交一定格式的XML文件,生成索引;也可以通过Http Get操作提出查请求,并得到XML格式的返回结果。
Elasticsearch是一个开源的全文搜索引擎,基于Lucene的搜索服务器,可以快速的储存、搜索和分析海量的数据。设计用于云计算中,能够达到实时搜索、稳定、可靠、快速以及安装使用方便。
还涉及到一些机器学习语言,比如,Mahout主要目标是创建一些可伸缩的机器学习算法,供开发人员在Apache的许可下免费使用;深度学习框架Caffe以及使用数据流图进行数值计算的开源软件库TensorFlow等,常用的机器学习算法,比如贝叶斯、逻辑回归、决策树、神经网络和协同过滤等。
5.数据可视化
对接一些BI平台,将分析得到的数据进行可视化,用于指导决策服务。主流的BI平台比如,国外的敏捷BI Tableau,Qlikview,PowrerBI等,国内的SmallBI和新兴的网易有数等。
在上面的每一个阶段,对保障数据的安全都是不可忽视的问题。
基于网络身份认证的协议Kerberos,用来在非安全网络中,对个人通信以安全的手段进行身份认证,它允许某实体在非安全网络环境下通信,向另一个实体以一种安全的方式证明自己的身份。
控制权限的ranger是一个Hadoop集权限框架,提供操作、监控、管理复杂的数据权限,它提供一个集中的管理机制,管理基于yarn的Hadoop生态圈的所有数据权限。可以对Hadoop生态的组件如Hive,Hbase进行细粒度的数据访问控制。通过操作Ranger控制台,管理员可以轻松的通过配置策略来控制用户访问HDFS文件夹、HDFS文件、数据库、表和字段权限。这些策略可以为不同的用户和组来设置,同时权限可与hadoop无缝对接。
简单说大数据有三大核心技术:拿数据、算数据和卖数据。
首先做为大数据,拿不到大量数据都没用。现在由于机器学
云南招考频道录取查询入口
报考公务员年龄限制多大习的兴起,以及“万金油”算法的崛起,导致算法地位下降,数
■李荣1994-2019中国互联网流量争夺史
互联网进入中国的第25个年头,作为“数字地基”的流量,正在重构自己在互联网发展进程中的角扮演。
人口红利的消失,让互联网从业者谈流量变,如何破解流量桎梏成了新的全民话题。互联网电商巨头纷纷下乡刷墙,投资者表现出了无比清晰的流量导向,渴求流量的创业者被昂贵的成本压得喘不过气……
作为中国互联网基础流量运营风向标的“百度联盟峰会”,也将2019年的主题定为“百度联盟生态合作伙伴大会”,从流量联盟升级为用户联盟。似乎有意向外界告知:百度联盟不再是单纯的流量联盟,而是在百家号、短视频、智能小程序等产品的加持下,所开创的生态联盟。
不过,流量本身是否会带来焦虑,取决于我们理解“流量”的角度。早在10多年前就有创业者抱怨流量变贵,新网站获取流量的机会成本和边际成本如滚雪球一般,可最后还是诞生了这样或那样的超级APP。就算是在今天,有人抱怨流量生意越来越难做,不还是有人从下沉市场挖到了一桶又一桶金。
互联网的流量战争就像是一场雾里看花的游戏,看似不到门道,杂乱无章间却存在着某种必然,如果去扒一下中国互联网的流量争夺史,又总能到一些清晰的时间节点,乃至于总结出经验和规律。
1.精英时代
中工网1996年深秋,北京白颐路口竖起了一面硕大的牌子,上面写着:“中国人离信息高速公路还有多远?向北1500米。”沿着路标寻下去,会到一家名为瀛海威的公司,中国互联网曾经的标志性大旗。
可惜到了今天,瀛海威的名字听起来已经十分陌生。后来有媒体将瀛海威的落魄定义为“在大雾中领跑”,既选错了商业模式,又错了竞争对手。
在我们的文化中,对失败者向来少有溢美之词,却遗忘了特定的历史背景:1994年4月份,中国才开通了一条64K的国际专线。没有人知道流量为何物,甚至没有太多人去思考该如何从互联网中赚钱。
1994-2001年出现的互联网公司,被人熟记的仅剩下网易、搜狐、新浪、腾讯、阿里和百度等,知识存量再丰富一些的话,还可以说出天涯、猫扑和西祠等盛极一时的BBS。
在这些先驱或巨头身后,要么是张朝阳、李彦宏等见证了硅谷传奇的海归派,要么是丁磊、马化腾等走在潮流前沿的技术极客,唯一例外的可能就是“翻译社”起家的马云。
这样的结果并不值得意外,精英们比99%的人更早接触到了互联网,也深谙杨致远与DavidFilo制定的“游戏规则”。在只有几十万用户的小众世界里,相比于讨论“流量”,人们更愿意猜想互联网可以改变什么。萌芽期的中国互联网,可以说是一精英们掀起的“飓风革命”。
尽管新浪在1998年世界杯期间,就以24小时滚动播出新闻的形式,赚到了18万元的广告收益。可当2
000年科技股泡沫出现时,大量的网站死在了赚钱的临界点上,哪怕是名噪一时的新浪、网易和搜狐,最终摘掉“垃圾股”帽子的,不是当今互
据地位提高了。举个通俗的例子,就好比由于教育的发展,导致个人智力重要性降低,教育背景变得重要了,因为一般人按标准流程读个书,就能比牛顿懂得多了。谷歌就说:拿厉害的数据喂给一个一般的算法,很多情况下好于拿简单的数据喂给高级的算法。所以拿数据很重要,因为巧妇难为无米之炊啊!这就是为什么好多公司要烧钱抢入口、抢用户——
—就是为了争夺数据源。
其次就是算数据,如果数据拿到直接就有价值地话,那也就不需要公司了,政府直接赚外快就好了。所以数据在那里摆着,能挖出什么就各凭本事了。算数据就需要计算平台,数据怎么存(HDFS,S3,HBase,Cassandra),怎么算(Hadoop,Spark)就要靠程序员了。
再次就是卖得出去才能变现,比如《疑犯追踪》里面的李四和大锤,见人所未见,预测未来并趋利避害才是智能的终极目标以及存在意义,这个得靠大家一块儿琢磨。
其实个人觉得最后那个才是“核心技术”,什么Spark,Storm,Deep-Learning,
都是第二梯队的……当然,没有强大的算力做支撑,智能也无从说起。