Skip to main content

Posix IPC-backed ASGI channel layer implementation

Project description

https://api.travis-ci.org/andrewgodwin/asgi_ipc.svg https://img.shields.io/pypi/v/asgi_ipc.svg

An ASGI channel layer that uses POSIX shared memory IPC as its backing store (only works between processes on the same machine).

Beta - please file issues if it doesn’t work or fails weirdly (shared memory and IPC can be tricky)

Usage

You’ll need to instantiate the channel layer with a path prefix to create IPC objects underneath; any channel layers with the same prefix will talk to each other as long as they’re on the same machine.

Example:

channel_layer = IPCChannelLayer(
    prefix="aeracode",
    channel_memory=200 * 1024 * 1024,
)

prefix

Prefix to use for IPC objects under the root namespace. Defaults to asgi. IPC layers on the same machine with the same prefix will talk to each other.

channel_memory

The amount of shared memory to allocate to the channel storage, in bytes. Defaults to 100MB. All of your in-flight messages must fit into this, otherwise you’ll get ChannelFull errors if the memory space is full up.

ASGI messages can be a maximum of one megabyte, and are usually much smaller. The IPC routing metadata on top of each message is approximately 50 bytes.

group_memory

The amount of shared memory to allocate to the group storage, in bytes. Defaults to 20MB. All of your group membership data must fit into this space, otherwise your group memberships may fail to persist.

You can fit approximately 4000 group-channel membership associations into one megabyte of memory.

expiry

Message expiry in seconds. Defaults to 60. You generally shouldn’t need to change this, but you may want to turn it down if you have peaky traffic you wish to drop, or up if you have peaky traffic you want to backlog until you get to it.

group_expiry

Group expiry in seconds. Defaults to 86400. Interface servers will drop connections after this amount of time; it’s recommended you reduce it for a healthier system that encourages disconnections.

capacity

Default channel capacity. Defaults to 100. Once a channel is at capacity, it will refuse more messages. How this affects different parts of the system varies; a HTTP server will refuse connections, for example, while Django sending a response will just wait until there’s space.

channel_capacity

Per-channel capacity configuration. This lets you tweak the channel capacity based on the channel name, and supports both globbing and regular expressions.

It should be a dict mapping channel name pattern to desired capacity; if the dict key is a string, it’s intepreted as a glob, while if it’s a compiled re object, it’s treated as a regular expression.

This example sets http.request to 200, all http.response! channels to 10, and all websocket.send! channels to 20:

channel_capacity={
    "http.request": 200,
    "http.response!*": 10,
    re.compile(r"^websocket.send\!.+"): 20,
}

If you want to enforce a matching order, use an OrderedDict as the argument; channels will then be matched in the order the dict provides them.

Project details


Download files

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

Source Distribution

asgi_ipc-1.0.0.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

asgi_ipc-1.0.0-py2.py3-none-any.whl (8.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file asgi_ipc-1.0.0.tar.gz.

File metadata

  • Download URL: asgi_ipc-1.0.0.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for asgi_ipc-1.0.0.tar.gz
Algorithm Hash digest
SHA256 4bd56898d8b99185bd97285e16a9e2a9865bdc0870c4111f0209be87b11de130
MD5 a613d19af6d09649e2ccfad5670eee4f
BLAKE2b-256 7f110556fa0e0c901dc58c0765940060e60ceec5900b0ce01e18c681888cbec6

See more details on using hashes here.

File details

Details for the file asgi_ipc-1.0.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for asgi_ipc-1.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 3bb86e96201a224436b35156760ed8ed2287a4042dc9f888731e7a21e1bffab8
MD5 65e24d871be570adf1e583285f6acfde
BLAKE2b-256 9f6b3db7e21806db62d9974d72896e4fd93bfa014525d6511347dbb181dafde7

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