【问题标题】:Py4JJavaError: An error occurred while calling z:org.apache.spark.api.python.PythonRDD.runJobPy4JJavaError: 调用 z:org.apache.spark.api.python.PythonRDD.runJob 时出错
【发布时间】:2019-03-05 05:26:14
【问题描述】:

我在运行 Python 3.6.5 的 Jupyter notebook 和运行 3.7.2 的 Python shell 中遇到此错误。我的操作系统是 Windows 10。我在两个环境中都做了 pip install pyspark。两者都使用Spark 2.4.0版,我的Java JDK是Oracle JDK 8版,jdk1.8.0_201。这是我在两种情况下都运行的代码:

>>> from pyspark import SparkConf, SparkContext
>>> conf = SparkConf().setAppName("app")
>>> sc = SparkContext(conf=conf)
>>> import os

>>> os.chdir("C:/Users/theca/Desktop/school_folders/Big Data")
>>> data = sc.textFile("post_codes.txt")
>>> data.take(1)

我使用的是 JRE 版本 8,我验证了 JAVA_HOME:

C:\Python\Python37\Scripts>echo %JAVA_HOME%

C:\ProgramData\Oracle\Java\javapath\java.exe

我改用 JDK 认为可以解决问题:

C:\Program Files\Java\jdk1.8.0_201>setx JAVA_HOME "C:\Program Files\Java\jdk1.8.0_201"

SUCCESS: Specified value was saved.

C:\Program Files\Java\jdk1.8.0_201>setx PATH "%PATH%;%JAVA_HOME%\bin";

WARNING: The data being saved is truncated to 1024 characters.

我退出 cmd 并返回,验证了我的 java home:

C:\WINDOWS\system32>echo %JAVA_HOME% C:\Program Files\Java\jdk1.8.0_201

我在这里尝试过解决方案: PySpark exception: Java gateway process exited before sending its port number

这里: Pyspark: SparkContext definition in Spyder throws Java gateway error

以及此板上的其他一些答案。我想知道是否可能需要使用早期版本的 spark? 以下是错误信息的全部内容:

Traceback (most recent call last):
  File "<pyshell#9>", line 1, in <module>
    data.take(1)
  File "C:\Python\Python37\lib\site-packages\pyspark\rdd.py", line 1327, in take
    totalParts = self.getNumPartitions()
  File "C:\Python\Python37\lib\site-packages\pyspark\rdd.py", line 391, in getNumPartitions
    return self._jrdd.partitions().size()
  File "C:\Python\Python37\lib\site-packages\py4j\java_gateway.py", line 1257, in __call__
    answer, self.gateway_client, self.target_id, self.name)
  File "C:\Python\Python37\lib\site-packages\py4j\protocol.py", line 328, in get_return_value
    format(target_id, ".", name), value)
py4j.protocol.Py4JJavaError: An error occurred while calling o20.partitions.
: org.apache.hadoop.mapred.InvalidInputException: Input path does not exist: file:/C:/Python/Python37/post_codes.txt

at org.apache.hadoop.mapred.FileInputFormat.singleThreadedListStatus(FileInputFormat.java:287)

at org.apache.hadoop.mapred.FileInputFormat.listStatus(FileInputFormat.java:229)

at org.apache.hadoop.mapred.FileInputFormat.getSplits(FileInputFormat.java:315)

at org.apache.spark.rdd.HadoopRDD.getPartitions(HadoopRDD.scala:204)

at org.apache.spark.rdd.RDD$$anonfun$partitions$2.apply(RDD.scala:253)

at org.apache.spark.rdd.RDD$$anonfun$partitions$2.apply(RDD.scala:251)

at scala.Option.getOrElse(Option.scala:121)

at org.apache.spark.rdd.RDD.partitions(RDD.scala:251)

at org.apache.spark.rdd.MapPartitionsRDD.getPartitions(MapPartitionsRDD.scala:49)

at org.apache.spark.rdd.RDD$$anonfun$partitions$2.apply(RDD.scala:253)

at org.apache.spark.rdd.RDD$$anonfun$partitions$2.apply(RDD.scala:251)

at scala.Option.getOrElse(Option.scala:121)

at org.apache.spark.rdd.RDD.partitions(RDD.scala:251)

at org.apache.spark.api.java.JavaRDDLike$class.partitions(JavaRDDLike.scala:61)

at org.apache.spark.api.java.AbstractJavaRDDLike.partitions(JavaRDDLike.scala:45)

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 py4j.reflection.MethodInvoker.invoke(MethodInvoker.java:244)

at py4j.reflection.ReflectionEngine.invoke(ReflectionEngine.java:357)

at py4j.Gateway.invoke(Gateway.java:282)

at py4j.commands.AbstractCommand.invokeMethod(AbstractCommand.java:132)

at py4j.commands.CallCommand.execute(CallCommand.java:79)

at py4j.GatewayConnection.run(GatewayConnection.java:238)

at java.lang.Thread.run(Thread.java:748)

【问题讨论】:

  • 嗯,这很奇怪:Input path does not exist: file:/C:/Python/Python37/post_codes.txt,我假设你已经尝试过 data = sc.textFile("absolute/path/to/post_codes.txt")
  • @mkaran 我不确定你的意思,但如果你问我是否尝试过直接路径而不是 os.chdir,那么是的,我有,结果是一样的。
  • 是的,这就是我的意思,因为这似乎是主要的例外,感谢您的回答。
  • 看来 os.chdir 无论如何都被忽略了!或者你可能有一个无效的路径!例如,我不喜欢“大数据”上的这个空间 :) 我会先尝试使用绝对路径和不同的文件夹,例如:sc.textFile("C:/Users/theca/Desktop/school_folders/Big_Data/post_codes.txt")
  • @AlexandrosBiratsis,我刚刚通过手动输入创建了一个 RDD: data_heterogeneous = sc.parallelize([('Ferrari','fast'), {"Porche": 100000}, ["Spain", "visited", 4504]]).collect() 执行 sc.take(1) 后仍然出现 py4jjava 错误。

标签: python-3.x java-8 pyspark


【解决方案1】:

尝试以下方法:

data = sc.textFile("file:///path to the file/")

这应该可行。

【讨论】:

  • 它对我不起作用。我在创建的 RDD 上也收到 py4jj 错误,即不是我读入的文件。不过还是谢谢。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2020-02-10
  • 2020-08-06
  • 2021-11-15
  • 2021-01-20
  • 1970-01-01
  • 2019-10-27
  • 2019-05-26
相关资源
最近更新 更多