使用StackExchange.Redis库实现.NET中Redis缓存读写,通过NuGet安装包并用ConnectionMultiplexer单例管理连接;2. 封装RedisCacheService类提供字符串和对象的存取、删除操作,支持设置过期时间及JSON序列化;3. 在应用中调用该服务进行缓存读写,需注意处理序列化、异常及生产环境下的重试与日志。

在.NET项目中实现Redis缓存读写,最常用的方式是使用StackExchange.Redis这个官方推荐的客户端库。下面是一个简单、实用的实现步骤,帮助你在.NET(包括.NET 6/7/8)中快速集成Redis进行缓存操作。
1. 安装 StackExchange.Redis 包
在项目中通过 NuGet 安装 Redis 客户端:
Install-Package StackExchange.Redis2. 创建 Redis 连接管理器
Redis连接应被复用,不要每次操作都新建连接。建议使用 ConnectionMultiplexer 单例模式管理连接:
using StackExchange.Redis;
public static class RedisCacheManager
{
private static readonly ConnectionMultiplexer _connection;
private static readonly IDatabase _database;
static RedisCacheManager()
{
var configuration = "localhost:6379"; // 可替换为你的Redis地址
_connection = ConnectionMultiplexer.Connect(configuration);
_database = _connection.GetDatabase(); // 默认数据库 0
}
public static IDatabase GetDatabase()
{
return _database;
}
}
3. 实现简单的缓存读写方法
封装常用的 Set 和 Get 操作:
public class RedisCacheService
{
private readonly IDatabase _db;
public RedisCacheService()
{
_db = RedisCacheManager.GetDatabase();
}
// 写入字符串缓存,支持过期时间
public bool SetString(string key, string value, TimeSpan? expiry = null)
{
return _db.StringSet(key, value, expiry);
}
// 读取字符串缓存
public string GetString(string key)
{
return _db.StringGet(key);
}
// 删除缓存
public bool Remove(string key)
{
return _db.KeyDelete(key);
}
// 设置对象(需序列化,例如使用 JSON)
public bool SetObject(string key, T obj, TimeSpan? expiry = null)
{
var json = System.Text.Json.JsonSerializer.Serialize(obj);
return _db.StringSet(key, json, expiry);
}
// 获取反序列化的对象
public T GetObject(string key)
{
var json = _db.StringGet(key);
if (!json.IsNullOrEmpty)
{
return System.Text.Json.JsonSerializer.Deserialize(json!);
}
return default(T);
}
}
4. 在程序中使用示例
比如在控制台或 Web API 中调用:
var cache = new RedisCacheService();
// 写入缓存
cache.SetString("name", "张三", TimeSpan.FromMinutes(10));
cache.SetObject("user", new { Id = 1, Name = "李四" }, TimeSpan.FromMinutes(5));
// 读取缓存
var name = cache.GetString("name");
var user = cache.GetObject
基本上就这些。只要Redis服务运行正常(默认端口6379),.NET就能通过上述方式实现高效缓存读写。注意处理序列化细节和异常(如Redis不可用),生产环境建议加上重试机制和日志记录。不复杂但容易忽略。










