//! This example will connect to Redis in one of three modes: //! //! - Regular async connection //! - Async multiplexed connection //! - Async connection manager //! //! It will then send a PING every 100 ms and print the result. use std::env; use std::process; use std::time::Duration; use futures::future; use mco_redis_rs::aio::ConnectionLike; use mco_redis_rs::RedisResult; use tokio::time::interval; enum Mode { Default, Multiplexed, Reconnect, } async fn run_single(mut con: C) -> RedisResult<()> { let mut interval = interval(Duration::from_millis(100)); loop { interval.tick().await; println!(); println!("> PING"); let result: RedisResult = mco_redis_rs::cmd("PING").query_async(&mut con).await; println!("< {:?}", result); } } async fn run_multi(mut con: C) -> RedisResult<()> { let mut interval = interval(Duration::from_millis(100)); loop { interval.tick().await; println!(); println!("> PING"); println!("> PING"); println!("> PING"); let results: ( RedisResult, RedisResult, RedisResult, ) = future::join3( mco_redis_rs::cmd("PING").query_async(&mut con.clone()), mco_redis_rs::cmd("PING").query_async(&mut con.clone()), mco_redis_rs::cmd("PING").query_async(&mut con), ) .await; println!("< {:?}", results.0); println!("< {:?}", results.1); println!("< {:?}", results.2); } } #[tokio::main] async fn main() -> RedisResult<()> { let mode = match env::args().nth(1).as_deref() { Some("default") => { println!("Using default connection mode\n"); Mode::Default } Some("multiplexed") => { println!("Using multiplexed connection mode\n"); Mode::Multiplexed } Some("reconnect") => { println!("Using reconnect manager mode\n"); Mode::Reconnect } Some(_) | None => { println!("Usage: reconnect-manager (default|multiplexed|reconnect)"); process::exit(1); } }; let client = mco_redis_rs::Client::open("redis://127.0.0.1/").unwrap(); match mode { Mode::Default => run_single(client.get_async_connection().await?).await?, Mode::Multiplexed => run_multi(client.get_multiplexed_tokio_connection().await?).await?, Mode::Reconnect => run_multi(client.get_tokio_connection_manager().await?).await?, }; Ok(()) }