Dagster Data Engineering Glossary:
Data Shuffling
data:image/s3,"s3://crabby-images/eb8c2/eb8c25fe8746bf3192086b6987419daf4719052e" alt="Glossary entry badge for Shuffle"
Data shuffling definition:
Data shuffling is a process in modern data pipelines where the data is randomly redistributed across different partitions to enable parallel processing and better performance. Shuffling is generally done after some processing has been completed on the data, such as sorting or grouping, and before additional processing is performed. Shuffling can be an expensive operation in terms of time and resources, especially for large datasets.
Data shuffling example using Python:
In Python, data shuffling can be performed using various libraries such as Apache Spark or Dask. Here is an example of shuffling data using Apache Spark: Please note that you need to have the necessary Python libraries installed in your Python environment to run this code.
# Import necessary libraries
from pyspark.sql.functions import rand
from pyspark.sql.functions import col
from pyspark.sql import SparkSession
# create a SparkSession object
spark = SparkSession.builder.appName("DataShreddingExample").getOrCreate()
# Load data into Spark DataFrame
df = spark.read.csv("data.csv", header=True, inferSchema=True)
# Shuffle the DataFrame by randomizing the order of rows, shen print it out
df_shuffled = df.orderBy(rand()).show()
In this example, we first load the data into a Spark DataFrame. We then use the rand()
function to shuffle the rows in the DataFrame randomly. Note that the output will change on each execution since it is randomized.
So for a simple input file of
Col A,Col B
Item 1,A
Item 2,B
Item 3,C
Item 4,D
The output of the code might look like this:
+------+-----+
| Col A|Col B|
+------+-----+
|Item 4| D|
|Item 3| C|
|Item 1| A|
|Item 2| B|
+------+-----+
Note that shuffling can be an expensive operation, so it's important to use it judiciously and only when necessary. It's also important to carefully manage the resources required for shuffling, such as memory and network bandwidth, to avoid overloading the system.
Backpressure
data:image/s3,"s3://crabby-images/56c80/56c8032df42ec99bdac72ed40b5a782048e52526" alt="An image representing the data engineering concept of 'Backpressure'"
Compact
data:image/s3,"s3://crabby-images/dfd1a/dfd1abc6fd3f4dd8b443bb37b947448ae107c83b" alt="An image representing the data engineering concept of 'Compact'"
Compress
data:image/s3,"s3://crabby-images/67131/67131b4293c101b34f5bace0a926b70cbb8ddf0f" alt="An image representing the data engineering concept of 'Compress'"
Ingest
data:image/s3,"s3://crabby-images/02559/02559837c72f7678bf5dc811492cd74b0e577565" alt="An image representing the data engineering concept of 'Ingest'"
Load
data:image/s3,"s3://crabby-images/6fe8b/6fe8b65d859fa2faa23e3398225f24a6cf29a72f" alt="An image representing the data engineering concept of 'Load'"
NoSQL
Pickle
Rebalance
data:image/s3,"s3://crabby-images/1d800/1d800eb42d0867e8873aac9b21c572a294d10383" alt="An image representing the data engineering concept of 'Rebalance'"
Repartition
Scrape
data:image/s3,"s3://crabby-images/93db8/93db8ceb55a3de914c475906be361cc0d4369f4f" alt="An image representing the data engineering concept of 'Scrape'"
Shard
Spill
data:image/s3,"s3://crabby-images/54bb8/54bb8c8f320b53ce408c643588c9336e37fd0c89" alt="An image representing the data engineering concept of 'Spill'"
Stored Procedure
data:image/s3,"s3://crabby-images/46b3e/46b3e03566a0191a825c33f8c96b0bf60dbdf0d0" alt="An image representing the data engineering concept of 'Stored Procedure'"
Upsert
data:image/s3,"s3://crabby-images/e054f/e054f9ebedc2020d9a450988bd0cbaf06e21c0f0" alt="An image representing the data engineering concept of 'Upsert'"