You are viewing a plain text version of this content. The canonical link for it is here.
Posted to jira@arrow.apache.org by "Weston Pace (Jira)" <ji...@apache.org> on 2021/10/29 23:01:00 UTC
[jira] [Created] (ARROW-14524) [C++] Create plugging/coalescing
filesystem wrapper
Weston Pace created ARROW-14524:
-----------------------------------
Summary: [C++] Create plugging/coalescing filesystem wrapper
Key: ARROW-14524
URL: https://issues.apache.org/jira/browse/ARROW-14524
Project: Apache Arrow
Issue Type: New Feature
Components: C++
Reporter: Weston Pace
Assignee: Weston Pace
We have I/O optimizations scattered across some of our readers. The most prominent example is prebuffering in the parquet reader. However, these techniques are rather general purpose and will apply in IPC (see ARROW-14229) as well as other readers (e.g. Orc, maybe even CSV)
This filesystem wrapper will not generally be necessary for local filesystems as the OS' filesystem schedulers are sufficient. Most of these we can accomplish by simply aiming for some configurable degree of parallelism (e.g. if there are already X requests in progress then start batching).
Goals:
* Batch consecutive small requests into fewer large requests
* We could plug (configurably) small holes in read ranges as well
* Potentially split large requests into concurrent small requests
* Support for the RandomAccessFile::WillNeed command by prefetching ranges
--
This message was sent by Atlassian Jira
(v8.3.4#803005)