运行 Eclipse 上的基本 wordcount 程序时出错
Error while running a basic wordcount program on Eclipse
声明一下,我是hadoop领域的初学者。所以,我指的是 https://developer.yahoo.com/hadoop/tutorial/module3.html 教程。我完成了所有设置,并将所有代码复制到我的 eclipse map-reduce 项目中。就 wordcountmapper、wordcountreducer 和 wordcount.java 文件而言,没有显示错误。
现在,当我在 hadoop 上单击 运行 并在 VM 播放器上单击 select 已设置的服务器并单击下一步时,之后没有任何反应。同样的 "run on hadoop with the selected server page" 就像卡住了一样。进度信息面板的跨度非常短,因此无法检查其实际内容。
然而,这是我每次完成所有这些步骤后在日志文件中得到的。请帮帮我。自从过去 2 天以来,我一直在为此苦苦挣扎。至于所需的库,我已经从 hadoop 安装路径添加了所有必需的 .jar 文件。
.log 文件内容 ---
!ENTRY org.eclipse.ui 4 0 2015-05-31 16:56:39.849
!MESSAGE Unhandled event loop exception
!STACK 0
java.lang.ClassCastException: org.eclipse.swt.widgets.Table cannot be cast to org.eclipse.swt.widgets.TableColumn
at org.eclipse.swt.widgets.Table.getColumn(Table.java:766)
at org.eclipse.swt.widgets.Table.releaseChildren(Table.java:1532)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Canvas.releaseChildren(Canvas.java:120)
at org.eclipse.swt.widgets.Decorations.releaseChildren(Decorations.java:501)
at org.eclipse.swt.widgets.Shell.releaseChildren(Shell.java:932)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Widget.dispose(Widget.java:445)
at org.eclipse.swt.widgets.Decorations.dispose(Decorations.java:282)
at org.eclipse.swt.widgets.Shell.dispose(Shell.java:566)
at org.eclipse.jface.window.Window.close(Window.java:330)
at org.eclipse.jface.dialogs.Dialog.close(Dialog.java:971)
at org.eclipse.jface.dialogs.TrayDialog.close(TrayDialog.java:143)
at org.eclipse.jface.wizard.WizardDialog.hardClose(WizardDialog.java:797)
at org.eclipse.jface.wizard.WizardDialog.close(WizardDialog.java:427)
at org.eclipse.jface.wizard.WizardDialog.cancelPressed(WizardDialog.java:414)
at org.eclipse.jface.wizard.WizardDialog.widgetSelected(WizardDialog.java:293)
at org.eclipse.swt.widgets.TypedListener.handleEvent(TypedListener.java:227)
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:66)
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1006)
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:2413)
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:2164)
at org.eclipse.jface.window.Window.runEventLoop(Window.java:820)
at org.eclipse.jface.window.Window.open(Window.java:796)
at org.apache.hadoop.eclipse.launch.HadoopApplicationLaunchShortcut.findLaunchConfiguration(HadoopApplicationLaunchShortcut.java:110)
at org.eclipse.jdt.internal.debug.ui.launcher.JavaLaunchShortcut.launch(JavaLaunchShortcut.java:109)
at org.eclipse.jdt.internal.debug.ui.launcher.JavaLaunchShortcut.searchAndLaunch(JavaLaunchShortcut.java:74)
at org.eclipse.jdt.internal.debug.ui.launcher.JavaLaunchShortcut.launch(JavaLaunchShortcut.java:227)
at org.eclipse.debug.internal.ui.launchConfigurations.LaunchShortcutExtension.launch(LaunchShortcutExtension.java:429)
at org.eclipse.debug.internal.ui.actions.LaunchShortcutAction.run(LaunchShortcutAction.java:66)
at org.eclipse.jface.action.Action.runWithEvent(Action.java:498)
at org.eclipse.jface.action.ActionContributionItem.handleWidgetSelection(ActionContributionItem.java:546)
at org.eclipse.jface.action.ActionContributionItem.access(ActionContributionItem.java:490)
at org.eclipse.jface.action.ActionContributionItem.handleEvent(ActionContributionItem.java:402)
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:66)
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1006)
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:2413)
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:2164)
at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2389)
at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2353)
at org.eclipse.ui.internal.Workbench.access(Workbench.java:2219)
at org.eclipse.ui.internal.Workbench.run(Workbench.java:466)
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:289)
at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:461)
at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:106)
at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:169)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:106)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:76)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:363)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:176)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:508)
at org.eclipse.equinox.launcher.Main.basicRun(Main.java:447)
at org.eclipse.equinox.launcher.Main.run(Main.java:1173)
该错误似乎与 hadoop 无关。我在该页面中也找不到任何对 SWT Table 或专栏的引用。
您可以启动一个普通的 java 应用程序来查看它是否一切正常,然后从终端 运行 wordcount ($HADOOP_HOME/share/hadoop/mapreduce/hadoop-mapreduce-examples) 来测试您的 hadoop 安装.之后你应该回到 eclipse 看看它是否一切正常(在 hadoop 中总是有更少的问题 运行从终端而不是直接从 eclipse 做)
声明一下,我是hadoop领域的初学者。所以,我指的是 https://developer.yahoo.com/hadoop/tutorial/module3.html 教程。我完成了所有设置,并将所有代码复制到我的 eclipse map-reduce 项目中。就 wordcountmapper、wordcountreducer 和 wordcount.java 文件而言,没有显示错误。
现在,当我在 hadoop 上单击 运行 并在 VM 播放器上单击 select 已设置的服务器并单击下一步时,之后没有任何反应。同样的 "run on hadoop with the selected server page" 就像卡住了一样。进度信息面板的跨度非常短,因此无法检查其实际内容。
然而,这是我每次完成所有这些步骤后在日志文件中得到的。请帮帮我。自从过去 2 天以来,我一直在为此苦苦挣扎。至于所需的库,我已经从 hadoop 安装路径添加了所有必需的 .jar 文件。
.log 文件内容 ---
!ENTRY org.eclipse.ui 4 0 2015-05-31 16:56:39.849
!MESSAGE Unhandled event loop exception
!STACK 0
java.lang.ClassCastException: org.eclipse.swt.widgets.Table cannot be cast to org.eclipse.swt.widgets.TableColumn
at org.eclipse.swt.widgets.Table.getColumn(Table.java:766)
at org.eclipse.swt.widgets.Table.releaseChildren(Table.java:1532)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Composite.releaseChildren(Composite.java:840)
at org.eclipse.swt.widgets.Canvas.releaseChildren(Canvas.java:120)
at org.eclipse.swt.widgets.Decorations.releaseChildren(Decorations.java:501)
at org.eclipse.swt.widgets.Shell.releaseChildren(Shell.java:932)
at org.eclipse.swt.widgets.Widget.release(Widget.java:816)
at org.eclipse.swt.widgets.Widget.dispose(Widget.java:445)
at org.eclipse.swt.widgets.Decorations.dispose(Decorations.java:282)
at org.eclipse.swt.widgets.Shell.dispose(Shell.java:566)
at org.eclipse.jface.window.Window.close(Window.java:330)
at org.eclipse.jface.dialogs.Dialog.close(Dialog.java:971)
at org.eclipse.jface.dialogs.TrayDialog.close(TrayDialog.java:143)
at org.eclipse.jface.wizard.WizardDialog.hardClose(WizardDialog.java:797)
at org.eclipse.jface.wizard.WizardDialog.close(WizardDialog.java:427)
at org.eclipse.jface.wizard.WizardDialog.cancelPressed(WizardDialog.java:414)
at org.eclipse.jface.wizard.WizardDialog.widgetSelected(WizardDialog.java:293)
at org.eclipse.swt.widgets.TypedListener.handleEvent(TypedListener.java:227)
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:66)
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1006)
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:2413)
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:2164)
at org.eclipse.jface.window.Window.runEventLoop(Window.java:820)
at org.eclipse.jface.window.Window.open(Window.java:796)
at org.apache.hadoop.eclipse.launch.HadoopApplicationLaunchShortcut.findLaunchConfiguration(HadoopApplicationLaunchShortcut.java:110)
at org.eclipse.jdt.internal.debug.ui.launcher.JavaLaunchShortcut.launch(JavaLaunchShortcut.java:109)
at org.eclipse.jdt.internal.debug.ui.launcher.JavaLaunchShortcut.searchAndLaunch(JavaLaunchShortcut.java:74)
at org.eclipse.jdt.internal.debug.ui.launcher.JavaLaunchShortcut.launch(JavaLaunchShortcut.java:227)
at org.eclipse.debug.internal.ui.launchConfigurations.LaunchShortcutExtension.launch(LaunchShortcutExtension.java:429)
at org.eclipse.debug.internal.ui.actions.LaunchShortcutAction.run(LaunchShortcutAction.java:66)
at org.eclipse.jface.action.Action.runWithEvent(Action.java:498)
at org.eclipse.jface.action.ActionContributionItem.handleWidgetSelection(ActionContributionItem.java:546)
at org.eclipse.jface.action.ActionContributionItem.access(ActionContributionItem.java:490)
at org.eclipse.jface.action.ActionContributionItem.handleEvent(ActionContributionItem.java:402)
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:66)
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1006)
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:2413)
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:2164)
at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2389)
at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2353)
at org.eclipse.ui.internal.Workbench.access(Workbench.java:2219)
at org.eclipse.ui.internal.Workbench.run(Workbench.java:466)
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:289)
at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:461)
at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:106)
at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:169)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:106)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:76)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:363)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:176)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:508)
at org.eclipse.equinox.launcher.Main.basicRun(Main.java:447)
at org.eclipse.equinox.launcher.Main.run(Main.java:1173)
该错误似乎与 hadoop 无关。我在该页面中也找不到任何对 SWT Table 或专栏的引用。
您可以启动一个普通的 java 应用程序来查看它是否一切正常,然后从终端 运行 wordcount ($HADOOP_HOME/share/hadoop/mapreduce/hadoop-mapreduce-examples) 来测试您的 hadoop 安装.之后你应该回到 eclipse 看看它是否一切正常(在 hadoop 中总是有更少的问题 运行从终端而不是直接从 eclipse 做)