Uploaded image for project: 'Spark'
  1. Spark
  2. SPARK-15345

SparkSession's conf doesn't take effect when there's already an existing SparkContext

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Closed
    • Blocker
    • Resolution: Fixed
    • None
    • 2.0.0
    • PySpark, SQL
    • None

    Description

      I am working with branch-2.0, spark is compiled with hive support (-Phive and -Phvie-thriftserver).
      I am trying to access databases using this snippet:

      from pyspark.sql import HiveContext
      hc = HiveContext(sc)
      hc.sql("show databases").collect()
      [Row(result='default')]
      

      This means that spark doesn't find any databases specified in configuration.
      Using the same configuration (i.e. hive-site.xml and core-site.xml) in spark 1.6, and launching above snippet, I can print out existing databases.

      When run in DEBUG mode this is what spark (2.0) prints out:

      16/05/16 12:17:47 INFO SparkSqlParser: Parsing command: show databases
      16/05/16 12:17:47 DEBUG SimpleAnalyzer: 
      === Result of Batch Resolution ===
      !'Project [unresolveddeserializer(createexternalrow(if (isnull(input[0, string])) null else input[0, string].toString, StructField(result,StringType,false)), result#2) AS #3]   Project [createexternalrow(if (isnull(result#2)) null else result#2.toString, StructField(result,StringType,false)) AS #3]
       +- LocalRelation [result#2]                                                                                                                                                     +- LocalRelation [result#2]
              
      16/05/16 12:17:47 DEBUG ClosureCleaner: +++ Cleaning closure <function1> (org.apache.spark.sql.Dataset$$anonfun$53) +++
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared fields: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public static final long org.apache.spark.sql.Dataset$$anonfun$53.serialVersionUID
      16/05/16 12:17:47 DEBUG ClosureCleaner:      private final org.apache.spark.sql.types.StructType org.apache.spark.sql.Dataset$$anonfun$53.structType$1
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared methods: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final java.lang.Object org.apache.spark.sql.Dataset$$anonfun$53.apply(java.lang.Object)
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final java.lang.Object org.apache.spark.sql.Dataset$$anonfun$53.apply(org.apache.spark.sql.catalyst.InternalRow)
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + inner classes: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer classes: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer objects: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + populating accessed fields because this is the starting closure
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + fields accessed by starting closure: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + there are no enclosing objects!
      16/05/16 12:17:47 DEBUG ClosureCleaner:  +++ closure <function1> (org.apache.spark.sql.Dataset$$anonfun$53) is now cleaned +++
      16/05/16 12:17:47 DEBUG ClosureCleaner: +++ Cleaning closure <function1> (org.apache.spark.sql.execution.python.EvaluatePython$$anonfun$javaToPython$1) +++
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared fields: 1
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public static final long org.apache.spark.sql.execution.python.EvaluatePython$$anonfun$javaToPython$1.serialVersionUID
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared methods: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final java.lang.Object org.apache.spark.sql.execution.python.EvaluatePython$$anonfun$javaToPython$1.apply(java.lang.Object)
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final org.apache.spark.api.python.SerDeUtil$AutoBatchedPickler org.apache.spark.sql.execution.python.EvaluatePython$$anonfun$javaToPython$1.apply(scala.collection.Iterator)
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + inner classes: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer classes: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer objects: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + populating accessed fields because this is the starting closure
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + fields accessed by starting closure: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + there are no enclosing objects!
      16/05/16 12:17:47 DEBUG ClosureCleaner:  +++ closure <function1> (org.apache.spark.sql.execution.python.EvaluatePython$$anonfun$javaToPython$1) is now cleaned +++
      16/05/16 12:17:47 DEBUG ClosureCleaner: +++ Cleaning closure <function1> (org.apache.spark.rdd.RDD$$anonfun$collect$1$$anonfun$13) +++
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared fields: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public static final long org.apache.spark.rdd.RDD$$anonfun$collect$1$$anonfun$13.serialVersionUID
      16/05/16 12:17:47 DEBUG ClosureCleaner:      private final org.apache.spark.rdd.RDD$$anonfun$collect$1 org.apache.spark.rdd.RDD$$anonfun$collect$1$$anonfun$13.$outer
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared methods: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final java.lang.Object org.apache.spark.rdd.RDD$$anonfun$collect$1$$anonfun$13.apply(java.lang.Object)
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final java.lang.Object org.apache.spark.rdd.RDD$$anonfun$collect$1$$anonfun$13.apply(scala.collection.Iterator)
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + inner classes: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer classes: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      org.apache.spark.rdd.RDD$$anonfun$collect$1
      16/05/16 12:17:47 DEBUG ClosureCleaner:      org.apache.spark.rdd.RDD
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer objects: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      <function0>
      16/05/16 12:17:47 DEBUG ClosureCleaner:      MapPartitionsRDD[5] at collect at <stdin>:1
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + populating accessed fields because this is the starting closure
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + fields accessed by starting closure: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      (class org.apache.spark.rdd.RDD$$anonfun$collect$1,Set($outer))
      16/05/16 12:17:47 DEBUG ClosureCleaner:      (class org.apache.spark.rdd.RDD,Set(org$apache$spark$rdd$RDD$$evidence$1))
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outermost object is not a closure or REPL line object, so do not clone it: (class org.apache.spark.rdd.RDD,MapPartitionsRDD[5] at collect at <stdin>:1)
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + cloning the object <function0> of class org.apache.spark.rdd.RDD$$anonfun$collect$1
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + cleaning cloned closure <function0> recursively (org.apache.spark.rdd.RDD$$anonfun$collect$1)
      16/05/16 12:17:47 DEBUG ClosureCleaner: +++ Cleaning closure <function0> (org.apache.spark.rdd.RDD$$anonfun$collect$1) +++
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared fields: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public static final long org.apache.spark.rdd.RDD$$anonfun$collect$1.serialVersionUID
      16/05/16 12:17:47 DEBUG ClosureCleaner:      private final org.apache.spark.rdd.RDD org.apache.spark.rdd.RDD$$anonfun$collect$1.$outer
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared methods: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public org.apache.spark.rdd.RDD org.apache.spark.rdd.RDD$$anonfun$collect$1.org$apache$spark$rdd$RDD$$anonfun$$$outer()
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final java.lang.Object org.apache.spark.rdd.RDD$$anonfun$collect$1.apply()
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + inner classes: 1
      16/05/16 12:17:47 DEBUG ClosureCleaner:      org.apache.spark.rdd.RDD$$anonfun$collect$1$$anonfun$13
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer classes: 1
      16/05/16 12:17:47 DEBUG ClosureCleaner:      org.apache.spark.rdd.RDD
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer objects: 1
      16/05/16 12:17:47 DEBUG ClosureCleaner:      MapPartitionsRDD[5] at collect at <stdin>:1
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + fields accessed by starting closure: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      (class org.apache.spark.rdd.RDD$$anonfun$collect$1,Set($outer))
      16/05/16 12:17:47 DEBUG ClosureCleaner:      (class org.apache.spark.rdd.RDD,Set(org$apache$spark$rdd$RDD$$evidence$1))
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outermost object is not a closure or REPL line object, so do not clone it: (class org.apache.spark.rdd.RDD,MapPartitionsRDD[5] at collect at <stdin>:1)
      16/05/16 12:17:47 DEBUG ClosureCleaner:  +++ closure <function0> (org.apache.spark.rdd.RDD$$anonfun$collect$1) is now cleaned +++
      16/05/16 12:17:47 DEBUG ClosureCleaner:  +++ closure <function1> (org.apache.spark.rdd.RDD$$anonfun$collect$1$$anonfun$13) is now cleaned +++
      16/05/16 12:17:47 DEBUG ClosureCleaner: +++ Cleaning closure <function2> (org.apache.spark.SparkContext$$anonfun$runJob$5) +++
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared fields: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public static final long org.apache.spark.SparkContext$$anonfun$runJob$5.serialVersionUID
      16/05/16 12:17:47 DEBUG ClosureCleaner:      private final scala.Function1 org.apache.spark.SparkContext$$anonfun$runJob$5.cleanedFunc$1
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + declared methods: 2
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final java.lang.Object org.apache.spark.SparkContext$$anonfun$runJob$5.apply(java.lang.Object,java.lang.Object)
      16/05/16 12:17:47 DEBUG ClosureCleaner:      public final java.lang.Object org.apache.spark.SparkContext$$anonfun$runJob$5.apply(org.apache.spark.TaskContext,scala.collection.Iterator)
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + inner classes: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer classes: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + outer objects: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + populating accessed fields because this is the starting closure
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + fields accessed by starting closure: 0
      16/05/16 12:17:47 DEBUG ClosureCleaner:  + there are no enclosing objects!
      16/05/16 12:17:47 DEBUG ClosureCleaner:  +++ closure <function2> (org.apache.spark.SparkContext$$anonfun$runJob$5) is now cleaned +++
      16/05/16 12:17:47 INFO SparkContext: Starting job: collect at <stdin>:1
      16/05/16 12:17:47 INFO DAGScheduler: Got job 1 (collect at <stdin>:1) with 1 output partitions
      16/05/16 12:17:47 INFO DAGScheduler: Final stage: ResultStage 1 (collect at <stdin>:1)
      16/05/16 12:17:47 INFO DAGScheduler: Parents of final stage: List()
      16/05/16 12:17:47 INFO DAGScheduler: Missing parents: List()
      16/05/16 12:17:47 DEBUG DAGScheduler: submitStage(ResultStage 1)
      16/05/16 12:17:47 DEBUG DAGScheduler: missing: List()
      16/05/16 12:17:47 INFO DAGScheduler: Submitting ResultStage 1 (MapPartitionsRDD[5] at collect at <stdin>:1), which has no missing parents
      16/05/16 12:17:47 DEBUG DAGScheduler: submitMissingTasks(ResultStage 1)
      16/05/16 12:17:47 INFO MemoryStore: Block broadcast_1 stored as values in memory (estimated size 3.1 KB, free 5.8 GB)
      16/05/16 12:17:47 DEBUG BlockManager: Put block broadcast_1 locally took  1 ms
      16/05/16 12:17:47 DEBUG BlockManager: Putting block broadcast_1 without replication took  1 ms
      16/05/16 12:17:47 INFO MemoryStore: Block broadcast_1_piece0 stored as bytes in memory (estimated size 1856.0 B, free 5.8 GB)
      16/05/16 12:17:47 INFO BlockManagerInfo: Added broadcast_1_piece0 in memory on 188.165.13.157:35738 (size: 1856.0 B, free: 5.8 GB)
      16/05/16 12:17:47 DEBUG BlockManagerMaster: Updated info of block broadcast_1_piece0
      16/05/16 12:17:47 DEBUG BlockManager: Told master about block broadcast_1_piece0
      16/05/16 12:17:47 DEBUG BlockManager: Put block broadcast_1_piece0 locally took  1 ms
      16/05/16 12:17:47 DEBUG BlockManager: Putting block broadcast_1_piece0 without replication took  2 ms
      16/05/16 12:17:47 INFO SparkContext: Created broadcast 1 from broadcast at DAGScheduler.scala:1012
      16/05/16 12:17:47 INFO DAGScheduler: Submitting 1 missing tasks from ResultStage 1 (MapPartitionsRDD[5] at collect at <stdin>:1)
      16/05/16 12:17:47 DEBUG DAGScheduler: New pending partitions: Set(0)
      16/05/16 12:17:47 INFO TaskSchedulerImpl: Adding task set 1.0 with 1 tasks
      16/05/16 12:17:47 DEBUG TaskSetManager: Epoch for TaskSet 1.0: 0
      16/05/16 12:17:47 DEBUG TaskSetManager: Valid locality levels for TaskSet 1.0: NO_PREF, ANY
      16/05/16 12:17:47 DEBUG TaskSchedulerImpl: parentName: , name: TaskSet_1, runningTasks: 0
      16/05/16 12:17:47 INFO TaskSetManager: Starting task 0.0 in stage 1.0 (TID 1, xxx3, partition 0, PROCESS_LOCAL, 5542 bytes)
      16/05/16 12:17:47 DEBUG TaskSetManager: No tasks for locality level NO_PREF, so moving to locality level ANY
      16/05/16 12:17:47 INFO SparkDeploySchedulerBackend: Launching task 1 on executor id: 0 hostname: xxx3.
      16/05/16 12:17:48 DEBUG TaskSchedulerImpl: parentName: , name: TaskSet_1, runningTasks: 1
      16/05/16 12:17:48 DEBUG BlockManager: Getting local block broadcast_1_piece0 as bytes
      16/05/16 12:17:48 DEBUG BlockManager: Level for block broadcast_1_piece0 is StorageLevel(disk=true, memory=true, offheap=false, deserialized=false, replication=1)
      16/05/16 12:17:48 INFO BlockManagerInfo: Added broadcast_1_piece0 in memory on 188.165.13.158:53616 (size: 1856.0 B, free: 14.8 GB)
      16/05/16 12:17:49 DEBUG TaskSchedulerImpl: parentName: , name: TaskSet_1, runningTasks: 1
      16/05/16 12:17:50 DEBUG TaskSchedulerImpl: parentName: , name: TaskSet_1, runningTasks: 1
      16/05/16 12:17:50 DEBUG TaskSchedulerImpl: parentName: , name: TaskSet_1, runningTasks: 0
      16/05/16 12:17:50 INFO TaskSetManager: Finished task 0.0 in stage 1.0 (TID 1) in 2156 ms on xxx3 (1/1)
      16/05/16 12:17:50 INFO TaskSchedulerImpl: Removed TaskSet 1.0, whose tasks have all completed, from pool 
      16/05/16 12:17:50 INFO DAGScheduler: ResultStage 1 (collect at <stdin>:1) finished in 2.158 s
      16/05/16 12:17:50 DEBUG DAGScheduler: After removal of stage 1, remaining stages = 0
      16/05/16 12:17:50 INFO DAGScheduler: Job 1 finished: collect at <stdin>:1, took 2.174808 s
      

      I can't see any information on Hive connection in this trace.

      Attachments

        Issue Links

          Activity

            People

              rxin Reynold Xin
              m1lan Piotr Milanowski
              Votes:
              0 Vote for this issue
              Watchers:
              16 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved: