Spark报错 driver did not authorize commit

本文探讨了在Spark中启用Speculative Execution后,如何处理运行较慢的task在其他executor上同时启动,以及当一个task执行完毕时,另一个被禁止提交导致的WARN信息。解释了这种机制是为了避免显示误导性的失败提示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

启动Spark Speculative后,有时候运行任务会发现如下提示:

WARN TaskSetManager: Lost task 55.0 in stage 15.0 (TID 20815, spark047216)

org.apache.spark.executor.CommitDeniedException: attempt_201604191557_0015_m_000055_0: Not committed because the driver did not authorize commit

启动 Speculative 后,运行较慢的task会在其他executor上同时再启动一个相同的task,如果其中一个task执行完毕,相同的另一个task就会被禁止提交。因此产生了这个WARN。

这个WARN是因为task提交commit被driver拒绝引发,这个错误不会被统计在stage的failure中,这样做的目的是防止你看到一些具有欺骗性的提示。

相关源码

org.apache.spark.executor

case cDE: CommitDeniedException =>
            val reason = cDE.toTaskEndReason
          execBackend.statusUpdate(taskId, TaskState.FAILED, ser.serialize(reason))

org.apache.spark.executor.CommitDeniedException

private[spark] class CommitDeniedException(
    msg: String,
    jobID: Int,
    splitID: Int,
    attemptNumber: Int)
  extends Exception(msg) {

  def toTaskEndReason: TaskEndReason = TaskCommitDenied(jobID, splitID, attemptNumber)
}

org.apache.spark.TaskCommitDenied

case class TaskCommitDenied(
    jobID: Int,
    partitionID: Int,
    attemptNumber: Int) extends TaskFailedReason {
  override def toErrorString: String = s"TaskCommitDenied (Driver denied task commit)" +
    s" for job: $jobID, partition: $partitionID, attemptNumber: $attemptNumber"
  override def countTowardsTaskFailures: Boolean = false
}
### 解决方案 在 `uni-app` 中遇到 `uni.authorize is not a function` 的错误,主要是由于该方法仅支持小程序端调用,在 H5 和 App 端并不适用。因此可以通过条件编译来区分不同平台的行为。 以下是具体的实现方式: #### 条件编译解决跨平台差异 可以利用 `uni-app` 提供的条件编译功能,针对不同的运行环境编写特定逻辑。例如,对于需要授权的小程序场景,可以在代码中加入 `//#ifdef MP-WEIXIN` 判断语句[^1]。 ```javascript if (process.env.VUE_APP_PLATFORM === 'mp-weixin') { //#ifdef MP-WEIXIN uni.authorize({ scope: 'scope.userLocation', success() { console.log('用户同意授权'); // 获取地理位置信息 uni.getLocation({ type: 'wgs84', success(res) { console.log('当前位置:', res); }, fail(err) { console.error('获取位置失败', err); } }); }, fail() { console.warn('用户拒绝授权'); } }); //#endif } else { // 对于其他平台(如App或H5),直接尝试获取位置 uni.getLocation({ type: 'wgs84', success(res) { console.log('当前位置:', res); }, fail(err) { console.error('获取位置失败', err); } }); } ``` 上述代码实现了以下功能: - **小程序端**:通过 `uni.authorize` 请求用户授权后再调用 `uni.getLocation` 方法。 - **非小程序端**:跳过授权流程,直接调用 `uni.getLocation` 方法。 #### app.json 文件中的权限声明 如果应用涉及地图定位等功能,还需要在项目的配置文件 `app.json` 或 `manifest.json` 中声明相关权限[^2]。具体操作如下: ```json { "permissions": { "scope.userLocation": { "desc": "用于提供基于您所在城市的功能服务" } } } ``` 此设置确保在提交微信小程序审核时不会因缺少权限声明而被驳回。 --- ### 常见问题排查 当遇到类似 `Object(...) is not a function` 的错误时,通常是因为某些依赖未正确加载或存在版本兼容性问题[^3]。建议按照以下步骤逐一排查: 1. 检查项目中是否存在未上传至云端的自定义模块或工具类; 2. 更新 `uni-app` SDK 至最新稳定版; 3. 清理缓存并重新构建项目。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值