Master Reading Spark DAGs
ฝัง
- เผยแพร่เมื่อ 20 ก.ค. 2024
- Spark Performance Tuning
In this tutorial, we dive deep into the core of Apache Spark performance tuning by exploring the Spark DAGs (Directed Acyclic Graph).
We cover the Spark DAGs (Directed Acyclic Graph) for a range of operations from reading files, Spark narrow and wide transformations with examples, aggregation using groupBy count, groupBy count distinct. Understand the differences between sort merge and broadcast joins, and analyze the DAG from different perspectives with practical examples.
This video is a treasure trove for both beginners and experienced Spark users looking to optimize their code and understand the inner workings of Apache Spark. We examine the DAG, input batches, and partitions in great detail, understand the significance of metadata, and explore how Spark optimizes the execution of jobs and stages.
📄 Complete Code on GitHub: github.com/afaqueahmad7117/sp...
🎥 Full Spark Performance Tuning Playlist: • Apache Spark Performan...
🎥 Link to Spark Query Plan Video: • Master Reading Spark Q...
🔗 LinkedIn: / afaque-ahmad-5a5847129
Chapters:
00:00 Introduction
00:34 Module imports
00:51 Topics covered
01:54 Spark DAG for Reading a file
07:36 DAG for Narrow transformations
11:17 Wide transformations introduction
11:24 DAG for Sort Merge join (wide transformation)
18:30 DAG for Broadcast join (narrow transformation)
20:15 DAG for Aggregations Group by count (wide transformation)
24:41 DAG for Aggregations Group by sum (wide transformation)
25:44 DAG for Aggregations Group by count distinct (wide transformation)
#ApacheSpark #SparkPerformanceTuning #DataEngineering #SparkDAG #SparkOptimization
Amazing. This is just too good. Will share with my team also.
this is probably the best explanation I've seen on spark DAG's. Please keep up the amazing content! thank you
Explained so well!! Crystal clear!
again in depth content. Thanks a lot. Please discuss a scenario based question on todays topics.
Nice serie about performance, waiting for more videos, tranks.
amazing explanination ..Waiting for more videos from you
It's really informative session, thank you!!
Bro..Can't thank you enough... This is what exactly I was looking... Thanks a ton bro... 🎉
Beautiful content. Very clear and crystal explanation. Thank you for doing this. ❤❤
Glad you enjoyed it!
@Afaque asually amazing vedio bro. It's been more than 1 month we are dying of waiting for vedios from you
A new playlist coming soon brother :)
@@afaqueahmad7117 waiting
🔔🔔 Please remember to subscribe to the channel folks. It really motivates me to make more such videos :)
Done - awesome videos will watch the rest of the series. Would be great to get some databricks oriented videos also when possible
very good explanation, thanks. you earned a new subscriber
Done with the second video on this channel. See you tomorrow again.
Doing fantastic work bro.... Keep this up 💪❤
beautifully explained!
awesome explanation.👍
very well explained!!
Great explanation bro,thanks for the great work you are doing
Thank you @Learner1234-hv4be, really appreciate it :)
Nice explanation.Great work.Thank you .Liked and Subscribed.
Thank you @balakrishna61, appreciate it :)
Excellent bro
Amazing content. Keep it up
Appreciate it :)
Superb ❤
Thank you Bro!! your videos are very informative and helpful. Can you please one video explaining setting up spark in local machine. That will be very helpful
Thanks @ankursinhaa2466, videos on deployment (local and cluster) coming soon :)
Please make a dedicated video on shuffle partition... how it behaves when it's increased or decrease from 200
Hey @SHUBHAM_707, have you watched this - th-cam.com/video/q1LtBU_ca20/w-d-xo.html
Thank you very much for the explanation. But I want to know what is your source of knowledge. Where do you learn these things?
Could you also do a video on Spark SQL and how to read DAGs/Execution Plans for that? Amazing video btw, subscribed!!
Hey @subaruhassufferredenough7892, Thanks you for the kind words, really appreciate it :)
On Spark SQL, DAGs/Execution plans for both Spark SQL and non-SQL (python) are the same as they are compiled/optimized by the same underlying engine/catalyst optimizer.
thank you
Appreciate it :)
At 16:49, as part of the AQE plan for the larger dataset, the way that I understood is 1 skewed partition was split in 12 and finally we had 24+12 = 36 partitions. We see the same on Job Id 9 at 13:40 that it had 36 tasks. But I heard you say that 36 partitions have been reduced to 24. Can you please help clear the confusion ? thank you.
I think in that AQE Step, AQEShuffleRead reads 200 partitions (as per previous node) from customers dataset, then coalesced to 24 then something happened and make them to 36 thats why that right side node is showing "number of of partitions 36".
At left side for transactions dataset, this "number of of partitions 36" is appearing as last value where at right side for customers dataset its appearing as first value.
But Im not sure what is that " something"???
your expertise and explanations is like "filtered gold in one can " Can you make quick video on AQE in depth please. 1000 thanks
Thanks @jdisunil for the kind words. There's already an in-depth video on AQE.
You can refer here: th-cam.com/video/bRjVa7MgsBM/w-d-xo.html
Hi Afaque Ahmad
At 13:37 you were saying that separate job for shuffle operation that one job for transactions dataset shuffle operation and one for customers dataset.
Im bit confused why they need a separate job? As per my understanding, when spark encounters a shuffle operation, it just creates a new stage within that job right?
When I execute the same code snippet, it create 5 jobs totally: two for metadata (expected), two for shuffle operation (not expected) and final one is for join operation.
Many thanks
Hi Afaque Ahmad
At 7:24, you were saying that a batch is a group of rows and its not same as a partition.
Shall we assume something like
a group of rows read from one or more partitions available in one or more executors (not from all executors) to match that df.show() count?
Thanks for this. When is the next video coming sir?
Coming soon in the next few days! :)
How do you access this spark UI?
Hello Bro,
I have a doubt. at "23:30 min" playtime, it was mentioned that AQEShuffleRead: coalesced partitions into 1, then will the other worker nodes will sit ideal ?
In the Video it is mentioned that even after shuffle, all A's will be in 1 partition and B's in another partition.
can you please explain me, what do you actually mean by Number of Coalesced Partitions=1
Bhai , can help to make a video on spark architecture as well for beginners
Haan bhai, ayega kuch time mein :)
why shuffle partitions made 200 hundread. when we have only 13 partitions max. at 14:55
By default, shuffle partitions are 200, hence you see that in the 'Exchange' step. The reduction (optimization) to fewer partitions takes place in the 'AQEShuffleRead' step below.
While stages are created whenever a shuffle occurs, how are jobs created?
Hey @satheeshkumar2149, jobs are created whenever an actions is invoked. Examples of action in Apache Spark can be - collect(), count()
@@afaqueahmad7117 , but in some cases we have more than one job being created. This is where I find difficulty in understanding
No clarity is provided on when job is created. The stages are result of shuffle. The task is just a unit of execution