-
Notifications
You must be signed in to change notification settings - Fork 392
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
[#5361] improvment(hadoop-catalog): Introduce timeout mechanism to get Hadoop File System. #5406
Changes from all commits
58efcf6
77785e9
859d8ac
2217682
42c5dce
563c66a
fc961e5
b08fc9c
ec0ef6e
2164e5c
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -53,6 +53,9 @@ public class HadoopCatalogPropertiesMetadata extends BaseCatalogPropertiesMetada | |
*/ | ||
public static final String DEFAULT_FS_PROVIDER = "default-filesystem-provider"; | ||
|
||
static final String FILESYSTEM_CONNECTION_TIMEOUT_SECONDS = "filesystem-conn-timeout-secs"; | ||
static final int DEFAULT_GET_FILESYSTEM_TIMEOUT_SECONDS = 6; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why it is the "6" seconds we defined here? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is just an experience value. This specific setting depends on the environment at that time. I believe 6s is long enough to get the connection. |
||
|
||
public static final String BUILTIN_LOCAL_FS_PROVIDER = "builtin-local"; | ||
public static final String BUILTIN_HDFS_FS_PROVIDER = "builtin-hdfs"; | ||
|
||
|
@@ -82,6 +85,14 @@ public class HadoopCatalogPropertiesMetadata extends BaseCatalogPropertiesMetada | |
false /* immutable */, | ||
BUILTIN_LOCAL_FS_PROVIDER, // please see LocalFileSystemProvider#name() | ||
false /* hidden */)) | ||
.put( | ||
FILESYSTEM_CONNECTION_TIMEOUT_SECONDS, | ||
PropertyEntry.integerOptionalPropertyEntry( | ||
FILESYSTEM_CONNECTION_TIMEOUT_SECONDS, | ||
"Timeout to wait for to create the Hadoop file system client instance.", | ||
false /* immutable */, | ||
DEFAULT_GET_FILESYSTEM_TIMEOUT_SECONDS, | ||
false /* hidden */)) | ||
// The following two are about authentication. | ||
.putAll(KERBEROS_PROPERTY_ENTRIES) | ||
.putAll(AuthenticationConfig.AUTHENTICATION_PROPERTY_ENTRIES) | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why it is so time-consuming to initialize the filesystem client?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If the user sets an incorrect endpoint, the client will retry to get the connection for a certain amount of time.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think you really fix this problem without using another thread to create a FS and polling the status asynchronously?