Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

How to make transfer data faster while using databricks-sql-go #235

Open
calebeaires opened this issue Jul 11, 2024 · 4 comments
Open

How to make transfer data faster while using databricks-sql-go #235

calebeaires opened this issue Jul 11, 2024 · 4 comments

Comments

@calebeaires
Copy link

calebeaires commented Jul 11, 2024

I am using the driver to run a data migration. When dealing with a table of 24 million rows and 9 columns, the performance is excellent when I fetch 10 thousand rows. When I increase the fetch size to 100 thousand rows, the transfer speed is still good. However, when fetching 1 million rows or more, the data transfer becomes very slow. A quick test made me think that the driver tries to fetch all the data in a single batch. Is there a way to improve this process?

This is the connection string

"token:xxx@host:443$xxx-path?catalog=sample&database=big_table&useCloudFetch=true&maxRows=10000"

I've tried to use this two settings, data transfer is still slow to big tables.

  • useCloudFetch=true
  • maxRows=10000

In forums users suggest change spark.driver.maxResultSize ?

@kravets-levko
Copy link
Contributor

kravets-levko commented Jul 12, 2024

@calebeaires considering you enabled CloudFetch - most likely your assumption is correct, the driver actually tries to download all the data in memory. That's what we discovered recently, and are trying to fix right now - #234 Try to disable CloudFetch, this helped some other users. And then you can play with maxRows to see if it has any effect in your case

@calebeaires
Copy link
Author

calebeaires commented Jul 16, 2024

@kravets-levko I've changed the settings to useCloudFetch=false, still getting errors. Sometimes this erros come out:

execution error: failed to execute query: unexpected operation state ERROR_STATE: Total size of serialized results of 382 tasks (4.0 GiB) is bigger than spark.driver.maxResultSize 4.0 GiB. Code: 108

Topic: Spark Driver maxResultSize exceed 4.0 GiB

Hope we find a solution!

@kravets-levko
Copy link
Contributor

@calebeaires for this particular error please reach out an administrator of your workspace, or Databricks support. This one is related to your workspace configuration, and that's not something that can be handled in library

@calebeaires
Copy link
Author

Thank you so much. Please, help me elaborate the issue to the administrator. Is there some config the admin can define concerning max memory result size?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants