<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic How to ensure pyspark udf execution is distributed across worker nodes in Data Engineering</title>
    <link>https://community.databricks.com/t5/data-engineering/how-to-ensure-pyspark-udf-execution-is-distributed-across-worker/m-p/93244#M38663</link>
    <description>&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;I have the following databricks notebook code defined:&lt;/P&gt;&lt;DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;pyspark_dataframe &lt;/SPAN&gt;&lt;SPAN&gt;=&lt;/SPAN&gt; &lt;SPAN&gt;create_pyspark_dataframe&lt;/SPAN&gt;&lt;SPAN&gt;(some input data)&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;MyUDF&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;=&lt;/SPAN&gt; &lt;SPAN&gt;udf&lt;/SPAN&gt;&lt;SPAN&gt;(myfunc, &lt;/SPAN&gt;&lt;SPAN&gt;StringType&lt;/SPAN&gt;&lt;SPAN&gt;())&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;pyspark_dataframe &lt;/SPAN&gt;&lt;SPAN&gt;=&lt;/SPAN&gt;&lt;SPAN&gt; pyspark_dataframe.&lt;/SPAN&gt;&lt;SPAN&gt;withColumn&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;'UDFOutput'&lt;/SPAN&gt;&lt;SPAN&gt;,&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;DownloadUDF&lt;/SPAN&gt;&lt;SPAN&gt;(input data columns&lt;/SPAN&gt;&lt;SPAN&gt;))&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;output_strings&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;=&lt;/SPAN&gt;&lt;SPAN&gt; [x[&lt;/SPAN&gt;&lt;SPAN&gt;"UDFOutput"&lt;/SPAN&gt;&lt;SPAN&gt;] &lt;/SPAN&gt;&lt;SPAN&gt;for&lt;/SPAN&gt;&lt;SPAN&gt; x &lt;/SPAN&gt;&lt;SPAN&gt;in&lt;/SPAN&gt;&lt;SPAN&gt; pyspark_dataframe.&lt;/SPAN&gt;&lt;SPAN&gt;select&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;"UDFOutput"&lt;/SPAN&gt;&lt;SPAN&gt;).&lt;/SPAN&gt;&lt;SPAN&gt;collect&lt;/SPAN&gt;&lt;SPAN&gt;()]&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;Im running this notebook on a cluster with multiple worker nodes. H&lt;/SPAN&gt;&lt;SPAN&gt;ow can I ensure that the udf execution is distributed equally across the worker nodes?&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;Kind regards,&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;Pim&lt;/SPAN&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;</description>
    <pubDate>Wed, 09 Oct 2024 10:05:17 GMT</pubDate>
    <dc:creator>pjv</dc:creator>
    <dc:date>2024-10-09T10:05:17Z</dc:date>
    <item>
      <title>How to ensure pyspark udf execution is distributed across worker nodes</title>
      <link>https://community.databricks.com/t5/data-engineering/how-to-ensure-pyspark-udf-execution-is-distributed-across-worker/m-p/93244#M38663</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;I have the following databricks notebook code defined:&lt;/P&gt;&lt;DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;pyspark_dataframe &lt;/SPAN&gt;&lt;SPAN&gt;=&lt;/SPAN&gt; &lt;SPAN&gt;create_pyspark_dataframe&lt;/SPAN&gt;&lt;SPAN&gt;(some input data)&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;MyUDF&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;=&lt;/SPAN&gt; &lt;SPAN&gt;udf&lt;/SPAN&gt;&lt;SPAN&gt;(myfunc, &lt;/SPAN&gt;&lt;SPAN&gt;StringType&lt;/SPAN&gt;&lt;SPAN&gt;())&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;pyspark_dataframe &lt;/SPAN&gt;&lt;SPAN&gt;=&lt;/SPAN&gt;&lt;SPAN&gt; pyspark_dataframe.&lt;/SPAN&gt;&lt;SPAN&gt;withColumn&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;'UDFOutput'&lt;/SPAN&gt;&lt;SPAN&gt;,&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;DownloadUDF&lt;/SPAN&gt;&lt;SPAN&gt;(input data columns&lt;/SPAN&gt;&lt;SPAN&gt;))&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;output_strings&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;=&lt;/SPAN&gt;&lt;SPAN&gt; [x[&lt;/SPAN&gt;&lt;SPAN&gt;"UDFOutput"&lt;/SPAN&gt;&lt;SPAN&gt;] &lt;/SPAN&gt;&lt;SPAN&gt;for&lt;/SPAN&gt;&lt;SPAN&gt; x &lt;/SPAN&gt;&lt;SPAN&gt;in&lt;/SPAN&gt;&lt;SPAN&gt; pyspark_dataframe.&lt;/SPAN&gt;&lt;SPAN&gt;select&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;"UDFOutput"&lt;/SPAN&gt;&lt;SPAN&gt;).&lt;/SPAN&gt;&lt;SPAN&gt;collect&lt;/SPAN&gt;&lt;SPAN&gt;()]&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;Im running this notebook on a cluster with multiple worker nodes. H&lt;/SPAN&gt;&lt;SPAN&gt;ow can I ensure that the udf execution is distributed equally across the worker nodes?&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;Kind regards,&lt;/SPAN&gt;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;SPAN&gt;Pim&lt;/SPAN&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;&lt;/DIV&gt;</description>
      <pubDate>Wed, 09 Oct 2024 10:05:17 GMT</pubDate>
      <guid>https://community.databricks.com/t5/data-engineering/how-to-ensure-pyspark-udf-execution-is-distributed-across-worker/m-p/93244#M38663</guid>
      <dc:creator>pjv</dc:creator>
      <dc:date>2024-10-09T10:05:17Z</dc:date>
    </item>
    <item>
      <title>Re: How to ensure pyspark udf execution is distributed across worker nodes</title>
      <link>https://community.databricks.com/t5/data-engineering/how-to-ensure-pyspark-udf-execution-is-distributed-across-worker/m-p/97230#M39457</link>
      <description>&lt;P&gt;&lt;a href="https://community.databricks.com/t5/user/viewprofilepage/user-id/105077"&gt;@pjv&lt;/a&gt;&amp;nbsp;Can you please try the following, you'll basically want to have more than a single partition:&lt;/P&gt;
&lt;LI-CODE lang="markup"&gt;from pyspark.sql import SparkSession
from pyspark.sql.functions import udf
from pyspark.sql.types import StringType

# Initialize Spark session (if not already done)
spark = SparkSession.builder.appName("AppName").getOrCreate()

# Create a PySpark DataFrame from your input data
pyspark_dataframe = create_pyspark_dataframe(some_input_data)

# Repartition the DataFrame to ensure even distribution across worker nodes
num_partitions = 4  # Adjust based on your cluster size
pyspark_dataframe = pyspark_dataframe.repartition(num_partitions)

# Define your UDF
MyUDF = udf(myfunc, StringType())

# Apply the UDF to the DataFrame
pyspark_dataframe = pyspark_dataframe.withColumn('UDFOutput', MyUDF(input_data_columns))

# Collect the results
output_strings = [x["UDFOutput"] for x in pyspark_dataframe.select("UDFOutput").collect()]

# Confirm the distribution UDF execution.
&lt;/LI-CODE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 01 Nov 2024 13:59:28 GMT</pubDate>
      <guid>https://community.databricks.com/t5/data-engineering/how-to-ensure-pyspark-udf-execution-is-distributed-across-worker/m-p/97230#M39457</guid>
      <dc:creator>VZLA</dc:creator>
      <dc:date>2024-11-01T13:59:28Z</dc:date>
    </item>
  </channel>
</rss>

