Jasyncfio provides an asynchronous file I/O API based on the Linux io_uring interface.
- Fully asynchronous io_uring based file I/O API
- API comes in two kinds: Buffered and Direct I/O
- API for linear access to file (depends on your file system)
- Using a wide range of io_uring features such as polling, registered buffers/files
EventExecutor eventExecutor = EventExecutor.initDefault();
CompletableFuture<AsyncFile> asyncFileCompletableFuture = AsyncFile.open(Paths.get("path/to/file"), eventExecutor);
AsyncFile file = asyncFileCompletableFuture.get();
ByteBuffer byteBuffer = ByteBuffer.allocateDirect(1024);
CompletableFuture<Integer> readCompletableFuture = file.read(byteBuffer);
Integer readBytes = readCompletableFuture.get();
If you want to dive deeper, there are more examples with explanations on the wiki.
Releases are available at Maven Central.
Since the library uses native code, it is necessary to specify the classifier. At the moment there are releases only for linux-amd64, there are plans to support linux-arm64.
- Linux Kernel >= 5.11
- Java >= 8
<dependency>
<groupId>one.jasyncfio</groupId>
<artifactId>jasyncfio</artifactId>
<version>0.0.8</version>
<classifier>linux-amd64</classifier>
</dependency>
implementation 'one.jasyncfio:jasyncfio:0.0.8:linux-amd64'
implementation("one.jasyncfio:jasyncfio:0.0.8:linux-amd64")