推荐使用 StackExchange.Redis 客户端库操作 Redis,它线程安全、支持连接池与自动重连,应通过单例 ConnectionMultiplexer 管理连接,并用异步 IDatabase 方法操作数据,配合 JSON 序列化存取对象。
用 C# 操作 Redis,最主流、高性能、推荐的方式就是使用 StackExchange.Redis 客户端库。它线程安全、支持连接池、自动重连(需配置)、支持同步/异步操作,是 .NET 生态中 Redis 的事实标准。
通过 NuGet 安装:
StackExchange.Redis 使用 IConnectionMultiplexer 管理连接,它是线程安全的、应全局复用(单例),不要每次操作都新建。
"localhost:6379,abortConnect=false,connectTimeout=5000"
GetDatabase() 返回 IDatabase 实例,用于执行具体命令(默认 db=0)简单示例:
private static readonly LazyLazyConnection = new Lazy (() => ConnectionMultiplexer.Connect("localhost:6379")); public static ConnectionMultiplexer Connection => LazyConnection.Value;
// 获取数据库(可指定 dbIndex) IDatabase db = Connection.GetDatabase(0);
所有操作都通过 IDatabase 提供的方法完成,支持同步和异步(推荐异步)。
await db.StringSetAsync("name", "Alice");string value = await db.StringGetAsync("name");
await db.HashSetAsync("user:1001", new HashEntry[] { new("name", "Bob"), new("age", "28") });var values = await db.HashGetAllAsync("user:1001");
await db.ListRightPushAsync("tasks", "login");string first = awa
it db.ListLeftPopAsync("tasks");
await db.SetAddAsync("tags", "redis", "csharp");bool exists = await db.SetContainsAsync("tags", "redis");
await db.SortedSetAddAsync("leaderboard", new SortedSetEntry("alice", 95.5));var top3 = await db.SortedSetRangeByRankAsync("leaderboard", 0, 2, Order.Descending);
StackExchange.Redis 默认只支持 byte[],存对象需自行序列化(如 JSON);同时注意连接状态和超时配置。
System.Text.Json 序列化:await db.StringSetAsync("user:1001", JsonSerializer.Serialize(user));User u = JsonSerializer.Deserialize(await db.StringGetAsync("user:1001"));
Connection.ConnectionFailed += (sender, e) => Console.WriteLine(e.Exception);
abortConnect=false(启动失败不抛异常)connectRetry=3(重试次数)keepAlive=60(保活秒数)defaultDatabase=0(默认 DB)基本上就这些。用好 ConnectionMultiplexer 单例 + 异步 IDatabase 操作 + 合理序列化,就能稳定高效地在 C# 中操作 Redis。