您当前的位置: 首页 >  redis

Phil Arist

暂无认证

  • 5浏览

    0关注

    276博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

Redis应用

Phil Arist 发布时间:2021-08-05 13:24:49 ,浏览量:5

开源客户端

StackExchange.Redis:

https://github.com/StackExchange/StackExchange.Redis?spm=5176.100239.blogcont272212.10.IsQwET&file=StackExchange.Redis

基本用法

StackExchange.Redis中的中心对象是名称空间中的ConnectionMultiplexer类StackExchange.Redis。这是隐藏多个服务器详细信息的对象。由于ConnectionMultiplexer功能很多,因此可以在调用方之间共享和重用它。您不应该创建ConnectionMultiplexer每个操作。它是完全线程安全的,并且可以用于此用途。在所有后续示例中,将假定您已ConnectionMultiplexer保存一个实例以供重用。但是现在,让我们创建一个。这可以使用ConnectionMultiplexer.Connect或ConnectionMultiplexer.ConnectAsync传入配置字符串或ConfigurationOptions对象来完成。配置字符串可以采用逗号分隔的一系列节点的形式,因此让我们仅通过默认端口(6379)连接到本地计算机上的实例:

using StackExchange.Redis;

...

ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");

// ^^^ store and re-use this!!!

需要注意的是ConnectionMultiplexer工具IDisposable,可以在不再需要处置。这是故意不显示using语句用法的原因,因为ConnectionMultiplexer要重用此对象非常少见,因此您希望简短地使用它。

更复杂的情况可能涉及主/副本设置。对于此用法,只需指定组成该逻辑Redis层的所有所需节点(它将自动识别主节点):

ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("server1:6379,server2:6379");

如果发现两个节点都是主节点,则可以有选择地指定一个决胜键,该键可用于解决问题,但是幸运的是这种情况很少见。

有了之后ConnectionMultiplexer,您可能需要做以下三件事:

  • 访问redis数据库(请注意,在集群的情况下,单个逻辑数据库可能分布在多个节点上)

  • 利用redis的发布/订阅功能

  • 访问单个服务器以进行维护/监视

关注
打赏
1662360869
查看更多评论
立即登录/注册

微信扫码登录

0.0398s