SparkRpc 之 RpcEndpoint、ThreadSafeRpcEndpoint、RpcEnvFactory

概述

本文主要描述package org.apache.spark.rpc.RpcEndpoint.scala中包含的三个Trait
在这里插入图片描述

  • RpcEndpoint功能同Actor,用于rpc通信的实体,通信并处理消息。
  • RpcEnvFactory用于创建RpcEnv的工厂类
  • ThreadSafeRpcEndpoint是线程完全的RpcEndpoint

1. RpcEndpoint

1.1 定义

RpcEndpoint是RPC通信的端点,用于定义给定消息要触发的函数。

1.2 生命周期

RpcEndpoint的生命周期为:constructor -> onStart -> receive* -> onStop

注意:

  • "receive"可以同时调用。如果您希望"receive"是线程安全的,请使用[[ThreadSafeRpcEndpoint]]
  • 如果从 [RpcEndpoint] 方法之一引发任何错误("onError"除外),则"onError"将随原因一起调用。
  • 如果"onError"引发错误,[RpcEnv] 将忽略它。

1.3 Filed详解

1.3.1 变量RpcEnv

RpcEndpoint要向此RpcEnv注册

  val rpcEnv: RpcEnv
1.3.2 onStart()

在 [RpcEndpoint]开始之前调用onStart处理任何消息。

  def onStart(): Unit = {
    // By default, do nothing.
  }
1.3.3 self()

[ RpcEndpointRef]当调用"OnStart"时,"self"将变为有效。当调用"onStop"时,“self"将变为"null”。

  • 注意:因为在"onStart"之前,[RpcEndpoint] 尚未注册,并且没有有效的 [RpcEndpointRef]。
  • 因此,在调用"onStart"之前不要调用"self"。
  final def self: RpcEndpointRef = {
    require(rpcEnv != null, "rpcEnv has not been initialized")
    rpcEnv.endpointRef(this)
  }
1.3.4 receive()
  • 处理来自"RpcEndpointRef.send"或"RpcCallContext.reply"的消息。
  • 如果收到不匹配的消息,将抛出"SparkException"并将其发送到"onError"。
  def receive: PartialFunction[Any, Unit] = {
    case _ => throw new SparkException(self + " does not implement 'receive'")
  }
1.3.5 receiveAndReply()
  • 处理来自"RpcEndpointRef.ask"的消息。
  • 如果收到不匹配的消息,将抛出"SparkException"并将其发送到"onError"
  def receiveAndReply(context: RpcCallContext): PartialFunction[Any, Unit] = {
    case _ => context.sendFailure(new SparkException(self + " won't reply anything"))
  }
1.3.6 onError()
  • 在处理消息期间引发任何异常时调用。
  def onError(cause: Throwable): Unit = {
    // By default, throw e and let RpcEnv handle it
    throw cause
  }
1.3.7 网络连接处理

onConnected() : 当"远程地址"连接到当前节点时调用。
onDisconnected() :当“远程地址”失去连接时调用.
onNetworkError() : 当前节点和"远程地址"之间的连接中发生某些网络错误时调用

  def onConnected(remoteAddress: RpcAddress): Unit = {
    // By default, do nothing.
  }
  def onDisconnected(remoteAddress: RpcAddress): Unit = {
    // By default, do nothing.
  }
  def onNetworkError(cause: Throwable, remoteAddress: RpcAddress): Unit = {
    // By default, do nothing.
  }
1.3.8 onStop()
  • 在 [RpcEndpoint] 停止时调用。
  • 在此方法中,“self"将为"空”,您不能使用它发送或询问消息。
  def onStop(): Unit = {
    // By default, do nothing.
  }
1.3.9 stop()
  • 停止 [RpcEndpoint] 的便捷方法。
  final def stop(): Unit = {
    val _self = self
    if (_self != null) {
      rpcEnv.stop(_self)
    }
  }

2. RpcEnvFactory

创建RpcEnv的工厂类,包含一个空的构造函数,以便通过反射创建RpcEnv

private[spark] trait RpcEnvFactory {
  def create(config: RpcEnvConfig): RpcEnv
}

3. ThreadSafeRpcEndpoint

  • 要求RpcEnv线程安全地向其发送消息的特性。
  • 线程安全是指在处理下一条消息之前,由同一个[[threadsaferpcendpoint]]处理一条消息。
  • 换句话说,在处理下一条消息时,可以看到对[[threasaferpcendpoint]内部字段的更改,
  • 并且[[threasaferpcendpoint]中的字段不必是可变的或等效的。
  • 但是,不能保证同一线程将对不同的消息执行相同的[[threasaferpcendpoint]]。
private[spark] trait ThreadSafeRpcEndpoint extends RpcEndpoint
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先不要急于去启动服务。 根据经验,电脑有很大可能存在病毒。. 首先,你看看注册表HKEY_LOCAL_MACHINE\SYSTEM \CurrentControlSet\Services\RpcSs\Parameters 下,有没有ServiceDll的键值,其类型为"REG_EXPAND_SZ".如果有,在看看数值数据是不 是%SystemRoot%\system32\rpcss.dll 如果没有.那么在c:\windows\system32目录下面你也找不到"rpcss.dll"文件的.此时你就得新建此键值,并从网上或者其它电脑 上拷贝"rpcss.dll"文件放到c:\windows\system32目录下面(注意:如果RPC服务不能启动的话."粘贴"功能是不能用的,所 以在用U盘之类的拷贝RPCSS.dll文件,最好是把RPCSS.dll压缩成包.然后通过解压的方式放到system32目录).到此.重启计算机. 应该就行了. 把以下内容保存成reg文件: Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\RpcSs] "Description"="提供终结点映射程序 (endpoint mapper) 以及其它 RPC 服务。" "DisplayName"="Remote Procedure Call (RPC)" "ErrorControl"=dword:00000001 "Group"="COM Infrastructure" "ImagePath"=hex(2):25,00,53,00,79,00,73,00,74,00,65,00,6d,00,52,00,6f,00,6f,00,\ 74,00,25,00,5c,00,73,00,79,00,73,00,74,00,65,00,6d,00,33,00,32,00,5c,00,73,\ 00,76,00,63,00,68,00,6f,00,73,00,74,00,20,00,2d,00,6b,00,20,00,72,00,70,00,\ 63,00,73,00,73,00,00,00 "ObjectName"="NT AUTHORITY\\NetworkService" "Start"=dword:00000002 "Type"=dword:00000020 "FailureActions"=hex:00,00,00,00,00,00,00,00,00,00,00,00,01,00,00,00,00,00,00,\ 00,02,00,00,00,60,ea,00,00 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\RpcSs\Parameters] "ServiceDll"=hex(2):25,00,53,00,79,00,73,00,74,00,65,00,6d,00,52,00,6f,00,6f,\ 00,74,00,25,00,5c,00,73,00,79,00,73,00,74,00,65,00,6d,00,33,00,32,00,5c,00,\ 72,00,70,00,63,00,73,00,73,00,2e,00,64,00,6c,00,6c,00,00,00 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\RpcSs\Security] "Security"=hex:01,00,14,80,a8,00,00,00,b4,00,00,00,14,00,00,00,30,00,00,00,02,\ 00,1c,00,01,00,00,00,02,80,14,00,ff,01,0f,00,01,01,00,00,00,00,00,01,00,00,\ 00,00,02,00,78,00,05,00,00,00,00,00,14,00,8d,00,02,00,01,01,00,00,00,00,00,\ 05,0b,00,00,00,00,00,18,00,ff,01,0f,00,01,02,00,00,00,00,00,05,20,00,00,00,\ 20,02,00,00,00,00,18,00,8d,00,02,00,01,02,00,00,00,00,00,05,20,00,00,00,23,\ 02,00,00,00,00,14,00,9d,00,00,00,01,01,00,00,00,00,00,05,04,00,00,00,00,00,\ 18,00,9d,00,00,00,01,02,00,00,00,00,00,05,20,00,00,00,21,02,00,00,01,01,00,\ 00,00,00,00,05,12,00,00,00,01,01,00,00,00,00,00,05,12,00,00,00 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\RpcSs\Enum] "0"="Root\\LEGACY_RPCSS\\0000" "Count"=dword:00000001 "NextInstance"=dword:00000001 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\Root\LEGACY_RPCSS] "NextInstance"=dword:00000001 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\Root\LEGACY_RPCSS\0000] "Service"="RpcSs" "Legacy"=dword:00000001 "ConfigFlags"=dword:00000020 "Class"="LegacyDriver" "ClassGUID"="{8ECC055D-047F-11D1-A537-0000F8753ED1}" "DeviceDesc"="Remote Procedure Call (RPC)" [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\Root\LEGACY_RPCSS\0000\Control] "ActiveService"="RpcSs" 然后双击导入注册表。 接着在cmd下用sc开服务: sc config Remote Procedure Call(RPC) binpath= c:\windows\system32\svchost.exe -k rpcss start= auto 希望有用~~

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值