Я хочу обработать данные на свече и вставить их в HBase.Я использую библиотеку Hbase-Spark (Apache HBase) (https://mvnrepository.com/artifact/org.apache.hbase/hbase-spark/2.0.0-alpha4)
Я получаю следующее исключение,
Caused by: java.lang.NoClassDefFoundError: org/apache/spark/Logging
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)
at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at org.apache.hadoop.hbase.spark.JavaHBaseContext.<init>(JavaHBaseContext.scala:46)
at job.sqoop_process.HostLookupGenerator.insert(HostLookupGenerator.java:44)
at job.sqoop_process.SparkSqoopJob.process(SparkSqoopJob.java:17)
at job.spark.SparkExecutor$Executor.execute(SparkExecutor.java:75)
at job.spark.SparkExecutor.main(SparkExecutor.java:37)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.spark.deploy.yarn.ApplicationMaster$$anon$4.run(ApplicationMaster.scala:721)
Проблема в используемой версии HBase-Spark-2.0.0-alpha4класс spark Logging, который устарел в Spark-2.3.1.
Может кто-нибудь помочь мне решить эту проблему.
Примечание: я использую Spark 2.3.1 и HBase 1.2.6.1