PySpark - StorageLevel
StorageLevel तय करता है कि RDD को कैसे संग्रहीत किया जाना चाहिए। अपाचे स्पार्क में, StorageLevel यह तय करता है कि RDD को मेमोरी में संग्रहीत किया जाना चाहिए या इसे डिस्क पर संग्रहीत किया जाना चाहिए, या दोनों। यह भी तय करता है कि क्या आरडीडी को क्रमबद्ध करना है और क्या आरडीडी विभाजन को दोहराया जाना है।
निम्नलिखित कोड ब्लॉक में StorageLevel की वर्ग परिभाषा है -
class pyspark.StorageLevel(useDisk, useMemory, useOffHeap, deserialized, replication = 1)
अब, RDD के भंडारण का निर्णय लेने के लिए, विभिन्न भंडारण स्तर हैं, जो नीचे दिए गए हैं -
DISK_ONLY = स्टोरेजवेल (सच, गलत, गलत, गलत, 1)
DISK_ONLY_2 = स्टोरेजवेल (सच, गलत, गलत, गलत, 2)
MEMORY_AND_DISK = स्टोरेजवेल (सच, सच, गलत, गलत, 1)
MEMORY_AND_DISK_2 = स्टोरेजवेल (सच, सच, गलत, गलत, 2)
MEMORY_AND_DISK_SER = स्टोरेजवेल (सच, सच, गलत, गलत, 1)
MEMORY_AND_DISK_SER_2 = स्टोरेजवेल (सच, सच, गलत, गलत, 2)
MEMORY_ONLY = स्टोरेजवेल (झूठी, सच्ची, झूठी, झूठी, १)
MEMORY_ONLY_2 = स्टोरेजवेल (गलत, सच, गलत, गलत, 2)
MEMORY_ONLY_SER = स्टोरेजवेल (झूठी, सच्ची, झूठी, झूठी, १)
MEMORY_ONLY_SER_2 = स्टोरेजवेल (गलत, सच, गलत, गलत, 2)
OFF_HEAP = स्टोरेजवेल (सच, सच्चा, सच्चा, गलत, 1)
हमें StorageLevel के निम्नलिखित उदाहरण पर विचार करें, जहां हम भंडारण स्तर का उपयोग करते हैं MEMORY_AND_DISK_2, जिसका मतलब है कि RDD विभाजन में 2 की प्रतिकृति होगी।
------------------------------------storagelevel.py-------------------------------------
from pyspark import SparkContext
import pyspark
sc = SparkContext (
"local",
"storagelevel app"
)
rdd1 = sc.parallelize([1,2])
rdd1.persist( pyspark.StorageLevel.MEMORY_AND_DISK_2 )
rdd1.getStorageLevel()
print(rdd1.getStorageLevel())
------------------------------------storagelevel.py-------------------------------------
Command - कमांड इस प्रकार है -
$SPARK_HOME/bin/spark-submit storagelevel.py
Output - उपरोक्त कमांड के लिए आउटपुट नीचे दिया गया है -
Disk Memory Serialized 2x Replicated