- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在开发一个应用程序,该应用程序使用 Websocket API 在线收集实时流比特币交易数据并在旅途中对其进行分析。我创建了 Kafka 生产者来从特定主题收集数据。我正在使用 Intellij、Scala 和 Kafka 来开发应用程序。
因为我正在研究 Kafka 制作人部分。
我的代码文件结构是 src/scala/main/coinyser。
这是第一个文件(src/scala/main/coinyser/StreamingProducer.scala):
package coinyser
import java.sql.Timestamp
import java.text.SimpleDateFormat
import java.util.TimeZone
import cats.effect.IO
import com.fasterxml.jackson.databind._
import com.fasterxml.jackson.module.scala.DefaultScalaModule
import com.pusher.client.Client
import com.pusher.client.channel.SubscriptionEventListener
import com.typesafe.scalalogging.StrictLogging
object StreamingProducer extends StrictLogging {
def subscribe(pusher: Client)(onTradeReceived: String => Unit): IO[Unit] = {
for {
_ <- IO(pusher.connect())
channel <- IO(pusher.subscribe("live_trades"))
_ <- IO(channel.bind("trade", new SubscriptionEventListener() {
override def onEvent(channel: String, event: String, data:
String): Unit = {
logger.info(s"Received event: $event with data: $data")
onTradeReceived(data)
}
}))
} yield ()
}
val mapper: ObjectMapper = {
// println("I'm running!")
// val m = new ObjectMapper()
val m = new ObjectMapper().registerModule(DefaultScalaModule)
val sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")
sdf.setTimeZone(TimeZone.getTimeZone("UTC"))
m.setDateFormat(sdf)
}
def deserializeWebsocketTransaction(s: String): WebsocketTransaction = {
mapper.readValue(s, classOf[WebsocketTransaction])
}
def convertWsTransaction(wsTx: WebsocketTransaction): Transaction =
Transaction(
timestamp = new Timestamp(wsTx.timestamp.toLong * 1000), tid =
wsTx.id, price = wsTx.price, sell = wsTx.`type` == 1, amount =
wsTx.amount)
def serializeTransaction(tx: Transaction): String =
mapper.writeValueAsString(tx)
}
package coinyser
import cats.effect.{ExitCode, IO, IOApp}
import com.pusher.client.Pusher
import StreamingProducer._
import org.apache.kafka.clients.producer.{KafkaProducer, ProducerRecord}
import scala.collection.JavaConversions._
object StreamingProducerApp extends IOApp {
val topic = "transactions"
val pusher = new Pusher("de504dc5763aeef9ff52")
val props = Map(
"bootstrap.servers" -> "localhost:9092",
"key.serializer" ->
"org.apache.kafka.common.serialization.IntegerSerializer",
"value.serializer" ->
"org.apache.kafka.common.serialization.StringSerializer")
def run(args: List[String]): IO[ExitCode] = {
val kafkaProducer = new KafkaProducer[Int, String](props)
subscribe(pusher) { wsTx =>
val tx = convertWsTransaction(deserializeWebsocketTransaction(wsTx))
val jsonTx = serializeTransaction(tx)
kafkaProducer.send(new ProducerRecord(topic, tx.tid, jsonTx))
}.flatMap(_ => IO.never)
}
}
log4j:WARN No appenders could be found for logger (org.apache.kafka.clients.producer.ProducerConfig).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
Exception in thread "main" java.lang.NoClassDefFoundError: com/fasterxml/jackson/databind/Module
at coinyser.StreamingProducerApp$.run(StreamingProducerApp.scala:24)
at cats.effect.IOApp$$anonfun$main$2.apply(IOApp.scala:68)
at cats.effect.IOApp$$anonfun$main$2.apply(IOApp.scala:68)
at cats.effect.internals.IOAppPlatform$$anonfun$mainFiber$2.apply(IOAppPlatform.scala:43)
at cats.effect.internals.IOAppPlatform$$anonfun$mainFiber$2.apply(IOAppPlatform.scala:42)
at cats.effect.internals.IORunLoop$.liftedTree3$1(IORunLoop.scala:217)
at cats.effect.internals.IORunLoop$.step(IORunLoop.scala:217)
at cats.effect.IO.unsafeRunTimed(IO.scala:317)
at cats.effect.IO.unsafeRunSync(IO.scala:251)
at cats.effect.internals.IOAppPlatform$.main(IOAppPlatform.scala:28)
at cats.effect.IOApp$class.main(IOApp.scala:68)
at coinyser.StreamingProducerApp$.main(StreamingProducerApp.scala:9)
at coinyser.StreamingProducerApp.main(StreamingProducerApp.scala)
Caused by: java.lang.ClassNotFoundException: com.fasterxml.jackson.databind.Module
at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
at java.lang.ClassLoader.loadClass(ClassLoader.java:418)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:355)
at java.lang.ClassLoader.loadClass(ClassLoader.java:351)
... 13 more
Process finished with exit code 1
name := "bitcoin-analyser"
version := "0.1"
scalaVersion := "2.11.11"
val sparkVersion = "2.3.1"
libraryDependencies ++= Seq(
"org.apache.spark" %% "spark-core" % sparkVersion % Provided,
"org.apache.spark" %% "spark-core" % sparkVersion % Test classifier "tests",
"org.apache.spark" %% "spark-core" % sparkVersion % Test classifier "test-sources",
"org.apache.spark" %% "spark-sql" % sparkVersion % Provided,
"org.apache.spark" %% "spark-sql" % sparkVersion % Test classifier "tests",
"org.apache.spark" %% "spark-sql" % sparkVersion % Test classifier "test-sources",
"org.apache.spark" %% "spark-catalyst" % sparkVersion % Test classifier "tests",
"org.apache.spark" %% "spark-catalyst" % sparkVersion % Test classifier "test-sources",
"com.typesafe.scala-logging" %% "scala-logging" % "3.9.0",
"org.scalatest" %% "scalatest" % "3.0.4" % "test",
"org.typelevel" %% "cats-core" % "1.1.0",
"org.typelevel" %% "cats-effect" % "1.0.0-RC2",
"org.apache.spark" %% "spark-streaming" % sparkVersion % Provided,
"org.apache.spark" %% "spark-sql-kafka-0-10" % sparkVersion,
"com.pusher" % "pusher-java-client" % "1.8.0",
"org.apache.hadoop" % "hadoop-common" % "2.3.0",
"org.apache.kafka" % "kafka-clients" % "1.1.1")
scalacOptions += "-Ypartial-unification"
// Avoids SI-3623
target := file("/tmp/sbt/bitcoin-analyser")
assemblyOption in assembly := (assemblyOption in assembly).value.copy(includeScala = false)
test in assembly := {}
assemblyMergeStrategy in assembly := {
case PathList("META-INF", xs @ _*) => MergeStrategy.discard
case x => MergeStrategy.first
}
mainClass in assembly := Some("coinyser.BatchProducerAppSpark")
最佳答案
spark-sql-kafka-0-10
已经包含 kafka-clients
,这反过来每个导入 Jackson ,并为它们声明不同的版本将有这样的类路径异常
虽然,不清楚为什么你甚至需要 Spark 或 Hadoop,因为你只是使用普通的 Kafka Producer API 并且从不初始化 Spark 对象
关于scala - 线程 "main"java.lang.NoClassDefFoundError : com/fasterxml/jackson/databind/Module in Intellij while running Kafka App? 中的异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59090222/
我一直在尝试在我的代码中使用 Jar 文件作为库,并且它编译得很好。但是,在运行时,我不断收到 NoClassDefFoundError信息。为什么会这样?我也在编译路径和运行时路径中包含了 Jar
关于Apache-Kafka messaging queue . 我已经从 Kafka 下载页面下载了 Apache Kafka。我已将其提取到 /opt/apache/installed/kafka
我正在尝试使用 Apache DefaultHttpClient 来执行 JSON POST 请求,当我尝试实例化它时它给我一个 NoClassDefFound 错误。 HttpClient clie
当我在模拟器(Nexus One API 22)上测试我的应用程序时,它运行顺利,没有失败。然而,当我在自己的个人手机(三星 Galaxy S5,Android 版本 5.0)上测试该应用程序时,它崩
我需要在python中使用java代码来减少,所以我选择了Jython。一段时间后,我设法弄清楚了如何运行我的代码,但我遇到了最奇怪的事情。当我写作时 from vohmm.corpus import
这是我的mybatis配置。这是我的pom.xml。。当我运行项目时,它显示了错误的原因:org/mybatis/spring/mapper/MapperScannerConfigurer.有没有人能
所以我正在尝试构建一个简单的gradle应用,当我运行它时, geb.ConfigurationLoader$UnableToLoadException: Unable to load configu
假设我有一个主类应用程序,它使用 URLClassLoader 加载子目录 plugins 中的所有 jar: public class App(){ public static void m
我在尝试运行 Netbeans (7.2) 时遇到一个反复出现的错误,上次遇到它时,我发现某个地方可以将所有文件移动到一个新项目。这可能会奏效,但我的项目的规模让这很麻烦。这是踪迹... Except
这个问题已经有答案了: Including all the jars in a directory within the Java classpath (25 个回答) 已关闭 6 年前。 我得到一个
在这里,我正在下载网页源代码,然后将其存储在文本文件中。然后我读取该文件并将其与正则表达式匹配以搜索特定字符串。 没有编译器错误。 Exception in thread "main" java.la
我正在一个“大”的 Maven/Java 项目中工作,无法理解运行应用程序时遇到的错误(它编译正常)。我得到的错误代码是: java.lang.NoClassDefFoundError: Could
对于学校的作业,我需要创建一个类 Blender 来实现一些预定义的东西。我收到了一个 JAR 文件 imagecompositor.jar,它可以完成所有操作并使用 Blender 类。 JAR 文
我遇到了一个问题,即抛出 NoClasDefFoundError。这让我感到困惑,因为我正在使用接口(interface),并且没有类定义应该可用。我已经阅读了一些指向类路径的帖子,但我不认为这是这里
我正在使用 hibernate,在使用 hibernate Connection 时出现如下错误 java.lang.NoClassDefFoundError: Could not initializ
我有一个使用 SubVersion 的 Android 项目。我使用 Subclipse 将项目导入我的 Eclipse Wordspace。 现在我有一个问题: java.lang.NoClass
我需要编译一个外部 java 文件(比如 a.java)。这是我为此编写的代码。 (字符串路径包含java和class文件的路径) command[0] = "javac"; comm
我正在尝试运行一个基本的 Hibernate 程序。当我运行它时,出现以下错误 java.lang.NoClassDefFoundError: org/jboss/logging/BasicLogge
标题:Eclipse插件开发由于java.lang.NoClassDefFoundError无法实例化类: 试图构建一个 eclipse 插件,但遇到一些运行时错误.. 我知道这是由于代码所依赖的类文
我是新手,我无法让它工作......:/ 我的 build.sbt: val apacheDeps = Seq( "commons-validator" % "commons-validator"
我是一名优秀的程序员,十分优秀!