博客园 - 泰山不老生
uuid:24b78886-0ed1-41c2-8670-e3f31dcf42c4;id=10284
2019-02-28T06:50:34Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
feed.cnblogs.com
https://www.cnblogs.com/jiaan-geng/p/10313068.html
Spark2.1.0——内置Web框架详解 - 泰山不老生
<img src="http://spark.apache.org/images/spark-logo-trademark.png" class="desc_img">任何系统都需要提供监控功能,否则在运行期间发生一些异常时,我们将会束手无策。也许有人说,可以增加日志来解决这个问题。日志只能解决你的程序逻辑在运行期的监控,进而发现Bug,以及提供对业务有帮助的调试信息。当你的JVM进程奔溃或者程序响应速度很慢时,这些日志将毫无用处。好在JVM提供了jstat、jstack、jinfo、jmap、jhat等工具帮助我们分析,更有VisualVM的可视化界面以更加直观的方式对JVM运行期的状况进行监控。此外,像Tomcat、Hadoop等服务都提供了基于Web的监控页面,用浏览器能访问具有样式及布局,并提供丰富监控数据的页面无疑是一种简单、高效的方式。
2019-02-28T06:45:00Z
2019-02-28T06:45:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】<img src="http://spark.apache.org/images/spark-logo-trademark.png" class="desc_img">任何系统都需要提供监控功能,否则在运行期间发生一些异常时,我们将会束手无策。也许有人说,可以增加日志来解决这个问题。日志只能解决你的程序逻辑在运行期的监控,进而发现Bug,以及提供对业务有帮助的调试信息。当你的JVM进程奔溃或者程序响应速度很慢时,这些日志将毫无用处。好在JVM提供了jstat、jstack、jinfo、jmap、jhat等工具帮助我们分析,更有VisualVM的可视化界面以更加直观的方式对JVM运行期的状况进行监控。此外,像Tomcat、Hadoop等服务都提供了基于Web的监控页面,用浏览器能访问具有样式及布局,并提供丰富监控数据的页面无疑是一种简单、高效的方式。 <a href="https://www.cnblogs.com/jiaan-geng/p/10313068.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/10231702.html
Spark2.1.0——深入浅出度量系统 - 泰山不老生
对于一个系统而言,首先考虑要满足一些业务场景,并实现功能。随着系统功能越来越多,代码量级越来越高,系统的可维护性、可测试性、性能都会成为新的挑战,这时监控功能就变得越来越重要了。在国内,绝大多数IT公司的项目都以业务为导向,以完成功能为目标,这些项目在立项、设计、开发、上线的各个阶段,很少有人会考虑到监控的问题。
2019-01-07T02:18:00Z
2019-01-07T02:18:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】对于一个系统而言,首先考虑要满足一些业务场景,并实现功能。随着系统功能越来越多,代码量级越来越高,系统的可维护性、可测试性、性能都会成为新的挑战,这时监控功能就变得越来越重要了。在国内,绝大多数IT公司的项目都以业务为导向,以完成功能为目标,这些项目在立项、设计、开发、上线的各个阶段,很少有人会考虑到监控的问题。 <a href="https://www.cnblogs.com/jiaan-geng/p/10231702.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/10137655.html
Spark2.1.0——深入理解事件总线 - 泰山不老生
Spark程序在运行的过程中,Driver端的很多功能都依赖于事件的传递和处理,而事件总线在这中间发挥着至关重要的纽带作用。事件总线通过异步线程,提高了Driver执行的效率。
2018-12-19T02:58:00Z
2018-12-19T02:58:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】Spark程序在运行的过程中,Driver端的很多功能都依赖于事件的传递和处理,而事件总线在这中间发挥着至关重要的纽带作用。事件总线通过异步线程,提高了Driver执行的效率。 <a href="https://www.cnblogs.com/jiaan-geng/p/10137655.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/10006822.html
使用Akka构建集群(二) - 泰山不老生
在《使用Akka构建集群(一)》一文中通过简单集群监听器的例子演示了如何使用Akka搭建一个简单的集群,本文将介绍一个相对看来更符合我们对于集群使用的业务需求的例子。
2018-11-23T04:31:00Z
2018-11-23T04:31:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】在《使用Akka构建集群(一)》一文中通过简单集群监听器的例子演示了如何使用Akka搭建一个简单的集群,本文将介绍一个相对看来更符合我们对于集群使用的业务需求的例子。 <a href="https://www.cnblogs.com/jiaan-geng/p/10006822.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/9798078.html
Spark2.1.0——内置RPC框架详解 - 泰山不老生
在Spark中很多地方都涉及网络通信,比如Spark各个组件间的消息互通、用户文件与Jar包的上传、节点间的Shuffle过程、Block数据的复制与备份等。在Spark 0.x.x与Spark 1.x.x版本中,组件间的消息通信主要借助于Akka,使用Akka可以轻松的构建强有力的高并发与分布式应用。但是Akka在Spark 2.0.0版本中被移除了,https://img2018.cnblogs.com/blog/816981/201810/816981-20181016145505263-870721231.jpg
2018-11-05T10:57:00Z
2018-11-05T10:57:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】在Spark中很多地方都涉及网络通信,比如Spark各个组件间的消息互通、用户文件与Jar包的上传、节点间的Shuffle过程、Block数据的复制与备份等。在Spark 0.x.x与Spark 1.x.x版本中,组件间的消息通信主要借助于Akka,使用Akka可以轻松的构建强有力的高并发与分布式应用。但是Akka在Spark 2.0.0版本中被移除了,https://img2018.cnblogs.com/blog/816981/201810/816981-20181016145505263-870721231.jpg <a href="https://www.cnblogs.com/jiaan-geng/p/9798078.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/9708246.html
Spark2.1.0模型设计与基本架构(下) - 泰山不老生
每项技术的诞生都会由某种社会需求所驱动,Spark正是在实时计算的大量需求下诞生的。Spark借助其优秀的处理能力,可用性高,丰富的数据源支持等特点,在当前大数据领域变得火热,参与的开发者也越来越多。
2018-09-29T09:53:00Z
2018-09-29T09:53:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】每项技术的诞生都会由某种社会需求所驱动,Spark正是在实时计算的大量需求下诞生的。Spark借助其优秀的处理能力,可用性高,丰富的数据源支持等特点,在当前大数据领域变得火热,参与的开发者也越来越多。 <a href="https://www.cnblogs.com/jiaan-geng/p/9708246.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/9667571.html
Spark2.1.0模型设计与基本架构(上) - 泰山不老生
随着近十年互联网的迅猛发展,越来越多的人融入了互联网——利用搜索引擎查询词条或问题;社交圈子从现实搬到了Facebook、Twitter、微信等社交平台上;女孩子们现在少了逛街,多了在各大电商平台上的购买;喜欢棋牌的人能够在对战平台上找到世界各地的玩家对弈。在国内随着网民数量的持续增加,造成互联网公司的数据在体量、产生速度、多样性等方面呈现出巨大的变化。本文将对Spark的背景、基础知识、模块设计进行介绍。
2018-09-18T02:44:00Z
2018-09-18T02:44:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】随着近十年互联网的迅猛发展,越来越多的人融入了互联网——利用搜索引擎查询词条或问题;社交圈子从现实搬到了Facebook、Twitter、微信等社交平台上;女孩子们现在少了逛街,多了在各大电商平台上的购买;喜欢棋牌的人能够在对战平台上找到世界各地的玩家对弈。在国内随着网民数量的持续增加,造成互联网公司的数据在体量、产生速度、多样性等方面呈现出巨大的变化。本文将对Spark的背景、基础知识、模块设计进行介绍。 <a href="https://www.cnblogs.com/jiaan-geng/p/9667571.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/9065021.html
Spark2.1.0——剖析spark-shell - 泰山不老生
通过在spark-shell中执行word count的过程,让读者了解到可以使用spark-shell提交Spark作业。现在读者应该很想知道spark-shell究竟做了什么呢?本文将详细分析这其中的奥秘。
2018-06-13T02:14:00Z
2018-06-13T02:14:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】通过在spark-shell中执行word count的过程,让读者了解到可以使用spark-shell提交Spark作业。现在读者应该很想知道spark-shell究竟做了什么呢?本文将详细分析这其中的奥秘。 <a href="https://www.cnblogs.com/jiaan-geng/p/9065021.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/9127294.html
使用Akka构建集群(一) - 泰山不老生
Akka提供的非常吸引人的特性之一就是轻松构建自定义集群,这也是我要选择Akka的最基本原因之一。如果你不想敲太多代码,也可以通过简单的配置构建一个非常简单的集群。本文为说明Akka集群构建的学习成本低廉,以Akka官网的例子代码出发,进行简单改造后与Spring集成。
2018-06-07T03:39:00Z
2018-06-07T03:39:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】Akka提供的非常吸引人的特性之一就是轻松构建自定义集群,这也是我要选择Akka的最基本原因之一。如果你不想敲太多代码,也可以通过简单的配置构建一个非常简单的集群。本文为说明Akka集群构建的学习成本低廉,以Akka官网的例子代码出发,进行简单改造后与Spring集成。 <a href="https://www.cnblogs.com/jiaan-geng/p/9127294.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/8876822.html
使用Akka的远程调用 - 泰山不老生
正如其它RPC或者RMI框架那样,Akka也提供了远程调用的能力。服务端在监听的端口上接收客户端的调用。本文将在《Spring与Akka的集成》一文的基础上介绍Akka的remote调用,本文很多代码和例子来源于Akka官网的代码示例,也包含了一些适用于Spring集成的改造,本文旨在介绍Akka的远程调用的开发过程。
2018-05-28T03:15:00Z
2018-05-28T03:15:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】正如其它RPC或者RMI框架那样,Akka也提供了远程调用的能力。服务端在监听的端口上接收客户端的调用。本文将在《Spring与Akka的集成》一文的基础上介绍Akka的remote调用,本文很多代码和例子来源于Akka官网的代码示例,也包含了一些适用于Spring集成的改造,本文旨在介绍Akka的远程调用的开发过程。 <a href="https://www.cnblogs.com/jiaan-geng/p/8876822.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/9064994.html
Spark2.1.0——Spark初体验 - 泰山不老生
学习一个工具的最好途径,就是使用它。在IT领域,在深入了解一个系统的原理、实现细节之前,应当先准备好它的运行环境或者源码阅读环境。如果能在实际环境下安装和运行Spark,显然能够提升读者对于Spark的一些感受,对系统能有个大体的印象,有经验的工程师甚至能够猜出一些Spark在实现过程中采用的设计模式、编程模型。在准备好基本的Spark运行环境后应当实践一下,以便于在使用过程中提升读者对于Spark最直接的感触!本文通过Spark的基本使用,让读者对Spark能有初步的认识,便于引导读者逐步深入学习。
2018-05-21T07:48:00Z
2018-05-21T07:48:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】学习一个工具的最好途径,就是使用它。在IT领域,在深入了解一个系统的原理、实现细节之前,应当先准备好它的运行环境或者源码阅读环境。如果能在实际环境下安装和运行Spark,显然能够提升读者对于Spark的一些感受,对系统能有个大体的印象,有经验的工程师甚至能够猜出一些Spark在实现过程中采用的设计模式、编程模型。在准备好基本的Spark运行环境后应当实践一下,以便于在使用过程中提升读者对于Spark最直接的感触!本文通过Spark的基本使用,让读者对Spark能有初步的认识,便于引导读者逐步深入学习。 <a href="https://www.cnblogs.com/jiaan-geng/p/9064994.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/9064975.html
Spark2.1.0——运行环境准备 - 泰山不老生
学习一个工具的最好途径,就是使用它。在IT领域,在深入了解一个系统的原理、实现细节之前,应当先准备好它的运行环境或者源码阅读环境。如果能在实际环境下安装和运行Spark,显然能够提升读者对于Spark的一些感受,对系统能有个大体的印象,有经验的工程师甚至能够猜出一些Spark在实现过程中采用的设计模式、编程模型。
2018-05-21T02:14:00Z
2018-05-21T02:14:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】学习一个工具的最好途径,就是使用它。在IT领域,在深入了解一个系统的原理、实现细节之前,应当先准备好它的运行环境或者源码阅读环境。如果能在实际环境下安装和运行Spark,显然能够提升读者对于Spark的一些感受,对系统能有个大体的印象,有经验的工程师甚至能够猜出一些Spark在实现过程中采用的设计模式、编程模型。 <a href="https://www.cnblogs.com/jiaan-geng/p/9064975.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/8581312.html
Spring与Akka的集成 - 泰山不老生
近年来随着Spark的火热,Spark本身使用的开发语言Scala、用到的分布式内存文件系统Tachyon(现已更名为Alluxio)以及基于Actor并发编程模型的Akka都引起了大家的注意。了解过Akka或者Actor的人应该知道,这的确是一个很不错的框架,按照Akka官网的描述——使用Akka使得构建强有力的并发与分布式应用将更加容易。由于历史原因,很多Web系统在开发分布式服务时首先会选择RMI(Remote Method Invoke ,远程方法调用)、RPC(Remote Procedure Call Protocol,远程过程调用)或者使用JMS(Java Messaging Service,Java消息服务)。
2018-03-16T06:45:00Z
2018-03-16T06:45:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】近年来随着Spark的火热,Spark本身使用的开发语言Scala、用到的分布式内存文件系统Tachyon(现已更名为Alluxio)以及基于Actor并发编程模型的Akka都引起了大家的注意。了解过Akka或者Actor的人应该知道,这的确是一个很不错的框架,按照Akka官网的描述——使用Akka使得构建强有力的并发与分布式应用将更加容易。由于历史原因,很多Web系统在开发分布式服务时首先会选择RMI(Remote Method Invoke ,远程方法调用)、RPC(Remote Procedure Call Protocol,远程过程调用)或者使用JMS(Java Messaging Service,Java消息服务)。 <a href="https://www.cnblogs.com/jiaan-geng/p/8581312.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/5462144.html
Hadoop2.6.0配置参数查看小工具 - 泰山不老生
使用Hadoop进行离线分析或者数据挖掘的工程师,经常会需要对Hadoop集群或者mapreduce作业进行性能调优。性能调优的前提是需要能准确知道目前针对Hadoop集群或者mapreduce作业配置的参数。本文将针对这一需求,基于Hadoop开发一个简单实用的工具查询查看各种参数。
2016-07-27T01:39:00Z
2016-07-27T01:39:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】使用Hadoop进行离线分析或者数据挖掘的工程师,经常会需要对Hadoop集群或者mapreduce作业进行性能调优。性能调优的前提是需要能准确知道目前针对Hadoop集群或者mapreduce作业配置的参数。本文将针对这一需求,基于Hadoop开发一个简单实用的工具查询查看各种参数。 <a href="https://www.cnblogs.com/jiaan-geng/p/5462144.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/5462137.html
Hadoop2.6.0的FileInputFormat的任务切分原理分析(即如何控制FileInputFormat的map任务数量) - 泰山不老生
我在测试mapreduce任务时,发现相比于使用Job.setNumReduceTasks(int)控制reduce任务数量而言,控制map任务数量一直是一个困扰我的问题。好在经过很多摸索与实验,终于梳理出来,希望对在工作中进行Hadoop进行性能调优的新人们有个借鉴。本文只针对FileInputFormat的任务划分进行分析,其它类型的InputFormat的划分方式又各有不同。虽然如此,都可以按照本文类似的方法进行分析和总结。
2016-05-23T05:36:00Z
2016-05-23T05:36:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】我在测试mapreduce任务时,发现相比于使用Job.setNumReduceTasks(int)控制reduce任务数量而言,控制map任务数量一直是一个困扰我的问题。好在经过很多摸索与实验,终于梳理出来,希望对在工作中进行Hadoop进行性能调优的新人们有个借鉴。本文只针对FileInputFormat的任务划分进行分析,其它类型的InputFormat的划分方式又各有不同。虽然如此,都可以按照本文类似的方法进行分析和总结。 <a href="https://www.cnblogs.com/jiaan-geng/p/5462137.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/5445103.html
Hadoop2.6.0子项目hadoop-mapreduce-examples的简单介绍 - 泰山不老生
引文 学习Hadoop的同学们,一定知道如果运行Hadoop自带的各种例子,以大名鼎鼎的wordcount为例,你会输入以下命令: 当然,有些人还会用以下替代方式: 相比于原始的执行方式,使用jar命令方式,让我们不用再敲入繁琐的完整包路径。比如我们知道hadoop-mapreduce-exampl
2016-04-29T05:16:00Z
2016-04-29T05:16:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】引文 学习Hadoop的同学们,一定知道如果运行Hadoop自带的各种例子,以大名鼎鼎的wordcount为例,你会输入以下命令: 当然,有些人还会用以下替代方式: 相比于原始的执行方式,使用jar命令方式,让我们不用再敲入繁琐的完整包路径。比如我们知道hadoop-mapreduce-exampl <a href="https://www.cnblogs.com/jiaan-geng/p/5445103.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/5423160.html
Hadoop2.6.0的事件分类与实现 - 泰山不老生
说实在的,在阅读Hadoop YARN的源码之前,我对于java枚举的使用相形见绌。YARN中实现的事件在可读性、可维护性、可扩展性方面的工作都值得借鉴。
2016-04-27T07:19:00Z
2016-04-27T07:19:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】说实在的,在阅读Hadoop YARN的源码之前,我对于java枚举的使用相形见绌。YARN中实现的事件在可读性、可维护性、可扩展性方面的工作都值得借鉴。 <a href="https://www.cnblogs.com/jiaan-geng/p/5423160.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/5407287.html
Linux下Hadoop2.6.0集群环境的搭建 - 泰山不老生
本文旨在提供最基本的,可以用于在生产环境进行Hadoop、HDFS分布式环境的搭建,对自己是个总结和整理,也能方便新人学习使用。
2016-04-19T05:50:00Z
2016-04-19T05:50:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】本文旨在提供最基本的,可以用于在生产环境进行Hadoop、HDFS分布式环境的搭建,对自己是个总结和整理,也能方便新人学习使用。 <a href="https://www.cnblogs.com/jiaan-geng/p/5407287.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/5385993.html
Spark如何使用Akka实现进程、节点通信的简明介绍 - 泰山不老生
Akka是Actor编程模型的高级类库,类似于JDK 1.5之后越来越丰富的并发工具包,简化了程序员并发编程的难度。Akka是一款提供了用于构建高并发的、分布式的、可伸缩的、基于Java虚拟机的消息驱动应用的工具集和运行时环境。
2016-04-13T05:23:00Z
2016-04-13T05:23:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】Akka是Actor编程模型的高级类库,类似于JDK 1.5之后越来越丰富的并发工具包,简化了程序员并发编程的难度。Akka是一款提供了用于构建高并发的、分布式的、可伸缩的、基于Java虚拟机的消息驱动应用的工具集和运行时环境。 <a href="https://www.cnblogs.com/jiaan-geng/p/5385993.html" target="_blank">阅读全文</a>
https://www.cnblogs.com/jiaan-geng/p/5301129.html
Spark中常用工具类Utils的简明介绍 - 泰山不老生
《深入理解Spark:核心思想与源码分析》一书前言的内容请看链接《深入理解SPARK:核心思想与源码分析》一书正式出版上市 《深入理解Spark:核心思想与源码分析》一书第一章的内容请看链接《第1章 环境准备》 《深入理解Spark:核心思想与源码分析》一书第二章的内容请看链接《第2章 SPARK设
2016-03-23T06:44:00Z
2016-03-23T06:44:00Z
泰山不老生
https://www.cnblogs.com/jiaan-geng/
【摘要】《深入理解Spark:核心思想与源码分析》一书前言的内容请看链接《深入理解SPARK:核心思想与源码分析》一书正式出版上市 《深入理解Spark:核心思想与源码分析》一书第一章的内容请看链接《第1章 环境准备》 《深入理解Spark:核心思想与源码分析》一书第二章的内容请看链接《第2章 SPARK设 <a href="https://www.cnblogs.com/jiaan-geng/p/5301129.html" target="_blank">阅读全文</a>