hadoop超时解决办法context.progress()的作用 假设在map()方法中,你有一个从数据库读取大量数据的操作,是用一个循环来完成的,并且,在读完全部的数据之前,你不会有任何的数据输出
2015-01-26 10:15
1011 查看
进行矩阵计算的时候,由于持续时间长,往往会出现超时的错误,错误内容如下:
Task attempt_201005281116_119912_r_000823_0 failed to report status for 606 seconds. Killing!
10/06/10 10:49:45 INFO mapred.JobClient: Task Id : attempt_201005281116_119912_r_000015_1, Status : FAILED
解决办法是在代码中定时report
context.progress()的作用
假设在map()方法中,你有一个从数据库读取大量数据的操作,是用一个循环来完成的,并且,在读完全部的数据之前,你不会有任何的数据输出(纯读),那么,读完全部数据所需的时间可能很长,一直没有输出的话,这个task就会因为超时被杀掉,为了避免这个问题,可在以读取数据的循环中使用context.progress()方法来报告进度,那么该task就会被认为还活着,从而解决超时问题。
Task attempt_201005281116_119912_r_000823_0 failed to report status for 606 seconds. Killing!
10/06/10 10:49:45 INFO mapred.JobClient: Task Id : attempt_201005281116_119912_r_000015_1, Status : FAILED
解决办法是在代码中定时report
final TaskAttemptContext context = ; long lastTime = System.currentTimeMillis(); public void ping() { final long currtime = System.currentTimeMillis(); if (currtime - lastTime > 10000) { context.progress(); lastTime = currtime; } }
context.progress()的作用
假设在map()方法中,你有一个从数据库读取大量数据的操作,是用一个循环来完成的,并且,在读完全部的数据之前,你不会有任何的数据输出(纯读),那么,读完全部数据所需的时间可能很长,一直没有输出的话,这个task就会因为超时被杀掉,为了避免这个问题,可在以读取数据的循环中使用context.progress()方法来报告进度,那么该task就会被认为还活着,从而解决超时问题。
相关文章推荐
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- 超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法[转]
- 超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- "超时间时间已到。在操作完成之前超时时间已过或服务器未响应"的解决办法
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- 编写一段程序,从标准输入读取string对象的序列直到连续出现两个相同的单词或者所有单词都读完为止。使用while循环一次读取一个单词,当一个单词连续出现两次是使用break语句终止循环。输出连续重复出现的单词,或者输出一个消息说明没有人任何单词是重复出现的。
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- 关于数据库循环插入大量对象数据的解决办法
- 超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- 问题:“Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。”的解决方法
- 单元测试时候使用[ClassInitialize]会该方法必须是静态的公共方法,不返回值并且应采用一个TestContext类型的参数报错的解决办法
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- 【转】"超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- "超时时间已到。在操作完成之前超时时间已过或服务器未响应"解决办法
- SqlServer2008 无法修改表,超时时间已到 在操作完成之前超时解决方法