解決Eclipse中執行WordCount出現java.lang.ClassNotFoundException:org.apache.hadoop.examples.WordCount$TokenizerMapper問題
原文:http://tonymomo.pixnet.net/blog/post/62329497
1 package org.apache.hadoop.examples; 2 3 import java.io.File; 4 import java.io.FileInputStream; 5 import java.io.FileOutputStream; 6 import java.io.IOException; 7 import java.net.URL; 8 import java.net.URLClassLoader; 9 import java.util.ArrayList; 10 import java.util.List; 11 import java.util.jar.JarEntry; 12 import java.util.jar.JarOutputStream; 13 import java.util.jar.Manifest; 14 15 public class EJob { 16 17 // To declare global field 18 private static List<URL> classPath = new ArrayList<URL>(); 19 20 // To declare method 21 public static File createTempJar(String root) throws IOException { 22 if (!new File(root).exists()) { 23 return null; 24 } 25 Manifest manifest = new Manifest(); 26 manifest.getMainAttributes().putValue("Manifest-Version", "1.0"); 27 final File jarFile = File.createTempFile("EJob-", ".jar", new File( 28 System.getProperty("java.io.tmpdir"))); 29 30 Runtime.getRuntime().addShutdownHook(new Thread() { 31 public void run() { 32 jarFile.delete(); 33 } 34 }); 35 36 JarOutputStream out = new JarOutputStream( 37 new FileOutputStream(jarFile), manifest); 38 createTempJarInner(out, new File(root), ""); 39 out.flush(); 40 out.close(); 41 return jarFile; 42 } 43 44 private static void createTempJarInner(JarOutputStream out, File f, 45 String base) throws IOException { 46 if (f.isDirectory()) { 47 File[] fl = f.listFiles(); 48 if (base.length() > 0) { 49 base = base + "/"; 50 } 51 for (int i = 0; i < fl.length; i++) { 52 createTempJarInner(out, fl[i], base + fl[i].getName()); 53 } 54 } else { 55 out.putNextEntry(new JarEntry(base)); 56 FileInputStream in = new FileInputStream(f); 57 byte[] buffer = new byte[1024]; 58 int n = in.read(buffer); 59 while (n != -1) { 60 out.write(buffer, 0, n); 61 n = in.read(buffer); 62 } 63 in.close(); 64 } 65 } 66 67 public static ClassLoader getClassLoader() { 68 ClassLoader parent = Thread.currentThread().getContextClassLoader(); 69 if (parent == null) { 70 parent = EJob.class.getClassLoader(); 71 } 72 if (parent == null) { 73 parent = ClassLoader.getSystemClassLoader(); 74 } 75 return new URLClassLoader(classPath.toArray(new URL[0]), parent); 76 } 77 78 public static void addClasspath(String component) { 79 80 if ((component != null) && (component.length() > 0)) { 81 try { 82 File f = new File(component); 83 84 if (f.exists()) { 85 URL key = f.getCanonicalFile().toURL(); 86 if (!classPath.contains(key)) { 87 classPath.add(key); 88 } 89 } 90 } catch (IOException e) { 91 } 92 } 93 } 94 95 }
mian方法中新增:
File jarFile = EJob.createTempJar(“bin”);
EJob.addClasspath(“/usr/hadoop/conf”);
ClassLoader classLoader = EJob.getClassLoader();
Thread.currentThread().setContextClassLoader(classLoader);
。。。
((JobConf) job.getConfiguration()).setJar(jarFile.toString());
如果本文對您有幫助,點一下右下角的“推薦”
相關文章
- 解決eclipse編輯jsp、js檔案時,經常出現卡死的問題EclipseJS
- steam確認錯誤執行此操作時出現問題怎麼解決
- 解決 eclipse出現 Address already in use: bindEclipse
- Java中解決多執行緒資料安全問題Java執行緒
- 01 Eclipse使用Maven慢的問題解決EclipseMaven
- 解決jenkins執行磁碟滿的問題Jenkins
- 執行 shell 指令碼 \r 問題解決指令碼
- 多執行緒的出現是要解決什麼問題的? 本質什麼?執行緒
- 使用MapReduce執行WordCount案例
- 解決POI多執行緒匯出時資料錯亂問題執行緒
- mysql執行truncate drop 時卡死問題解決MySql
- Python執行緒安全問題及解決方法Python執行緒
- 解決Ubuntu配置nginx出現的問題UbuntuNginx
- 如何解決Eclipse整合華為AGC SDK工具包執行失敗問題EclipseGC
- Linux下安裝Hadoop 詳解及WordCount執行LinuxHadoop
- 執行Tensorboard出現kernel is dead的解決方法ORB
- 解決Eclipse中文註釋部分亂碼的問題Eclipse
- Faiss使用多執行緒出現的效能問題AI執行緒
- 解決Java執行過程中拋簽名異常的問題Java
- 解決react useEffect中的內容被執行兩次的問題React
- 多執行緒的安全問題及解決方案執行緒
- DMAIC如何作為解決問題的方法執行?AI
- 快速解決mongodb出現id重複問題MongoDB
- 企圖使用c++執行緒解決nodejs單執行緒問題C++執行緒NodeJS
- 解決STS或者Eclipse卡死在remote system explorer operation問題EclipseREM
- Spring Batch中管理長時間執行作業:解決連線問題SpringBAT
- 爬蟲中經常出現Traceback (most recent call last):問題解決!!!爬蟲AST
- 多執行緒併發同步問題及解決方案執行緒
- 解決spring security自定義filter重複執行問題SpringFilter
- 兩行命令解決 Windows 下 Homestead 執行緩慢的問題Windows
- iOS 解決tableHeaderView新增searchBar後出現的問題iOSHeaderView
- kafka監聽出現的問題,解決和剖析Kafka
- 多執行緒問題解釋執行緒
- 解決eclipse的 Invalid project description. overlaps the location of another project: 問題EclipseProject
- TP5本地執行正常,線上執行某頁面出現【模板檔案不存在】問題的解決辦法
- 使用執行緒模擬解決銀行排隊叫號問題執行緒
- Python | 多執行緒死鎖問題的巧妙解決方法Python執行緒
- 【slam】解決VirtualBox執行ubuntu18.04.6卡頓的問題SLAMUbuntu
- SpringBoot專案在Eclipse/MyEclipse中執行Spring BootEclipse