pub struct PubSub<'a> { /* private fields */ }
Expand description
Represents a pubsub connection.
Implementations§
Source§impl<'a> PubSub<'a>
The pubsub object provides convenient access to the redis pubsub
system. Once created you can subscribe and unsubscribe from channels
and listen in on messages.
impl<'a> PubSub<'a>
The pubsub object provides convenient access to the redis pubsub system. Once created you can subscribe and unsubscribe from channels and listen in on messages.
Example:
let client = redis::Client::open("redis://127.0.0.1/")?;
let mut con = client.get_connection()?;
let mut pubsub = con.as_pubsub();
pubsub.subscribe("channel_1")?;
pubsub.subscribe("channel_2")?;
loop {
let msg = pubsub.get_message()?;
let payload : String = msg.get_payload()?;
println!("channel '{}': {}", msg.get_channel_name(), payload);
}
Sourcepub fn subscribe<T: ToRedisArgs>(&mut self, channel: T) -> RedisResult<()>
pub fn subscribe<T: ToRedisArgs>(&mut self, channel: T) -> RedisResult<()>
Subscribes to a new channel(s).
Sourcepub fn psubscribe<T: ToRedisArgs>(&mut self, pchannel: T) -> RedisResult<()>
pub fn psubscribe<T: ToRedisArgs>(&mut self, pchannel: T) -> RedisResult<()>
Subscribes to new channel(s) with pattern(s).
Sourcepub fn unsubscribe<T: ToRedisArgs>(&mut self, channel: T) -> RedisResult<()>
pub fn unsubscribe<T: ToRedisArgs>(&mut self, channel: T) -> RedisResult<()>
Unsubscribes from a channel(s).
Sourcepub fn punsubscribe<T: ToRedisArgs>(&mut self, pchannel: T) -> RedisResult<()>
pub fn punsubscribe<T: ToRedisArgs>(&mut self, pchannel: T) -> RedisResult<()>
Unsubscribes from channel pattern(s).
Sourcepub fn ping_message<T: FromRedisValue>(
&mut self,
message: impl ToRedisArgs,
) -> RedisResult<T>
pub fn ping_message<T: FromRedisValue>( &mut self, message: impl ToRedisArgs, ) -> RedisResult<T>
Sends a ping with a message to the server
Sourcepub fn ping<T: FromRedisValue>(&mut self) -> RedisResult<T>
pub fn ping<T: FromRedisValue>(&mut self) -> RedisResult<T>
Sends a ping to the server
Sourcepub fn get_message(&mut self) -> RedisResult<Msg>
pub fn get_message(&mut self) -> RedisResult<Msg>
Fetches the next message from the pubsub connection. Blocks until a message becomes available. This currently does not provide a wait not to block :(
The message itself is still generic and can be converted into an appropriate type through the helper methods on it.
Sourcepub fn set_read_timeout(&self, dur: Option<Duration>) -> RedisResult<()>
pub fn set_read_timeout(&self, dur: Option<Duration>) -> RedisResult<()>
Sets the read timeout for the connection.
If the provided value is None
, then get_message
call will
block indefinitely. It is an error to pass the zero Duration
to this
method.
Trait Implementations§
Auto Trait Implementations§
impl<'a> Freeze for PubSub<'a>
impl<'a> !RefUnwindSafe for PubSub<'a>
impl<'a> Send for PubSub<'a>
impl<'a> Sync for PubSub<'a>
impl<'a> Unpin for PubSub<'a>
impl<'a> !UnwindSafe for PubSub<'a>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more