cancel
Showing results for 
Search instead for 
Did you mean: 
Data Engineering
Join discussions on data engineering best practices, architectures, and optimization strategies within the Databricks Community. Exchange insights and solutions with fellow data engineers.
cancel
Showing results for 
Search instead for 
Did you mean: 

PySpark: Writing Parquet Files to the Azure Blob Storage Container

Eyespoop
New Contributor II

Currently I am having some issues with the writing of the parquet file in the Storage Container. I do have the codes running but whenever the dataframe writer puts the parquet to the blob storage instead of the parquet file type, it is created as a folder type with many files content to it.

One note to it, I tried searching various ways in the internets that it seems this is default creation when using pyspark and I can see in the folder created there was a file parquet with a snappy add into it (refer to the screenshots below)

 imageimage(1)image(2)If this is a default creation to pyspark code, how can I write a single parquet format that will do some splitting or creation of folder? any recommendations? on how to do it?

1 ACCEPTED SOLUTION

Accepted Solutions

Anonymous
Not applicable

When you write a file, it uses the default compression if you don't specify it. The default compression is snappy, so that's expected + desired behavior.

Parquet is meant to be splittable. It also needs to create the other files that begin with the underscore to ensure you don't get partial or broken writes.

What exactly are you trying to do?

View solution in original post

3 REPLIES 3

Anonymous
Not applicable

When you write a file, it uses the default compression if you don't specify it. The default compression is snappy, so that's expected + desired behavior.

Parquet is meant to be splittable. It also needs to create the other files that begin with the underscore to ensure you don't get partial or broken writes.

What exactly are you trying to do?

Eyespoop
New Contributor II

Already found out that this is already the behaviour, so to make it work, currently all the wrangled folders are being deleted and the file parquet contents inside the wrangled folder are already being moved outside the folder while renaming it. That's the solution I see from my goal to dump a single parquet file on the container with no wrangled folders.

Thank you @Joseph Kambourakis​ 

image

User16764241763
Honored Contributor

Hello @Karl Saycon​ 

Can you try setting this config to prevent additional parquet summary and metadata files from being written? The result from dataframe write to storage should be a single file.

https://community.databricks.com/s/question/0D53f00001HKHiNCAX/how-do-i-prevent-success-and-committe...

A combination of below three properties will help to disable writing all the transactional files which start with "_".

  1. We can disable the transaction logs of spark parquet write using "spark.sql.sources.commitProtocolClass = org.apache.spark.sql.execution.datasources.SQLHadoopMapReduceCommitProtocol". This will help to disable the "committed<TID>" and "started<TID>" files but still _SUCCESS, _common_metadata and _metadata files will generate.
  2. We can disable the _common_metadata and _metadata files using "parquet.enable.summary-metadata=false".
  3. We can also disable the _SUCCESS file using "mapreduce.fileoutputcommitter.marksuccessfuljobs=false".

Connect with Databricks Users in Your Area

Join a Regional User Group to connect with local Databricks users. Events will be happening in your city, and you won’t want to miss the chance to attend and share knowledge.

If there isn’t a group near you, start one and help create a community that brings people together.

Request a New Group