
Product
Introducing Socket Firewall Enterprise: Flexible, Configurable Protection for Modern Package Ecosystems
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.
NOTE: Native Linux aio implementation supports since 4.18 kernel version.
Python bindings for Linux AIO API and simple asyncio wrapper.
import asyncio
from caio import AsyncioContext
loop = asyncio.get_event_loop()
async def main():
    # max_requests=128 by default
    ctx = AsyncioContext(max_requests=128)
    with open("test.file", "wb+") as fp:
        fd = fp.fileno()
        # Execute one write operation
        await ctx.write(b"Hello world", fd, offset=0)
        # Execute one read operation
        print(await ctx.read(32, fd, offset=0))
        # Execute one fdsync operation
        await ctx.fdsync(fd)
        op1 = ctx.write(b"Hello from ", fd, offset=0)
        op2 = ctx.write(b"async world", fd, offset=11)
        await asyncio.gather(op1, op2)
        print(await ctx.read(32, fd, offset=0))
        # Hello from async world
loop.run_until_complete(main())
The linux implementation works normal for modern linux kernel versions
and file systems. So you may have problems specific for your environment.
It's not a bug and might be resolved some ways:
The caio since version 0.7.0 contains some ways to do this.
CAIO_IMPL with possible values:
linux - use native linux kernels aio mechanismthread - use thread based implementation written in Cpython - use pure python implementationdefault_implementation located near __init__.py in caio
installation path. It's useful for distros package maintainers. This file
might contains comments (lines starts with # symbol) and the first line
should be one of linux thread or python.Previous versions allows direct import of the target implementation.
FAQs
Asynchronous file IO for Linux MacOS or Windows.
We found that caio demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.

Security News
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.

Product
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socket’s new workflow scanning support.