Skip to main content

Linux aio ABI wrapper

Project description

[english] | [한국어 (korean)]

linux_aio: Python wrapper for Linux Kernel AIO

Say Thanks!

Python wrapper module that uses Linux Kernel AIO directly

What is Linux Kernel AIO?

Linux IO Models table

In summary, it allows non-blocking and asynchronous use of blocking IO operations such as read(2) and write(2).

Related documents

It is different from POSIX AIO

The POSIX AIO APIs have the aio_ prefix, but the Linux Kernel AIO has the io_ prefix.

There is already a POSIX AIO API for asynchronous I/O, but Linux implements it in glibc, a user-space library, which is supposed to use multi-threading internally. So, as you can see from the experiment below, it's much worse than using the blocking IO API.

Implementation & Structure

Package linux_aio

  • Implemented based on linux_aio_bind package which is low-level binding of Linux kernel AIO.
  • Unlike linux_aio_bind, it can be used without knowledge of ctypes
  • Examples can be found in the code in the test directory.

Example

Examples can be found in the code in the test directory.

Notes & Limits

  • Obviously available only on Linux
  • Because it is a wrapper, it brings the constraints of Linux.
    • It can not be used for files used as a kernel interface. (e.g. cgroup)
    • Sometimes it works as Blocking.
      • There are some things that have been solved through development after posting.
    • Some features are being added because they are still under development.
    • There are also some features that are not supported when the Linux version is low

Evaluation

Experiment script (requires python 3.7)

Setup

  • Distribution: Ubuntu Server 16.04.5 LTS

  • Linux: 4.19.0

  • CPU: 2-way Intel(R) Xeon(R) CPU E5-2683 v4 @ 2.10GHz

  • MEM: total 64GB

  • Storage: SK hynix SC300B SATA 512GB

  • Python: 3.7.2 (Ubuntu ppa)

  • Attempts to read a total of 1000 times in 1ms intervals.

  • The file size varies from 1KB to 100KB, but it is small.

  • Experiment with increasing the number of files read at the same time

  • Because we have experimented with high-performance server, there may be larger performance differences when testing on a typical desktop.

Comparison target

It is not a perfectly fair comparison.

aiofiles and aiofile are libraries that support asyncio. Since open() is blocking, there is a disadvantage that you can not do any other work while IO is going on. libaio and linux_aio are non-blocking, but must be polled.

Results

It may differ from environment to environment.

Runtime

  • Unit: second
# of files 1 6 12 24
aiofiles 1.681 3.318 5.354 9.768
aiofile 1.543 1.958 2.493 3.737
libaio 1.311 1.344 1.362 1.423
open() 1.252 1.322 1.375 1.481
linux_aio 1.305 1.327 1.353 1.431

Threads

# of files 1 6 12 24
aiofiles 321 321 321 321
aiofile 3 8 15 26
libaio 1 1 1 1
open() 1 1 1 1
linux_aio 1 1 1 1

Memory

  • Physical memory (Virtual memory)
# of files 1 6 12 24
aiofiles 21MB (22.6GB) 21MB (22.6GB) 21MB (22.6GB) 21MB (22.6GB)
aiofile 17MB (258MB) 17MB (654MB) 17MB (1080MB) 18MB (1949MB)
libaio 17MB (76MB) 17MB (76MB) 17MB (76MB) 17MB (76MB)
open() 17MB (76MB) 17MB (76MB) 17MB (76MB) 17MB (76MB)
linux_aio 17MB (76MB) 17MB (76MB) 17MB (76MB) 17MB (76MB)

CPU Utilization

# of files 1 6 12 24
aiofiles 42.8% 85.0% 102.2% 113.2%
aiofile 31.4% 52.4% 67.0% 84.0%
libaio 14.0% 16.0% 17.2% 20.6%
open() 13.4% 17.6% 21.0% 26.2%
linux_aio 13.0% 15.0% 16.0% 21.0%

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

linux_aio-0.4.1.tar.gz (13.5 kB view details)

Uploaded Source

Built Distributions

linux_aio-0.4.1-py37-none-any.whl (26.6 kB view details)

Uploaded Python 3.7

linux_aio-0.4.1-py36-none-any.whl (26.5 kB view details)

Uploaded Python 3.6

linux_aio-0.4.1-py35-none-any.whl (26.5 kB view details)

Uploaded Python 3.5

linux_aio-0.4.1-py34-none-any.whl (26.1 kB view details)

Uploaded Python 3.4

File details

Details for the file linux_aio-0.4.1.tar.gz.

File metadata

  • Download URL: linux_aio-0.4.1.tar.gz
  • Upload date:
  • Size: 13.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.4.8

File hashes

Hashes for linux_aio-0.4.1.tar.gz
Algorithm Hash digest
SHA256 1e03dc8dc23ab56b1ee945015466e01a94f7298bb1c65d69be46129d8d734070
MD5 2cb3a174b0f105f0e4923a6c33a31378
BLAKE2b-256 0a1404041de341534654eb6d7475ab8b6c25e057f43e612e21f7134ac744ad42

See more details on using hashes here.

File details

Details for the file linux_aio-0.4.1-py37-none-any.whl.

File metadata

  • Download URL: linux_aio-0.4.1-py37-none-any.whl
  • Upload date:
  • Size: 26.6 kB
  • Tags: Python 3.7
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.7.1

File hashes

Hashes for linux_aio-0.4.1-py37-none-any.whl
Algorithm Hash digest
SHA256 9ed90afb6b01ce66e35d387eff5f2da3a63251148d3f5f276eb0498b0b18af46
MD5 f87a262d39eb550c0e3df3e074762778
BLAKE2b-256 90ae755741c78c37899866b6f677e085088079563ad77277c8c5e67d6a405dc0

See more details on using hashes here.

File details

Details for the file linux_aio-0.4.1-py36-none-any.whl.

File metadata

  • Download URL: linux_aio-0.4.1-py36-none-any.whl
  • Upload date:
  • Size: 26.5 kB
  • Tags: Python 3.6
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.6.7

File hashes

Hashes for linux_aio-0.4.1-py36-none-any.whl
Algorithm Hash digest
SHA256 ccaf68cd948725a6c8a10058c728c30eeeee81f388a53f18595d7a07996999a7
MD5 e82300bb63ed475ae088cd3818187972
BLAKE2b-256 8759885a5a13a04a809ddbd903a4b5be751ff9ba7f3284048eee14e9f5f6b0b8

See more details on using hashes here.

File details

Details for the file linux_aio-0.4.1-py35-none-any.whl.

File metadata

  • Download URL: linux_aio-0.4.1-py35-none-any.whl
  • Upload date:
  • Size: 26.5 kB
  • Tags: Python 3.5
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.5.6

File hashes

Hashes for linux_aio-0.4.1-py35-none-any.whl
Algorithm Hash digest
SHA256 ec594ce307c9398a4c1c9731e8da0299f7bdbca7b2de14143105f583a6f70f51
MD5 d92f83bf6f0889802c8185fa9679e30d
BLAKE2b-256 4336f728727d1e1507a8419a73bf9f58a00e1eccf0d0536b7a4ef7aef436d562

See more details on using hashes here.

File details

Details for the file linux_aio-0.4.1-py34-none-any.whl.

File metadata

  • Download URL: linux_aio-0.4.1-py34-none-any.whl
  • Upload date:
  • Size: 26.1 kB
  • Tags: Python 3.4
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.4.8

File hashes

Hashes for linux_aio-0.4.1-py34-none-any.whl
Algorithm Hash digest
SHA256 fb5c2a041ea7d10910ebba549b44cf73e24a4db3c278434fbc4d4630a5c5e491
MD5 adba18454f3c913685c98dc5f2c805e0
BLAKE2b-256 ed123f2bdea6b75be84963a0850244b294d070fe1ca43c1b06765ad0d612108f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page