week7中的前两节课的标题是”Actors are Distributed",讲了很多Akka Cluster的内容,同时也很难理解。

Roland Kuhn并没有讲太多Akka Cluster自身如何工作的细节,而是更关注于如何利用Akka Cluster来把Actor分布到不同的节点上,或许这么安排是因为Akka Cluster能讲的东西太多,而Coursera的课时不够。但是,从听众的角度来说,这节课只是初步明白了下Akka Cluster能干啥,但是想要自己用起来,特别是想了解其工作的机制,还需要自己再去看很多东西。在我看了下Akka的文档里关于Cluster的一章之后,发现不懂的地方更多了……好吧,不能再搞魔兽世界了!

鉴于不懂的地方太多,还是按照课程讲的顺序先过一遍,整理一下不懂的地方,以后分开研究。下面是课程的内容, 包括:课程PPT的内容,作者在讲课过程中一些重要的观点和我的一些理解。

Roland Kuhn在视频开头的时候,介绍了一下本周要讲的内容:

In this last week of the reactive programming course, we will focus first on something which was implicitly there already. Namely, that actors as independent agents of computation are by default distributed. Normally you run them just on different CPU's in the same system. But, there is nothing stopping you from running them on different network hosts, and we will do this in practice. This means, if you picture for example, people who are living on different continents that it takes some effort for them to agree on a common truth or a common decision. The same thing is true for actors and we call this eventual consistency. After that, we will talk about scalability and responsiveness and how you achieve these in an actor-based system. Rounding up all the four tenets of reactive programming, which were event-driven Scalable, resilient, and responsive.

在这reactive programming课程的最后一周,我们将会重点看一下已经暗自存在着的内容。也就是说,actor作为相互独立的计算单元,默认是分布式的。通常,你会在一个系统的不同CPU上运行他们,但是,没有什么能阻止你把它们运行在网络中的不同主机上,我们接下来将实际这么做一次。这(actor是分布式的)意味着,举个栗子,拿生活在不同的大陆上的人们来说,他们需要花费一些努力才能够就某个事实或者某个决定达成一致。这种情况对actor也一样,我们把它叫做“最终一致性”。在那(介绍完最终一致性)之后,我们将介绍scalability和responsiveness以及如何在基于actor的系统中实现他们。围绍着reactive programming的四个原则: event-driven, scalable, resilent, responsive

这里发现得再理解下这四个tenets,于是找了篇文章翻译了一下

The Impact of Network Communication

Compared to in-process communication:

  • data sharing only by value
  • lower bandwith
  • higher latency
  • partial failure
  • data corruption

Multiple processes on the same machine are quantitatively less impacted, but qualitatively the issues are the same.

比较网络通信和进程内通信,是用来了解actor在分布式的方面能带领我们走多远。

  • 在网络通信时,数据以值的方式被传递。对象需要被序列化,通过网络传输,反序列化,经过这些步骤,被传输后的对象和原始的对象就不是完全相同了(毕竟现在在不同的JVM里)。之前讲过,一个有状态的对象,它的行为跟它的历史有关系。但是一个有状态的对象在经过网络传输以后,经过一段时间,网络两边的这两个对象的状态就可能会不同了。因此,只有共享不可变对象,才是有意义的。(意思应该是通过网络传输一个可变状态的对象,然后想在网络两端共享这个对象,是没有意义的)。
  • 网络带宽比一个机器内部数据的带宽要小很多。
  • 所有通信的延迟要高很多。你可以在一纳秒内调用一个方法,但是不能在一纳秒传递一个网络数据包。并且在网络通信时,对象需要被序列化和反序列化,这比在进程内部传递引用要带来更高的时延。
  • 除了这些量上的区别,还有新的情况发生。就是,当进行网络通信时,有partial failure的风险, 或者你的一些消息只有一部分到达了,并且在收到回复之前你不知道哪些到达了。
  • 另一类failure是data corruption。从个人的经验业看,通过TCP发送数据时,大约每TB会有一个损坏事件。

Multiple processes on the same machine are quantitatively less impacted, but qualitatively the issues are the same.

Distributed computing breaks assumptions made by the synchronous programming model.

在同一个机器上运行多个进程,让他们通过,比如localhost interface通信,可以缓解上边的一些问题。但是本质上的问题仍然存在。

The overarching description of the problem is that distributed computing breaks the core assumptions made by a synchronous programming model.

对于这个问题总的描述是分布式计算打破了同步编程模型的核心假设。

Actors are Distributed

Actor communication is asynchronous, one-way and not guaranteed.

Actor encapsulation makes them look the same, regardless where they live.

Actors are "Location Transparent", hidden behind ActorRef.

迄今,我们已经讲了很多关于actor的知识,你们也知道了actor的所有通信都是异步的和单向的,并且不会保证可靠传递。 因此,actor实际上建模的东西就是网络给我们的东西. They model precisely what the network gives us. 可以认为,actor采取了与“把本地模型扩展到网络”相反的方式。actor模型审视了网络模型,然后把它用在本地机器上。

Actor的另一个特征是他们如此独立地运行,以至于从外部来看,他们都一样。他们都是,ActorRef. 不管actor实际在哪,给他们发消息都是一样的,我们称之为位置透明。

当前的Akka的actor模型所提供的特性集里的所有语法都是严格地设定为所有东西都是远程的。所以不能在这个环境中建模的特性都被移除。结果就是,使用actor来编写一个分布式的程序就跟写一个本地的同样的程序有基本相同的工作量。代码本身没有什么大的区别喝,我们接下来将看到这点。

"Principles of Reactive Programming" 之<Actors are Distributed> (1)的更多相关文章

  1. "Principles of Reactive Programming" 之<Actors are Distributed> (3)

    Cluster 讲课的这哥们接下来讲了下Akka Cluster的使用,但是是通过把一个以前讲过的actor 系统改成使用cluster来介绍的Akka cluster. 这部分代码很多,还是直接看视 ...

  2. "Principles of Reactive Programming" 之<Actors are Distributed> (2)

    Actor Path 我们知道actor是有层级的(hierarchical),第.每个actor在它的父actor的名字空间下都有一个名字.这样就构成了一个树状的结构,就像是文件系统.每个actor ...

  3. "Principles of Reactive Programming" 之 <Persistent Actor State>学习笔记

    这是<Pinciples of Reactive Programming>week6的最后一课. 为什么需要把actor的状态持久化? 如果actor没有状态,那么在任何实时,这个acto ...

  4. Notes of Principles of Parallel Programming - TODO

    0.1 TopicNotes of Lin C., Snyder L.. Principles of Parallel Programming. Beijing: China Machine Pres ...

  5. "reactive programming"的概念

    下面的内容大多是翻译来的. Reactive Programming? What is Reactive Programming? 为了了解Reactive——从编程范式至其背后的动机,有必要了解现在 ...

  6. .Net中的反应式编程(Reactive Programming)

    系列主题:基于消息的软件架构模型演变 一.反应式编程(Reactive Programming) 1.什么是反应式编程:反应式编程(Reactive programming)简称Rx,他是一个使用LI ...

  7. Unity基于响应式编程(Reactive programming)入门

    系列目录 [Unity3D基础]让物体动起来①--基于UGUI的鼠标点击移动 [Unity3D基础]让物体动起来②--UGUI鼠标点击逐帧移动 时光煮雨 Unity3D让物体动起来③—UGUI DoT ...

  8. ReactiveCocoa与Functional Reactive Programming

    转自 http://blog.leezhong.com/ios/2013/06/19/frp-reactivecocoa.html Functional Reactive Programming(以下 ...

  9. [Reactive Programming] RxJS dynamic behavior

    This lesson helps you think in Reactive programming by explaining why it is a beneficial paradigm fo ...

随机推荐

  1. ScrollView 与ListView 滑动冲突完美解决

    一.介绍ListView高度的设置方法 二.根据实际需求解决冲突问题 一.介绍ListView高度的设置方法 在ScrollView中使用ListView,ListView的高度会不正常. 方式一:在 ...

  2. asp.net php asp jsp 301重定向的代码

    介绍一下针对各类程序系统实施301重定向的代码: 1.Linux主机重定向 Godaddy的Liunx主机,Godaddy本身已经支持Apache,所以直接创建一个.htaccess文件就可以了,一般 ...

  3. Java之趣味编程结婚问题

    问题如下:判断结婚的组合对数数.定义: 好三位新郎为 A,B,C ;三位新娘为X,Y,Z 有人想要知道他们谁和谁结婚 ,于是问了其中的三位. 回答是这样的:A说他将和X结婚 :X说她的未婚夫是C ;C ...

  4. Java之绘制方法

    绘制图形所用的函数类别分别为视图类.图形单元类和页面类. 对视图类,设置窗口的位置和大小: 对图形单元类,设置图形边界: 对页面类,只有当页面作为元件,该函数才起作用,设置元件边界. 一般构建窗口我们 ...

  5. Jquery 获得服务器控件值的方法小结(转)

    由于ASP.NET网页运行后,服务器控件会随机生成客户端id,jquery获取时候不太好操作,google了下,总结有以下3种方法. <!--服务器控件代码:--> <asp:Tex ...

  6. 在WCF中使用Flag Enumerations

      请看MSDN示例: [DataContract][Flags] public enum CarFeatures {     None = 0,     [EnumMember]     AirCo ...

  7. iOS学习——iOS视频和推荐网站

    最近有人问有没有iOS学习的相关资料,就简单的把自己的知道的和资源共享一下: 个人感觉iOS开发人才饱和,培训泛滥,个人推荐后台升职空间大和web前端竞争小. [链接][Ronda收集整理]2014年 ...

  8. XMPP登录应用

    一.导入框架 1.XMMP框架,写入头文件,设置XMPPStreamDelegate代理,定义 XMPPStream *_xmppStream; 2.libresolv.dylib 3.libxml2 ...

  9. 基于 HTML5 的数据存储

    以前想做个静态网页APP.最初的思路是用本地文件存储数据,后来发现在手机上运行时,文件无法找到. 经过了长达几个月的搜索(实际也就几天),没有找到合适的方法. 就在绝望的时候,无意间搜到基于HTML5 ...

  10. IIS安装Web Deploy之后没有显示右键菜单

    Bug描述: 使用IIS自带的"Web平台安装程序"安装完Web Deploy组件之后,鼠标右键点击网站,弹出的菜单中并没有新增的"部署"选项. Bug解决: ...