No description
This repository has been archived on 2023-03-26. You can view files and clone it, but cannot push or open issues or pull requests.
Find a file
2018-12-08 18:51:44 +00:00
.circleci Move linting to generic script 2018-12-08 16:06:54 +00:00
ipc_unix Switch simple server to use threads for requests 2018-12-08 18:51:44 +00:00
scripts Move linting to generic script 2018-12-08 16:06:54 +00:00
tests Refactor simple server client to class 2018-12-08 14:23:16 +00:00
.gitignore Setup project 2018-12-07 13:54:46 +00:00
.travis.yml Only support >=3.5 2018-12-08 16:11:56 +00:00
dev-requirements.txt Move black to separate script 2018-12-08 15:55:56 +00:00
LICENSE Create LICENSE 2018-12-08 15:08:54 +00:00
README.md Close server in example 2018-12-08 16:23:41 +00:00
setup.cfg Force payload to be dict, increase stability and speed 2018-12-08 01:12:34 +00:00
setup.py Only support >=3.5 2018-12-08 16:11:56 +00:00

IPC-Unix

CircleCI Build Status

Simple Inter-Process Communication using unix sockets for Python.

Note: Whilst mostly working, there's still some fairly common cases which haven't been tested. Use at your own risk until this message is removed.

Examples

For some more concrete examples, check out the tests/ directory.

Call / Response

from ipc_unix import Server, Client

class EchoServer(Server):
    def handle_request(self, request):
        return request

socket_path = '/tmp/sock.sock'
server = EchoServer(socket_path)
client = Client(socket_path)

print(client.send({"foo": "bar"}))
>>> {"foo": "bar"}

server.close()s

Pub-Sub

from ipc_unix import pubsub

socket_path = '/tmp/sock.sock'
publisher = pubsub.Publisher(socket_path)
subscriber = pubsub.Subscriber(socket_path)

publisher.write({"foo": "bar"})
print(self.subscriber.get_latest_message())
>>> {"foo": "bar"}

publisher.close()
subscriber.close()