© 2013 Urban Airship
https://github.com/urbanairship/kiddiepool
- Create a reusable connection pool class that handles failover
- Optionally allow connection pool to discover service locations via Zookeeper
pip install kiddiepool # without optional zookeeper support pip install kiddiepool[zookeeper] # with optional zookeeper support
Subclass at least KiddieClient
to create the public API for your client
driver. Should call KiddieClient._sendall(<str>)
to send data.
- Create a list of
"<host>:<port>"
strings to target for connections. - Instantiate a
KiddiePool
with that list of strings. - Pass the KiddiePool instance to your
KiddieClient
subclass for use. - Use your client's API and it will use the pool automatically.
Note
Ensure you have installed the package with zookeeper support.
- Instantiate a TidePool with the Zookeeper quorum and znode whose children to monitor.
- Use a context manager
with TidePool() as pool:
or thestart()
andstop()
methods to manage the connection to Zookeeper. - Use the dynamic pool exactly like the static pool. Candidates will be added/removed from the pool by a background thread.