gpt4 book ai didi

apache-spark - 由 async-http-client 引起的 Spark 中的 IllegalAccessError

转载 作者:行者123 更新时间:2023-12-04 04:02:50 30 4
gpt4 key购买 nike

上下文:我正在处理将数据写入 InfluxDB 的 Spark 流作业,使用 this library .这里的环境。

  • 斯卡拉 2.11.8
  • Spark 2.1.0(Dockerized 独立集群)

  • 相关依赖:
    "org.apache.spark" %% "spark-core" % "2.1.0" % "provided",
    "org.apache.spark" %% "spark-streaming" % "2.1.0" % "provided",
    "org.apache.spark" %% "spark-streaming-kafka-0-8" % "2.1.0",
    "com.paulgoldbaum" %% "scala-influxdb-client" % "0.5.2" // which uses "org.asynchttpclient" % "async-http-client" % "2.0.24"

    一切都在我的本地计算机上编译并运行良好,但是当我将程序集 jar 提交到 Spark 集群时,我在驱动程序中收到此错误:
    Exception in thread "main" java.lang.reflect.InvocationTargetException
    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.worker.DriverWrapper$.main(DriverWrapper.scala:58)
    at org.apache.spark.deploy.worker.DriverWrapper.main(DriverWrapper.scala)
    Caused by: java.lang.IllegalAccessError: tried to access field io.netty.handler.ssl.JdkSslContext.SUPPORTED_CIPHERS from class io.netty.handler.ssl.NettySslPackageAccessor
    at io.netty.handler.ssl.NettySslPackageAccessor.jdkSupportedCipherSuites(NettySslPackageAccessor.java:24)
    at org.asynchttpclient.config.AsyncHttpClientConfigDefaults.defaultEnabledCipherSuites(AsyncHttpClientConfigDefaults.java:85)
    at org.asynchttpclient.DefaultAsyncHttpClientConfig$Builder.<init>(DefaultAsyncHttpClientConfig.java:635)
    at org.asynchttpclient.DefaultAsyncHttpClient.<init>(DefaultAsyncHttpClient.java:67)
    at com.paulgoldbaum.influxdbclient.HttpClient.<init>(HttpClient.scala:21)
    at com.paulgoldbaum.influxdbclient.InfluxDB$.connect(InfluxDB.scala:16)
    ...

    如果我删除写入 InfluxDB 的代码,问题就会消失。

    环顾四周后,我了解到类(class) io.netty.handler.ssl.NettySslPackageAccessor居然属于 async-http-client图书馆。在 io.netty.handler.ssl.JdkSslContext 中访问 protected 成员似乎是一个黑客级别.

    我被这个问题困扰了几天。我让它工作的解决方案是覆盖 async-http-client到不包含违规代码的早期版本。
    dependencyOverrides ++= Set("org.asynchttpclient" % "async-http-client" % "2.0.12")

    问题:为什么是 IllegalAccessError只发生在集群上而不是在我的本地运行中?有没有更好的方法来解决这个问题?

    如果我的 SBT 可以正常编译,那么就不应该有这样的 IllegalAccessError ,所以这意味着我的本地代码和集群代码之间存在差异,这可能是 provided spark 依赖项,但它与集群的版本相同。

    我可以保持原样,但如果可以使用较新的版本会更好。或者至少我想了解为什么会出现这个问题并在将来避免它。

    最佳答案

    这是由 io.netty:netty 引起的和 org.asynchttpclient:async-http-client在你的类路径中。如果您想使用 netty 和 assync-http-client,请将以下依赖项添加到您的 gradle(类似于 maven pom.xml)构建脚本:
    compile 'org.asynchttpclient:async-http-client:2.0.38'
    compile 'org.asynchttpclient:async-http-client-netty-utils:2.0.38'

    关于apache-spark - 由 async-http-client 引起的 Spark 中的 IllegalAccessError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41689643/

    30 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com