Hi Markus,
the problem should be fixed with NUTCH-2442. It wasn't the case with the first
version of the
sitemap processor. It's mandatory to check also the return value of
job.waitForCompletion(true),
only checking for exceptions isn't enough!
Sebastian
On 01/17/2018 11:51 AM, Markus Jelsma wrote:
> Hello,
>
> We noticed some abnormalities in our crawl cycle caused by a sudden reduction
> of our CrawlDB's size. The SitemapProcessor ran, failed (timed out, see
> below) and left us with a decimated CrawlDB.
>
> This is odd because of:
>
> } catch (Exception e) {
> if (fs.exists(tempCrawlDb))
> fs.delete(tempCrawlDb, true);
>
> LockUtil.removeLockFile(fs, lock);
> throw e;
> }
>
> Any ideas?
>
> Thanks,
> Markus
>
> Full thread dump OpenJDK 64-Bit Server VM (25.151-b12 mixed mode):
>
> "Thread-52" #74 prio=5 os_prio=0 tid=0x00007fe2adc85000 nid=0x6cf8 runnable
> [0x00007fe28a86d000]
> java.lang.Thread.State: RUNNABLE
> at java.util.regex.Pattern$BmpCharProperty.match(Pattern.java:3797)
> at java.util.regex.Pattern$Start.match(Pattern.java:3461)
> at java.util.regex.Matcher.search(Matcher.java:1248)
> at java.util.regex.Matcher.find(Matcher.java:637)
> at java.util.regex.Matcher.replaceAll(Matcher.java:951)
> at
> org.apache.nutch.net.urlnormalizer.regex.RegexURLNormalizer.regexNormalize(RegexURLNormalizer.java:193)
>
> at
> org.apache.nutch.net.urlnormalizer.regex.RegexURLNormalizer.normalize(RegexURLNormalizer.java:200)
>
> at org.apache.nutch.net.URLNormalizers.normalize(URLNormalizers.java:319)
> at
> org.apache.nutch.util.SitemapProcessor$SitemapMapper.filterNormalize(SitemapProcessor.java:176)
>
> at
> org.apache.nutch.util.SitemapProcessor$SitemapMapper.generateSitemapUrlDatum(SitemapProcessor.java:225)
>
> at
> org.apache.nutch.util.SitemapProcessor$SitemapMapper.generateSitemapUrlDatum(SitemapProcessor.java:264)
>
> at
> org.apache.nutch.util.SitemapProcessor$SitemapMapper.map(SitemapProcessor.java:154)
>
> at
> org.apache.nutch.util.SitemapProcessor$SitemapMapper.map(SitemapProcessor.java:95)
>
> at org.apache.hadoop.mapreduce.Mapper.run(Mapper.java:146)
> at
> org.apache.hadoop.mapreduce.lib.map.MultithreadedMapper$MapRunner.run(MultithreadedMapper.java:273)
>
> "SpillThread" #34 daemon prio=5 os_prio=0 tid=0x00007fe2ada12000 nid=0x6c2f
> waiting on condition [0x00007fe28d2ad000]
> java.lang.Thread.State: WAITING (parking)
> at sun.misc.Unsafe.park(Native Method)
> - parking to wait for <0x00000000ede6dc80> (a
> java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
> at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
> at
> java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2039)
>
> at
> org.apache.hadoop.mapred.MapTask$MapOutputBuffer$SpillThread.run(MapTask.java:1530)
>
> "org.apache.hadoop.hdfs.PeerCache@1fc0053e" #33 daemon prio=5 os_prio=0
> tid=0x00007fe2ad7fe000 nid=0x6be7 waiting on condition [0x00007fe28d3ae000]
> java.lang.Thread.State: TIMED_WAITING (sleeping)
> at java.lang.Thread.sleep(Native Method)
> at org.apache.hadoop.hdfs.PeerCache.run(PeerCache.java:253)
> at org.apache.hadoop.hdfs.PeerCache.access$000(PeerCache.java:46)
> at org.apache.hadoop.hdfs.PeerCache$1.run(PeerCache.java:124)
> at java.lang.Thread.run(Thread.java:748)
>
> "communication thread" #28 daemon prio=5 os_prio=0 tid=0x00007fe2ad975800
> nid=0x6b9e in Object.wait() [0x00007fe28d8b1000]
> java.lang.Thread.State: TIMED_WAITING (on object monitor)
> at java.lang.Object.wait(Native Method)
> at org.apache.hadoop.mapred.Task$TaskReporter.run(Task.java:799)
> - locked <0x00000000ede69ae8> (a java.lang.Object)
> at java.lang.Thread.run(Thread.java:748)
>
> "client DomainSocketWatcher" #27 daemon prio=5 os_prio=0
> tid=0x00007fe2ad952000 nid=0x6b95 runnable [0x00007fe28d9b2000]
> java.lang.Thread.State: RUNNABLE
> at org.apache.hadoop.net.unix.DomainSocketWatcher.doPoll0(Native Method)
> at
> org.apache.hadoop.net.unix.DomainSocketWatcher.access$900(DomainSocketWatcher.java:52)
>
> at
> org.apache.hadoop.net.unix.DomainSocketWatcher$2.run(DomainSocketWatcher.java:503)
>
> at java.lang.Thread.run(Thread.java:748)
>
> "Thread for syncLogs" #26 daemon prio=5 os_prio=0 tid=0x00007fe2ad820000
> nid=0x6b81 waiting on condition [0x00007fe28deb3000]
> java.lang.Thread.State: TIMED_WAITING (parking)
> at sun.misc.Unsafe.park(Native Method)
> - parking to wait for <0x00000000e7118190> (a
> java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
> at java.util.concurrent.locks.LockSupport.parkNanos(LockSupport.java:215)
> at
> java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.awaitNanos(AbstractQueuedSynchronizer.java:2078)
>
> at
> java.util.concurrent.ScheduledThreadPoolExecutor$DelayedWorkQueue.take(ScheduledThreadPoolExecutor.java:1093)
>
> at
> java.util.concurrent.ScheduledThreadPoolExecutor$DelayedWorkQueue.take(ScheduledThreadPoolExecutor.java:809)
>
> at
> java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1074)
> at
> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1134)
>
> at
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
>
> at java.lang.Thread.run(Thread.java:748)
>
> "org.apache.hadoop.fs.FileSystem$Statistics$StatisticsDataReferenceCleaner"
> #24 daemon prio=5 os_prio=0 tid=0x00007fe2ad746800 nid=0x6b79 in
> Object.wait() [0x00007fe28e1cc000]
> java.lang.Thread.State: WAITING (on object monitor)
> at java.lang.Object.wait(Native Method)
> - waiting on <0x00000000e7171060> (a java.lang.ref.ReferenceQueue$Lock)
> at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:143)
> - locked <0x00000000e7171060> (a java.lang.ref.ReferenceQueue$Lock)
> at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:164)
> at
> org.apache.hadoop.fs.FileSystem$Statistics$StatisticsDataReferenceCleaner.run(FileSystem.java:3212)
>
> at java.lang.Thread.run(Thread.java:748)
>
> "IPC Parameter Sending Thread #0" #23 daemon prio=5 os_prio=0
> tid=0x00007fe2ad637000 nid=0x6b6d waiting on condition [0x00007fe28e4cd000]
> java.lang.Thread.State: TIMED_WAITING (parking)
> at sun.misc.Unsafe.park(Native Method)
> - parking to wait for <0x00000000e7117338> (a
> java.util.concurrent.SynchronousQueue$TransferStack)
> at java.util.concurrent.locks.LockSupport.parkNanos(LockSupport.java:215)
> at
> java.util.concurrent.SynchronousQueue$TransferStack.awaitFulfill(SynchronousQueue.java:460)
>
> at
> java.util.concurrent.SynchronousQueue$TransferStack.transfer(SynchronousQueue.java:362)
>
> at java.util.concurrent.SynchronousQueue.poll(SynchronousQueue.java:941)
> at
> java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1073)
> at
> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1134)
>
> at
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
>
> at java.lang.Thread.run(Thread.java:748)
>
> "IPC Client (1373419525) connection to /89.188.14.3:36783 from
> job_1516025831039_0247" #22 daemon prio=5 os_prio=0 tid=0x00007fe2ad632000
> nid=0x6b6c in Object.wait() [0x00007fe28e5ce000]
> java.lang.Thread.State: TIMED_WAITING (on object monitor)
> at java.lang.Object.wait(Native Method)
> at org.apache.hadoop.ipc.Client$Connection.waitForWork(Client.java:1008)
> - locked <0x00000000e7119130> (a org.apache.hadoop.ipc.Client$Connection)
> at org.apache.hadoop.ipc.Client$Connection.run(Client.java:1052)
>
> "Timer for 'MapTask' metrics system" #21 daemon prio=5 os_prio=0
> tid=0x00007fe2ad525800 nid=0x6b5f in Object.wait() [0x00007fe28f551000]
> java.lang.Thread.State: TIMED_WAITING (on object monitor)
> at java.lang.Object.wait(Native Method)
> at java.util.TimerThread.mainLoop(Timer.java:552)
> - locked <0x00000000e713ca30> (a java.util.TaskQueue)
> at java.util.TimerThread.run(Timer.java:505)
>
> "Service Thread" #17 daemon prio=9 os_prio=0 tid=0x00007fe2ac0f8800
> nid=0x6b36 runnable [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C1 CompilerThread11" #16 daemon prio=9 os_prio=0 tid=0x00007fe2ac0eb800
> nid=0x6b34 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C1 CompilerThread10" #15 daemon prio=9 os_prio=0 tid=0x00007fe2ac0e9800
> nid=0x6b33 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C1 CompilerThread9" #14 daemon prio=9 os_prio=0 tid=0x00007fe2ac0e7000
> nid=0x6b32 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C1 CompilerThread8" #13 daemon prio=9 os_prio=0 tid=0x00007fe2ac0e5000
> nid=0x6b31 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C2 CompilerThread7" #12 daemon prio=9 os_prio=0 tid=0x00007fe2ac0e3000
> nid=0x6b30 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C2 CompilerThread6" #11 daemon prio=9 os_prio=0 tid=0x00007fe2ac0e1000
> nid=0x6b2f waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C2 CompilerThread5" #10 daemon prio=9 os_prio=0 tid=0x00007fe2ac0de800
> nid=0x6b2d waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C2 CompilerThread4" #9 daemon prio=9 os_prio=0 tid=0x00007fe2ac0d4800
> nid=0x6b2b waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C2 CompilerThread3" #8 daemon prio=9 os_prio=0 tid=0x00007fe2ac0d2800
> nid=0x6b2a waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C2 CompilerThread2" #7 daemon prio=9 os_prio=0 tid=0x00007fe2ac0ce000
> nid=0x6b29 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C2 CompilerThread1" #6 daemon prio=9 os_prio=0 tid=0x00007fe2ac0cc000
> nid=0x6b28 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "C2 CompilerThread0" #5 daemon prio=9 os_prio=0 tid=0x00007fe2ac0c9000
> nid=0x6b26 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "Signal Dispatcher" #4 daemon prio=9 os_prio=0 tid=0x00007fe2ac0c7000
> nid=0x6b24 waiting on condition [0x0000000000000000]
> java.lang.Thread.State: RUNNABLE
>
> "Finalizer" #3 daemon prio=8 os_prio=0 tid=0x00007fe2ac0a0000 nid=0x6ab7 in
> Object.wait() [0x00007fe29592c000]
> java.lang.Thread.State: WAITING (on object monitor)
> at java.lang.Object.wait(Native Method)
> at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:143)
> - locked <0x00000000e72f0140> (a java.lang.ref.ReferenceQueue$Lock)
> at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:164)
> at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:209)
>
> "Reference Handler" #2 daemon prio=10 os_prio=0 tid=0x00007fe2ac09b800
> nid=0x6ab6 in Object.wait() [0x00007fe295a2d000]
> java.lang.Thread.State: WAITING (on object monitor)
> at java.lang.Object.wait(Native Method)
> at java.lang.Object.wait(Object.java:502)
> at java.lang.ref.Reference.tryHandlePending(Reference.java:191)
> - locked <0x00000000e72f0180> (a java.lang.ref.Reference$Lock)
> at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:153)
>
> "main" #1 prio=5 os_prio=0 tid=0x00007fe2ac014000 nid=0x6a69 in Object.wait()
> [0x00007fe2b5747000]
> java.lang.Thread.State: WAITING (on object monitor)
> at java.lang.Object.wait(Native Method)
> - waiting on <0x00000000edb32e88> (a
> org.apache.hadoop.mapreduce.lib.map.MultithreadedMapper$MapRunner)
> at java.lang.Thread.join(Thread.java:1252)
> - locked <0x00000000edb32e88> (a
> org.apache.hadoop.mapreduce.lib.map.MultithreadedMapper$MapRunner)
> at java.lang.Thread.join(Thread.java:1326)
> at
> org.apache.hadoop.mapreduce.lib.map.MultithreadedMapper.run(MultithreadedMapper.java:146)
>
> at org.apache.hadoop.mapred.MapTask.runNewMapper(MapTask.java:787)
> at org.apache.hadoop.mapred.MapTask.run(MapTask.java:341)
> at org.apache.hadoop.mapred.YarnChild$2.run(YarnChild.java:175)
> at java.security.AccessController.doPrivileged(Native Method)
> at javax.security.auth.Subject.doAs(Subject.java:422)
> at
> org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1836)
>
> at org.apache.hadoop.mapred.YarnChild.main(YarnChild.java:169)
>
> "VM Thread" os_prio=0 tid=0x00007fe2ac093800 nid=0x6aad runnable
>
> "GC task thread#0 (ParallelGC)" os_prio=0 tid=0x00007fe2ac029000 nid=0x6a77
> runnable
>
> "GC task thread#1 (ParallelGC)" os_prio=0 tid=0x00007fe2ac02b000 nid=0x6a79
> runnable
>
> "GC task thread#2 (ParallelGC)" os_prio=0 tid=0x00007fe2ac02c800 nid=0x6a7b
> runnable
>
> "GC task thread#3 (ParallelGC)" os_prio=0 tid=0x00007fe2ac02e800 nid=0x6a7d
> runnable
>
> "GC task thread#4 (ParallelGC)" os_prio=0 tid=0x00007fe2ac030000 nid=0x6a80
> runnable
>
> "GC task thread#5 (ParallelGC)" os_prio=0 tid=0x00007fe2ac032000 nid=0x6a95
> runnable
>
> "GC task thread#6 (ParallelGC)" os_prio=0 tid=0x00007fe2ac033800 nid=0x6a96
> runnable
>
> "GC task thread#7 (ParallelGC)" os_prio=0 tid=0x00007fe2ac035800 nid=0x6a97
> runnable
>
> "GC task thread#8 (ParallelGC)" os_prio=0 tid=0x00007fe2ac037000 nid=0x6a98
> runnable
>
> "GC task thread#9 (ParallelGC)" os_prio=0 tid=0x00007fe2ac039000 nid=0x6a99
> runnable
>
> "GC task thread#10 (ParallelGC)" os_prio=0 tid=0x00007fe2ac03a800 nid=0x6a9a
> runnable
>
> "GC task thread#11 (ParallelGC)" os_prio=0 tid=0x00007fe2ac03c800 nid=0x6a9b
> runnable
>
> "GC task thread#12 (ParallelGC)" os_prio=0 tid=0x00007fe2ac03e000 nid=0x6a9c
> runnable
>
> "VM Periodic Task Thread" os_prio=0 tid=0x00007fe2ac0fb000 nid=0x6b38 waiting
> on condition
>
> JNI global references: 275
>
> Heap
> PSYoungGen total 116224K, used 105934K [0x00000000f7b00000,
> 0x0000000100000000, 0x0000000100000000)
> eden space 100864K, 89% used
> [0x00000000f7b00000,0x00000000fd3a6228,0x00000000fdd80000)
> from space 15360K, 98% used
> [0x00000000fdd80000,0x00000000fec4d7a0,0x00000000fec80000)
> to space 19456K, 0% used
> [0x00000000fed00000,0x00000000fed00000,0x0000000100000000)
> ParOldGen total 273408K, used 189187K [0x00000000e7000000,
> 0x00000000f7b00000, 0x00000000f7b00000)
> object space 273408K, 69% used
> [0x00000000e7000000,0x00000000f28c0c88,0x00000000f7b00000)
> Metaspace used 33001K, capacity 33602K, committed 34048K, reserved
> 1079296K
> class space used 3581K, capacity 3675K, committed 3840K, reserved
> 1048576K
>