You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@spark.apache.org by "Vladimir Feinberg (JIRA)" <ji...@apache.org> on 2016/06/28 18:34:57 UTC
[jira] [Created] (SPARK-16262) Impossible to remake new
SparkContext using SparkSession API in Pyspark
Vladimir Feinberg created SPARK-16262:
-----------------------------------------
Summary: Impossible to remake new SparkContext using SparkSession API in Pyspark
Key: SPARK-16262
URL: https://issues.apache.org/jira/browse/SPARK-16262
Project: Spark
Issue Type: Bug
Components: PySpark
Reporter: Vladimir Feinberg
There are multiple use cases where one might like to be able to stop and re-start a {{SparkSession}}: configuration changes or modular testing. The following code demonstrates that without clearing a hidden global {{SparkSession._instantiatedContext = None}} it is impossible to re-create a new Spark session after stopping one in the same process:
{code}
>>> from pyspark.sql import SparkSession
>>> spark = SparkSession.builder.getOrCreate()
Using Spark's default log4j profile: org/apache/spark/log4j-defaults.properties
Setting default log level to "WARN".
To adjust logging level use sc.setLogLevel(newLevel).
16/06/28 11:28:10 WARN NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable
16/06/28 11:28:10 WARN Utils: Your hostname, vlad-databricks resolves to a loopback address: 127.0.1.1; using 192.168.3.166 instead (on interface enp0s31f6)
16/06/28 11:28:10 WARN Utils: Set SPARK_LOCAL_IP if you need to bind to another address
>>> spark.stop()
>>> spark = SparkSession.builder.getOrCreate()
>>> spark.createDataFrame([(1,)])
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "pyspark/sql/session.py", line 514, in createDataFrame
rdd, schema = self._createFromLocal(map(prepare, data), schema)
File "pyspark/sql/session.py", line 394, in _createFromLocal
return self._sc.parallelize(data), schema
File "pyspark/context.py", line 410, in parallelize
numSlices = int(numSlices) if numSlices is not None else self.defaultParallelism
File "pyspark/context.py", line 346, in defaultParallelism
return self._jsc.sc().defaultParallelism()
AttributeError: 'NoneType' object has no attribute 'sc'
{code}
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)
---------------------------------------------------------------------
To unsubscribe, e-mail: issues-unsubscribe@spark.apache.org
For additional commands, e-mail: issues-help@spark.apache.org