#tarantool #api #protocols #async #async-client

v_rusty_tarantool

Tarantul async client based on tokio framework

1 unstable release

0.1.5 Jan 15, 2021

#2217 in Asynchronous

Apache-2.0

51KB
1K SLoC

Simple Rust client to tarantool

Ported java connector to tarantool db

https://tarantool.io

https://github.com/tarantool/tarantool-java

Overview

Use tokio.io as base client framework

Usage

Latest Version

Example

Call echo stored procedure

run tarantool

cd test-tarantool;tarantool init-tarantool.lua

Lua stored procedure:

function test(a,b)
   return a,b,11
end

Rust client :


println!("Connect to tarantool and call simple stored procedure!");
let mut rt = Runtime::new().unwrap();

let addr = "127.0.0.1:3301".parse().unwrap();
let client = ClientConfig::new(addr, "rust", "rust").build();

let response_future = client.call_fn2("test", &("param11", "param12") , &2)
    .and_then(|response| {
        let res : ((String,String), (u64,), (Option<u64>,)) = response.decode_trio()?;
        Ok(res)
    }) ;

match rt.block_on(response_future) {
    Err(e) => println!("err={:?}", e),
    Ok(res) => println!("stored procedure response ={:?}", res)
}

Output :

Connect to tarantool and call simple stored procedure!
stored procedure response =(("param11", "param12"), (2,), (Some(11),))

On examples part of project you can also see more complicated example :

http server connecting to tarantool

Dependencies

~7–16MB
~195K SLoC