StackExchange.Redis 系列 1:基礎(chǔ)使用

本系列博文已經(jīng)全部完成,完整系列請訪問:https://blog.zhuliang.ltd/tags/StackExchange-Redis%E7%B3%BB%E5%88%97/

本文轉(zhuǎn)自:https://blog.zhuliang.ltd/2020/01/backend/StackExchangeRedis-BasicUsage.html

  • 本系列博文是“偽”官方文檔翻譯,并非完全將官方文檔進行翻譯,而是我在查閱、測試原始文檔并轉(zhuǎn)換為自己東西后進行的“準”翻譯。
  • 原始文檔見此:https://stackexchange.github.io/StackExchange.Redis/
  • 本系列本博文基于 redis 5.0.6,系列中部分博文跟官方文檔有出入,有不同見解 / 說明不當?shù)牡胤?,還請大家不吝拍磚。

ConnectionMultiplexer 說明

命名空間位于:StackExchange.Redis.ConnectionMultiplexer

  • ConnectionMultiplexer 是 StackExchange.Redis 的核心對象,內(nèi)部繼承了 IDisposable,但建議不要用 using 以便可以愉快重用,你就認為它足夠安全吧。
  • 該對象線程安全,且應該被重用,搞成單例即可,不要每次操作都創(chuàng)建一個。

主從庫示例:

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

項目中調(diào)用實例

說明:示例基于 .NET CORE 2.1,通過 IoC 進行注入,生命周期為“單例”。
如果不通過 IoC 的話建議直接使用“單例模式”。

    public class RedisClient : ICache
    {
        private readonly RedisSettings _redisSettings;
        private static IDatabaseAsync _db;

        public RedisClient(IOptions<RedisSettings> redisSettings)
        {
            _redisSettings = redisSettings.Value;
            var redis = ConnectionMultiplexer.Connect($"{_redisSettings.Address}:{_redisSettings.Port}");
            _db = redis.GetDatabase(_redisSettings.DataBase);
        }


        #region Implementation of ICache

        public async Task<bool> SetStringAsync(string key, string content)
        {
            return true;
        }

        public async Task<string> GetStringAsync(string key)
        {
            var result = await _db.StringGetAsync(key);
            return result;
        }
        #endregion
    }

其他一些建議和說明

  • StackExchange.Redis 有 3種主要使用機制:
    • 同步
    • 異步:建議優(yōu)先使用異步方法而不是同步方法。
    • 即發(fā)即忘(Fire-And-Forget):當你不需要響應結(jié)果的時候,可以使用這種機制,被調(diào)用方法會立馬返回,但操作會在后臺進行執(zhí)行。。
  • 即發(fā)即忘”機制補充:StackExchange.Redis 的方法中都有 CommandFlags 枚舉,默認值是 “None”,當你需要使用“即發(fā)即忘”機制的時候,需要在方法上顯示指定 CommandFlags.FireAndForget,需要注意:
    • 如果返回值是一個字符串類型,則將總是返回 null。
    • 如果返回值是一個 Int64 類型,則將總是返回 0。
    • 需要注意的是,如果返回值是一個 boolean,則返回的是 false(但操作是成功的,此時不要用該返回值作為你后續(xù)業(yè)務的判斷依據(jù))。
db.StringIncrement(cacheKey, flags: CommandFlags.FireAndForget);
  • StackExchange.Redis.IDatabase 的一些方法,是根據(jù) Redis 的數(shù)據(jù)類型來進行命名的,如 IDatabase.StringGet,這里的 StringGet 表示的是獲取一個 String ,跟 C# 中的字符串并非表示同一個東西,可參考:關(guān)于 Redis 的數(shù)據(jù)類型

發(fā)布/訂閱

  • 發(fā)布/訂閱不需要指定 database

例子:
客戶端

private readonly RedisSettings _redisSettings;
private static IDatabaseAsync _db;
private static ConnectionMultiplexer _redis;

public RedisClient(IOptions<RedisSettings> redisSettings)
{
    _redisSettings = redisSettings.Value;
    _redis = ConnectionMultiplexer.Connect($"{_redisSettings.Address}:{_redisSettings.Port}");
    _db = _redis.GetDatabase(_redisSettings.DataBase);
}

public async Task Subscribe(string channel, Action<RedisChannel, RedisValue> fun)
{
    var sub = _redis.GetSubscriber();
    await sub.SubscribeAsync(channel, fun);
}

public async Task Publish(string channel, string message)
{
    var sub = _redis.GetSubscriber();
    await sub.PublishAsync(channel, message);
}

訂閱者

class Program
{
    static void Main(string[] args)
    {
        var builder = new ConfigurationBuilder().AddJsonFile("appsettings.json");
        var configuration = builder.Build();
        var subscriber = configuration["Subscriber"];
        var settings = configuration.GetSection("RedisSettings").Get<RedisSettings>();

        var redisClient = new RedisClient(settings);
        redisClient.Subscribe(settings.ChannelName, (channel, message) =>
         {
             System.Console.WriteLine($"{subscriber}:{message}");
         }).Wait();

        System.Console.WriteLine("started");
        System.Console.ReadKey();
    }
}

測試效果:

image

服務器命令

若要使用服務器命令,需要通過 ConnectionMultiplexer 對象獲取 Server 對象,如下:

var server = _redis.GetServer($"{_redisSettings.Address}:{_redisSettings.Port},allowAdmin=true");
server.ScriptExists("scripts here");

目前支持的方法如下

image
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容