Tarantool connection driver for work with asyncio
Project description
Connector required tarantool version 1.6:
$ pip install gtarantool
Try it example:
import asyncio
import aiotarantool
cnt = 0
@asyncio.coroutine
def insert_job(tnt):
global cnt
for it in range(2500):
cnt += 1
r = yield from tnt.insert("tester", (cnt, cnt))
loop = asyncio.get_event_loop()
tnt = aiotarantool.connect("127.0.0.1", 3301)
tasks = [asyncio.async(insert_job(tnt))
for _ in range(40)]
loop.run_until_complete(asyncio.wait(tasks))
loop.run_until_complete(tnt.close())
loop.close()
Under this scheme the aiotarantool driver makes a smaller number of read/write tarantool socket.
See benchmark results time for insert/select/delete 100K tuples on 1.5KBytes:
call |
tarantool |
aiotarantool |
---|---|---|
insert |
35.938047 |
12.701088 |
select |
24.389748 |
18.158066 |
delete |
35.224515 |
13.905095 |
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
aiotarantool-1.0.1.tar.gz
(4.9 kB
view details)
File details
Details for the file aiotarantool-1.0.1.tar.gz
.
File metadata
- Download URL: aiotarantool-1.0.1.tar.gz
- Upload date:
- Size: 4.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 185fc7843033ba528891ff6386286edab7ccada39e58df3167204a2cf34030f4 |
|
MD5 | d8dd2bcd467e7648361157c3fba23d8e |
|
BLAKE2b-256 | 443c61820fda9267ea9746e0c2dfb30cdde35830c655861fc758d0bad002a74a |