Redis Helper封装:静态方法

Redis面试题:

1、什么是事务?2、Redis中有事务吗?3、Redis中的事务可以回滚吗?

答:

1、事务是指一个完整的动作,要么全部执行,要么什么也没有做

2、Redis中有事务,Redis 事务不是严格意义上的事务,只是用于帮助用户在一个步骤中执行多个命令。单个 Redis 命令的执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行并不是原子性的

3、Redis 事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令回滚,也不会造成后续的指令不做

事务一般都是为原子性而生,既然Redis事务没有原子性,那他存在的意义是什么

答:redis事务的主要作用就是串联多个命令防止 别的命令插队。

RedisHelper封装

1、添加StackExchange.Redis引用

Install-Package StackExchange.Redis -Version 2.0.601

2、封装

using Microsoft.AspNetCore.DataProtection.KeyManagement;
using StackExchange.Redis;namespace Web.Common
{/// <summary>/// Redis 助手/// </summary>public static class RedisHelper{#region 获取Multiplexer实例:单例模式public static IConnectionMultiplexer ConnMultiplexerInstance{get{return _ConnectionMultiplexer;// 总是返回同一个实例 }}#endregion 其它#region private field/// <summary>/// 连接字符串/// </summary>private static readonly string ConnectionString;/// <summary>/// redis 连接对象:单例/// </summary>private static IConnectionMultiplexer _ConnectionMultiplexer;/// <summary>/// 默认的 Key 值(用来当作 RedisKey 的前缀)/// </summary>private static readonly string DefaultPrefix;/// <summary>/// 默认的超时时间(单位毫秒)/// </summary>private static readonly TimeSpan? DefaultTimeout;/// <summary>/// 默认库(0-15)/// </summary>private static readonly int DefaultDB;/// <summary>/// 锁/// </summary>private static readonly object Locker = new object();/ <summary>/ 数据库/ </summary>//private readonly IDatabase GetOperationDB(db);#endregion private field#region 构造函数static RedisHelper(){var configuration = new ConfigurationBuilder().SetBasePath(AppDomain.CurrentDomain.BaseDirectory).AddJsonFile("appsettings.json").Build();// 读取Redis连接字符串ConnectionString = configuration["Redis:Default:Connection"] ?? "127.0.0.1:6379";//var options = ConfigurationOptions.Parse(ConnectionString);//options.Password = null; //密码//_ConnectionMultiplexer=ConnectionMultiplexer.Connect(options);_ConnectionMultiplexer = ConnectionMultiplexer.Connect(ConnectionString);//默认Key的前缀DefaultPrefix = configuration["Redis:Default:DefaultPrefix"];//默认操作数据库:如果配置了默认库,则按配置的默认库,没有配置则默认库为0DefaultDB = configuration["Redis:Default:DefaultDB"] == null ? 0 : Convert.ToInt32(configuration["Redis:Default:DefaultDB"]);//键的默认过期时间:如果配置了过期时间,则按配置规则计算过期时间,没有配置则默认过期时间为7天DefaultTimeout = configuration["Redis:Default:DefaultTimeout"] != null ? TimeSpan.FromSeconds(Convert.ToInt32(configuration["Redis:Default:DefaultTimeout"])) : TimeSpan.FromSeconds(60);AddRegisterEvent();}/// <summary>/// 获取要操作的库/// </summary>/// <param name="db">库,0和-1都是第一个库,1是第二个库...</param>/// <returns></returns>private static IDatabase GetOperationDB(int? db){if (db == null){return ConnMultiplexerInstance.GetDatabase(DefaultDB);}else{return ConnMultiplexerInstance.GetDatabase(db.Value);}}#endregion 构造函数#region String 操作/// <summary>/// 设置 key 并保存字符串(如果 key 已存在,则覆盖值)/// </summary>/// <param name="redisKey">键</param>/// <param name="redisValue">值</param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool StringSet(string redisKey, string redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var exptime = GetRedisKeyExpireTime(expiry);return GetOperationDB(db).StringSet(redisKey, redisValue, exptime);}/// <summary>/// 保存多个 Key-value/// </summary>/// <param name="keyValuePairs">键</param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool StringSet(IEnumerable<KeyValuePair<string, string>> keyValuePairs, TimeSpan? expiry = null, string? prefix = null, int? db = null){var pairs = keyValuePairs.Select(x => new KeyValuePair<RedisKey, RedisValue>(AddKeyPrefix(x.Key, prefix), x.Value));var result = GetOperationDB(db).StringSet(pairs.ToArray());_ = keyValuePairs.Select(y => KeyExpire(y.Key, expiry, prefix, db));//设置key的过期时间return result;}/// <summary>/// 存储一个对象(该对象会被序列化保存)/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool StringSet<T>(string key, T redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var exptime = GetRedisKeyExpireTime(expiry);try{var json = Serialize(redisValue);return GetOperationDB(db).StringSet(redisKey, json, exptime);}catch{return false;}}/// <summary>/// 获取字符串/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static string? StringGet(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).StringGet(redisKey);}/// <summary>/// 获取一个对象(会进行反序列化)/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static T? StringGet<T>(string redisKey, string? prefix = null, int? db = null){try{redisKey = AddKeyPrefix(redisKey, prefix);return Deserialize<T>(GetOperationDB(db).StringGet(redisKey));}catch{return default;}}#region async/// <summary>/// 保存一个字符串值/// </summary>/// <param name="redisKey">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> StringSetAsync(string redisKey, string redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var exptime = GetRedisKeyExpireTime(expiry);return await GetOperationDB(db).StringSetAsync(redisKey, redisValue, exptime);}/// <summary>/// 保存一组字符串值/// </summary>/// <param name="keyValuePairs"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> StringSetAsync(IEnumerable<KeyValuePair<string, string>> keyValuePairs, TimeSpan? expiry = null, string? prefix = null, int? db = null){var pairs = keyValuePairs.Select(x => new KeyValuePair<RedisKey, RedisValue>(AddKeyPrefix(x.Key, prefix), x.Value));var result = await GetOperationDB(db).StringSetAsync(pairs.ToArray());_ = keyValuePairs.Select(y => KeyExpire(y.Key, expiry, prefix, db));//设置key的过期时间return result;}/// <summary>/// 存储一个对象(该对象会被序列化保存)/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="redisValue">值</param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> StringSetAsync<T>(string redisKey, T redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){try{redisKey = AddKeyPrefix(redisKey, prefix);var json = Serialize(redisValue);var exptime = GetRedisKeyExpireTime(expiry);return await GetOperationDB(db).StringSetAsync(redisKey, json, exptime);}catch{return false;}}/// <summary>///  获取单个值/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<string?> StringGetAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).StringGetAsync(redisKey);}/// <summary>/// 获取一个对象(会进行反序列化)/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<T?> StringGetAsync<T>(string redisKey, string? prefix = null, int? db = null){try{redisKey = AddKeyPrefix(redisKey, prefix);return Deserialize<T>(await GetOperationDB(db).StringGetAsync(redisKey));}catch{return default;}}#endregion async#endregion String 操作#region Hash 操作/// <summary>///  在 hash 设定值/// </summary>/// <param name="key">键</param>/// <param name="hashField"></param>/// <param name="value"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool HashSet(string key, string hashField, string value, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = GetOperationDB(db).HashSet(redisKey, hashField, value);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在 hash 中设定值/// </summary>/// <param name="key">键</param>/// <param name="hashFields"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>public static void HashSet(string key, IEnumerable<KeyValuePair<string, string>> hashFields, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var entries = hashFields.Select(x => new HashEntry(x.Key, x.Value));GetOperationDB(db).HashSet(redisKey, entries.ToArray());KeyExpire(key, expiry, prefix, db); //设置key的过期时间 }/// <summary>/// 在 hash 设定值(序列化)/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="hashField"></param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool HashSet<T>(string key, string hashField, T redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){try{var redisKey = AddKeyPrefix(key, prefix);var json = Serialize(redisValue);var result = GetOperationDB(db).HashSet(redisKey, hashField, json);KeyExpire(key, expiry, prefix, db);return result;}catch{return false;}}/// <summary>/// 在 hash 中获取值/// </summary>/// <param name="redisKey">键</param>/// <param name="hashField"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static string? HashGet(string redisKey, string hashField, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).HashGet(redisKey, hashField);}/// <summary>/// 在 hash 中获取值/// </summary>/// <param name="redisKey">键</param>/// <param name="hashFields"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static IEnumerable<string?> HashGet(string redisKey, IEnumerable<string> hashFields, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var fields = hashFields.Select(x => (RedisValue)x);return ConvertStrings(GetOperationDB(db).HashGet(redisKey, fields.ToArray()));}/// <summary>/// 从 hash 返回所有的字段值/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static IEnumerable<string?> HashKeys(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return ConvertStrings(GetOperationDB(db).HashKeys(redisKey));}/// <summary>/// 返回 hash 中的所有值/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static IEnumerable<string?> HashValues(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return ConvertStrings(GetOperationDB(db).HashValues(redisKey));}/// <summary>/// 在 hash 中获取值(反序列化)/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="hashField"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static T? HashGet<T>(string redisKey, string hashField, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return Deserialize<T>(GetOperationDB(db).HashGet(redisKey, hashField));}/// <summary>/// 判断该字段是否存在 hash 中/// </summary>/// <param name="redisKey">键</param>/// <param name="hashField"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool HashExists(string redisKey, string hashField, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).HashExists(redisKey, hashField);}/// <summary>/// 从 hash 中移除指定字段/// </summary>/// <param name="redisKey">键</param>/// <param name="hashField"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool HashDelete(string redisKey, string hashField, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).HashDelete(redisKey, hashField);}/// <summary>/// 从 hash 中移除指定字段/// </summary>/// <param name="redisKey">键</param>/// <param name="hashFields"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>/// <exception cref="ArgumentNullException"></exception>public static long HashDelete(string redisKey, IEnumerable<string?> hashFields, string? prefix = null, int? db = null){if (hashFields is null){throw new ArgumentNullException(nameof(hashFields));}redisKey = AddKeyPrefix(redisKey, prefix);var fields = hashFields.Select(x => (RedisValue)x);return GetOperationDB(db).HashDelete(redisKey, fields.ToArray());}#region async/// <summary>/// 在 hash 设定值/// </summary>/// <param name="key">键</param>/// <param name="hashField"></param>/// <param name="value"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> HashSetAsync(string key, string hashField, string value, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result= await GetOperationDB(db).HashSetAsync(redisKey, hashField, value);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在 hash 中设定值/// </summary>/// <param name="key">键</param>/// <param name="hashFields"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task HashSetAsync(string key, IEnumerable<KeyValuePair<string, string>> hashFields, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var entries = hashFields.Select(x => new HashEntry(x.Key, x.Value));await GetOperationDB(db).HashSetAsync(redisKey, entries.ToArray());KeyExpire(key, expiry, prefix, db);}/// <summary>/// 在 hash 设定值(序列化)/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="hashField"></param>/// <param name="value"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> HashSetAsync<T>(string key, string hashField, T value, TimeSpan? expiry = null, string? prefix = null, int? db = null){try{var redisKey = AddKeyPrefix(key, prefix);var json = Serialize(value);var result = await GetOperationDB(db).HashSetAsync(redisKey, hashField, json);KeyExpire(key, expiry, prefix, db);return result;}catch{return false;}}/// <summary>/// 判断该字段是否存在 hash 中/// </summary>/// <param name="redisKey">键</param>/// <param name="hashField"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> HashExistsAsync(string redisKey, string hashField, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).HashExistsAsync(redisKey, hashField);}/// <summary>/// 从 hash 中移除指定字段/// </summary>/// <param name="redisKey">键</param>/// <param name="hashField"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> HashDeleteAsync(string redisKey, string hashField, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).HashDeleteAsync(redisKey, hashField);}/// <summary>/// 从 hash 中移除指定字段/// </summary>/// <param name="redisKey">键</param>/// <param name="hashFields"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> HashDeleteAsync(string redisKey, IEnumerable<string> hashFields, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var fields = hashFields.Select(x => (RedisValue)x);return await GetOperationDB(db).HashDeleteAsync(redisKey, fields.ToArray());}/// <summary>/// 在 hash 中获取值/// </summary>/// <param name="redisKey">键</param>/// <param name="hashField"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<string?> HashGetAsync(string redisKey, string hashField, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).HashGetAsync(redisKey, hashField);}/// <summary>/// 在 hash 中获取值/// </summary>/// <param name="redisKey">键</param>/// <param name="hashFields"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<IEnumerable<string?>> HashGetAsync(string redisKey, IEnumerable<string> hashFields, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var fields = hashFields.Select(x => (RedisValue)x);return ConvertStrings(await GetOperationDB(db).HashGetAsync(redisKey, fields.ToArray()));}/// <summary>/// 从 hash 返回所有的字段值/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<IEnumerable<string?>> HashKeysAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return ConvertStrings(await GetOperationDB(db).HashKeysAsync(redisKey));}/// <summary>/// 返回 hash 中的所有值/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<IEnumerable<string?>> HashValuesAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return ConvertStrings(await GetOperationDB(db).HashValuesAsync(redisKey));}/// <summary>/// 在 hash 中获取值(反序列化)/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="hashField"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<T?> HashGetAsync<T>(string redisKey, string hashField, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var result = await GetOperationDB(db).HashGetAsync(redisKey, hashField);return Deserialize<T>(result);}#endregion async#endregion Hash 操作#region List 操作/// <summary>/// 在列表头部插入值。如果键不存在,先创建再插入值/// </summary>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static long ListLeftPush(string key, string redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = GetOperationDB(db).ListLeftPush(redisKey, redisValue);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在列表头部插入值。如果键不存在,先创建再插入值/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static long ListLeftPush<T>(string key, T redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = GetOperationDB(db).ListLeftPush(redisKey, Serialize(redisValue));KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在列表尾部插入值。如果键不存在,先创建再插入值/// </summary>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static long ListRightPush(string key, string redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);long result = GetOperationDB(db).ListRightPush(redisKey, redisValue);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在列表尾部插入值。如果键不存在,先创建再插入值/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns>push操作后列表的长度。</returns>public static long ListRightPush<T>(string key, T redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = GetOperationDB(db).ListRightPush(redisKey, Serialize(redisValue));KeyExpire(key, expiry, prefix, db);return result;}/// <summary>///  移除并返回存储在该键列表的第一个元素/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns>返回字符串</returns>public static string? ListLeftPop(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).ListLeftPop(redisKey);}/// <summary>/// 移除并返回存储在该键列表的第一个元素/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns>返回泛型对象</returns>public static T? ListLeftPop<T>(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return Deserialize<T?>(GetOperationDB(db).ListLeftPop(redisKey));}/// <summary>/// 移除并返回存储在该键列表的最后一个元素/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static string? ListRightPop(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).ListRightPop(redisKey);}/// <summary>/// 移除并返回存储在该键列表的最后一个元素:/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns>返回泛型对象</returns>public static T? ListRightPop<T>(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return Deserialize<T?>(GetOperationDB(db).ListRightPop(redisKey));}/// <summary>/// 移除列表指定键上与该值相同的元素/// </summary>/// <param name="redisKey">键</param>/// <param name="redisValue"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static long ListRemove(string redisKey, string redisValue, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).ListRemove(redisKey, redisValue);}/// <summary>/// 返回列表上该键的长度,如果不存在,返回 0/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static long ListLength(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).ListLength(redisKey);}/// <summary>/// 返回在该列表上键所对应的元素/// </summary>/// <param name="redisKey">键</param>/// <param name="start"></param>/// <param name="stop"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static IEnumerable<string?> ListRange(string redisKey, long start = 0L, long stop = -1L, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return ConvertStrings(GetOperationDB(db).ListRange(redisKey, start, stop));}#region List-async/// <summary>/// 在列表尾部插入值。如果键不存在,先创建再插入值/// </summary>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> ListRightPushAsync(string key, string redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = await GetOperationDB(db).ListRightPushAsync(redisKey, redisValue);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在列表头部插入值。如果键不存在,先创建再插入值/// </summary>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> ListLeftPushAsync(string key, string redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = await GetOperationDB(db).ListLeftPushAsync(redisKey, redisValue);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在列表头部插入值。如果键不存在,先创建再插入值/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> ListLeftPushAsync<T>(string key, T redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = await GetOperationDB(db).ListLeftPushAsync(redisKey, Serialize(redisValue));KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在列表尾部插入值。如果键不存在,先创建再插入值/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="redisValue"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> ListRightPushAsync<T>(string key, T redisValue, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = await GetOperationDB(db).ListRightPushAsync(redisKey, Serialize(redisValue));KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 移除并返回存储在该键列表的第一个元素/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<string?> ListLeftPopAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).ListLeftPopAsync(redisKey);}/// <summary>/// 移除并返回存储在该键列表的最后一个元素/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<string?> ListRightPopAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).ListRightPopAsync(redisKey);}/// <summary>/// 移除列表指定键上与该值相同的元素/// </summary>/// <param name="redisKey">键</param>/// <param name="redisValue"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> ListRemoveAsync(string redisKey, string redisValue, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).ListRemoveAsync(redisKey, redisValue);}/// <summary>/// 返回列表上该键的长度,如果不存在,返回 0/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> ListLengthAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).ListLengthAsync(redisKey);}/// <summary>///  返回在该列表上键所对应的元素/// </summary>/// <param name="redisKey">键</param>/// <param name="start"></param>/// <param name="stop"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<IEnumerable<string>> ListRangeAsync(string redisKey, long start = 0L, long stop = -1L, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var query = await GetOperationDB(db).ListRangeAsync(redisKey, start, stop);return query.Select(x => x.ToString());}/// <summary>/// 移除并返回存储在该键列表的第一个元素/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<T?> ListLeftPopAsync<T>(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return Deserialize<T?>(await GetOperationDB(db).ListLeftPopAsync(redisKey));}/// <summary>/// 移除并返回存储在该键列表的最后一个元素/// </summary>/// <typeparam name="T"></typeparam>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<T?> ListRightPopAsync<T>(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return Deserialize<T?>(await GetOperationDB(db).ListRightPopAsync(redisKey));}#endregion List-async#endregion List 操作#region SortedSet 操作/// <summary>///  SortedSet 新增/// </summary>/// <param name="redisKey">键</param>/// <param name="member"></param>/// <param name="score"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool SortedSetAdd(string key, string member, double score, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = GetOperationDB(db).SortedSetAdd(redisKey, member, score);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// SortedSet 新增/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="member"></param>/// <param name="score"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool SortedSetAdd<T>(string key, T member, double score, TimeSpan? expiry = null, string? prefix = null, int? db = null){try{var redisKey = AddKeyPrefix(key, prefix);var json = Serialize(member);var result = GetOperationDB(db).SortedSetAdd(redisKey, json, score);KeyExpire(key, expiry, prefix, db);return result;}catch{return false;}}/// <summary>/// 增量的得分排序的集合中的成员存储键值键按增量/// </summary>/// <param name="key">键</param>/// <param name="member"></param>/// <param name="value"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static double SortedSetIncrement(string key, string member, double value = 1, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = GetOperationDB(db).SortedSetIncrement(redisKey, member, value);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在有序集合中返回指定范围的元素,默认情况下从低到高。/// </summary>/// <param name="redisKey">键</param>/// <param name="start"></param>/// <param name="stop"></param>/// <param name="order"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static IEnumerable<string> SortedSetRangeByRank(string redisKey, long start = 0L, long stop = -1L, OrderType order = OrderType.Ascending, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).SortedSetRangeByRank(redisKey, start, stop, (Order)order).Select(x => x.ToString());}/// <summary>/// 返回有序集合的元素个数/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static long SortedSetLength(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).SortedSetLength(redisKey);}/// <summary>/// 返回有序集合的元素个数/// </summary>/// <param name="redisKey">键</param>/// <param name="memebr"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool SortedSetLength(string redisKey, string memebr, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return GetOperationDB(db).SortedSetRemove(redisKey, memebr);}#region SortedSet-Async/// <summary>/// SortedSet 新增/// </summary>/// <param name="redisKey">键</param>/// <param name="member"></param>/// <param name="score"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> SortedSetAddAsync(string key, string member, double score, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = await GetOperationDB(db).SortedSetAddAsync(redisKey, member, score);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// SortedSet 新增/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">键</param>/// <param name="member"></param>/// <param name="score"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> SortedSetAddAsync<T>(string key, T member, double score, TimeSpan? expiry = null, string? prefix = null, int? db = null){try{var redisKey = AddKeyPrefix(key, prefix);var json = Serialize(member);var result = await GetOperationDB(db).SortedSetAddAsync(redisKey, json, score);KeyExpire(key, expiry, prefix, db);return result;}catch{return false;}}/// <summary>/// 增量的得分排序的集合中的成员存储键值键按增量/// </summary>/// <param name="key">键</param>/// <param name="member"></param>/// <param name="value"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static Task<double> SortedSetIncrementAsync(string key, string member, double value = 1, TimeSpan? expiry = null, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);var result = GetOperationDB(db).SortedSetIncrementAsync(redisKey, member, value);KeyExpire(key, expiry, prefix, db);return result;}/// <summary>/// 在有序集合中返回指定范围的元素,默认情况下从低到高。/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<IEnumerable<string?>> SortedSetRangeByRankAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return ConvertStrings(await GetOperationDB(db).SortedSetRangeByRankAsync(redisKey));}/// <summary>/// 返回有序集合的元素个数/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> SortedSetLengthAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).SortedSetLengthAsync(redisKey);}/// <summary>/// 返回有序集合的元素个数/// </summary>/// <param name="redisKey">键</param>/// <param name="memebr"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> SortedSetRemoveAsync(string redisKey, string memebr, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).SortedSetRemoveAsync(redisKey, memebr);}#endregion SortedSet-Async#endregion SortedSet 操作#region key 操作/// <summary>/// 移除指定 Key/// </summary>/// <param name="key">不带前缀的键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool KeyDelete(string key, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);return GetOperationDB(db).KeyDelete(redisKey);}/// <summary>/// 移除指定 Key/// </summary>/// <param name="redisKeys"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static long KeyDelete(IEnumerable<string> redisKeys, string? prefix = null, int? db = null){var keys = redisKeys.Select(key => (RedisKey)AddKeyPrefix(key, prefix));return GetOperationDB(db).KeyDelete(keys.ToArray());}/// <summary>/// 校验 Key 是否存在/// </summary>/// <param name="key">不带前缀的键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool KeyExists(string key, string? prefix = null, int? db = null){var redisKey = AddKeyPrefix(key, prefix);return GetOperationDB(db).KeyExists(redisKey);}/// <summary>/// 重命名 Key/// </summary>/// <param name="oldKey">不带前缀的键</param>/// <param name="newKey">新的不带前缀的键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool KeyRename(string oldKey, string newKey, string? prefix = null, int? db = null){var redisOldKey = AddKeyPrefix(oldKey, prefix);var redisNewKey = AddKeyPrefix(newKey, prefix);return GetOperationDB(db).KeyRename(redisOldKey, redisNewKey);}/// <summary>/// 设置 Key 的过期时间/// </summary>/// <param name="redisKey">键</param>/// <param name="expiry"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static bool KeyExpire(string redisKey, TimeSpan? expiry, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var exptime = GetRedisKeyExpireTime(expiry);return GetOperationDB(db).KeyExpire(redisKey, exptime);}#region key-async/// <summary>/// 移除指定 Key/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> KeyDeleteAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).KeyDeleteAsync(redisKey);}/// <summary>/// 移除指定 Key/// </summary>/// <param name="redisKeys"></param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<long> KeyDeleteAsync(IEnumerable<string> redisKeys, string? prefix = null, int? db = null){var keys = redisKeys.Select(key => (RedisKey)AddKeyPrefix(key, prefix));return await GetOperationDB(db).KeyDeleteAsync(keys.ToArray());}/// <summary>/// 校验 Key 是否存在/// </summary>/// <param name="redisKey">键</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> KeyExistsAsync(string redisKey, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);return await GetOperationDB(db).KeyExistsAsync(redisKey);}/// <summary>/// 重命名 Key/// </summary>/// <param name="oldKey">待重命名的键名称</param>/// <param name="newKey">新的键名称</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> KeyRenameAsync(string oldKey, string newKey, string? prefix = null, int? db = null){         var redisOldKey = AddKeyPrefix(oldKey, prefix);var redisNewKey = AddKeyPrefix(newKey, prefix);return await GetOperationDB(db).KeyRenameAsync(redisOldKey, redisNewKey);}/// <summary>/// 设置 Key 的过期时间(单位:毫秒)/// </summary>/// <param name="redisKey">键</param>/// <param name="expiry"></param>/// <param name="expiry">过期时间:为Null表示使用appsettings.json配置文件中DefaultTimeout节点的值.如未指定该值且未设置DefaultTimeout则默认库为7天</param>/// <param name="prefix">键的前缀:为Null表示使用appsettings.json配置文件中DefaultPrefix节点的值</param>/// <param name="db">库(0-15):为Null表示使用appsettings.json配置文件中DefaultDB节点的值.如未指定该值且未设置DefaultDB则默认库为0</param>/// <returns></returns>public static async Task<bool> KeyExpireAsync(string redisKey, TimeSpan? expiry, string? prefix = null, int? db = null){redisKey = AddKeyPrefix(redisKey, prefix);var exptime = GetRedisKeyExpireTime(expiry);return await GetOperationDB(db).KeyExpireAsync(redisKey, exptime);}#endregion key-async#endregion key 操作#region private method/// <summary>/// 添加 Key 的前缀/// </summary>/// <param name="key">键</param>/// <param name="prefix">Key 的前缀:如果为空则为appsettings.json中配置节点中的默认前缀DefaultPrefix</param>/// <returns></returns>private static string AddKeyPrefix(string key, string? prefix){if (string.IsNullOrEmpty(prefix) && string.IsNullOrEmpty(DefaultPrefix)){return key;}return prefix ?? DefaultPrefix + ":" + key;}/// <summary>/// 键的过期时间/// </summary>/// <param name="time">过期时间</param>/// <returns></returns>private static TimeSpan? GetRedisKeyExpireTime(TimeSpan? time){if (time == null && DefaultTimeout == null){return TimeSpan.Zero;}else{return time ?? DefaultTimeout;}}/// <summary>/// 转换为字符串/// </summary>/// <typeparam name="T"></typeparam>/// <param name="list"></param>/// <returns></returns>private static IEnumerable<string?> ConvertStrings<T>(IEnumerable<T> list) where T : struct{if (list == null) throw new ArgumentNullException(nameof(list));return list.Select(x => x.ToString());}#region 注册事件/// <summary>/// 添加注册事件/// </summary>private static void AddRegisterEvent(){_ConnectionMultiplexer.ConnectionRestored += ConnMultiplexer_ConnectionRestored;_ConnectionMultiplexer.ConnectionFailed += ConnMultiplexer_ConnectionFailed;_ConnectionMultiplexer.ErrorMessage += ConnMultiplexer_ErrorMessage;_ConnectionMultiplexer.ConfigurationChanged += ConnMultiplexer_ConfigurationChanged;_ConnectionMultiplexer.HashSlotMoved += ConnMultiplexer_HashSlotMoved;_ConnectionMultiplexer.InternalError += ConnMultiplexer_InternalError;_ConnectionMultiplexer.ConfigurationChangedBroadcast += ConnMultiplexer_ConfigurationChangedBroadcast;}/// <summary>/// 重新配置广播时(通常意味着主从同步更改)/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private static void ConnMultiplexer_ConfigurationChangedBroadcast(object sender, EndPointEventArgs e){Console.WriteLine($"{nameof(ConnMultiplexer_ConfigurationChangedBroadcast)}: {e.EndPoint}");}/// <summary>/// 发生内部错误时(主要用于调试)/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private static void ConnMultiplexer_InternalError(object sender, InternalErrorEventArgs e){Console.WriteLine($"{nameof(ConnMultiplexer_InternalError)}: {e.Exception}");}/// <summary>/// 更改集群时/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private static void ConnMultiplexer_HashSlotMoved(object sender, HashSlotMovedEventArgs e){Console.WriteLine($"{nameof(ConnMultiplexer_HashSlotMoved)}: {nameof(e.OldEndPoint)}-{e.OldEndPoint} To {nameof(e.NewEndPoint)}-{e.NewEndPoint}, ");}/// <summary>/// 配置更改时/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private static void ConnMultiplexer_ConfigurationChanged(object sender, EndPointEventArgs e){Console.WriteLine($"{nameof(ConnMultiplexer_ConfigurationChanged)}: {e.EndPoint}");}/// <summary>/// 发生错误时/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private static void ConnMultiplexer_ErrorMessage(object sender, RedisErrorEventArgs e){Console.WriteLine($"{nameof(ConnMultiplexer_ErrorMessage)}: {e.Message}");}/// <summary>/// 物理连接失败时/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private static void ConnMultiplexer_ConnectionFailed(object sender, ConnectionFailedEventArgs e){Console.WriteLine($"{nameof(ConnMultiplexer_ConnectionFailed)}: {e.Exception}");}/// <summary>/// 建立物理连接时/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private static void ConnMultiplexer_ConnectionRestored(object sender, ConnectionFailedEventArgs e){Console.WriteLine($"{nameof(ConnMultiplexer_ConnectionRestored)}: {e.Exception}");}#endregion 注册事件/// <summary>/// 序列化/// </summary>/// <param name="obj"></param>/// <returns></returns>private static byte[]? Serialize(object? obj){if (obj == null) return null;return System.Text.Json.JsonSerializer.SerializeToUtf8Bytes(obj);}/// <summary>/// 反序列化/// </summary>/// <typeparam name="T"></typeparam>/// <param name="data"></param>/// <returns></returns>private static T? Deserialize<T>(byte[]? data){if (data == null) return default;return System.Text.Json.JsonSerializer.Deserialize<T>(data);}/// <summary>/// 排序枚举/// </summary>public enum OrderType{/// <summary>/// 升序/// </summary>Ascending,/// <summary>/// 降序/// </summary>Descending}#endregion private method}
}

配置文件

在下面这个示例中,我们使用了Sentinel部分来配置Redis哨兵模式。你需要指定MasterName,这是你要连接的Redis主服务器的名称。然后,你需要提供一个Sentinels数组,其中包含哨兵节点的主机和端口信息。在示例中,我们使用了三个哨兵节点,但你可以根据实际情况进行更改。

{//"RedisConnectionStrings": "127.0.0.1:6379,password=,defaultDatabase=0,connectTimeout=5000,syncTimeout=1000","Redis": {"Host": "127.0.0.1","Port": 6379,"Password": "", //密码"Database": 0, //默认库"DefaultPrefix": "slxt", //键的默认前缀"DefaultTimeout": 604800, //键的默认超时时间 单位:秒//"ConnectionMultiplexer": "StackExchange.Redis", //Redis使用的客户端实例:如StackExchange.Redis和CsRedis客户端一般我们不需要//哨兵模式"Sentinel": {"MasterName": "mymaster","Sentinels": [{"Host": "127.0.0.1","Port": 26379},{"Host": "127.0.0.1","Port": 26380},{"Host": "127.0.0.1","Port": 26381}]}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/222854.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nodejs+vue+微信小程序+python+PHP血液中心管理平台的设计与实现-计算机毕业设计推荐

实现采血的完整功能&#xff0c;系统用户主要分为两类&#xff0c;一类是管理员&#xff0c;一类是采血工作人员。管理员主要对采血工作人员以及血库进行管理。派发账号给员工作为采血工作人员&#xff0c;对血库的出库入库进行信息化管理。采血工作人员主要完成采血工作。通过…

日志框架Log4j、JUL、JCL、Slf4j、Logback、Log4j2

为什么程序需要记录日志 我们不可能实时的24小时对系统进行人工监控&#xff0c;那么如果程序出现异常错误时要如何排查呢&#xff1f;并且系统在运行时做了哪些事情我们又从何得知呢&#xff1f;这个时候日志这个概念就出现了&#xff0c;日志的出现对系统监控和异常分析起着…

亿赛通电子文档安全管理系统 SQL注入漏洞复现

0x01 产品简介 亿赛通电子文档安全管理系统&#xff08;简称&#xff1a;CDG&#xff09;是一款电子文档安全加密软件&#xff0c;该系统利用驱动层透明加密技术&#xff0c;通过对电子文档的加密保护&#xff0c;防止内部员工泄密和外部人员非法窃取企业核心重要数据资产&…

C语言第五十弹---模拟使用strcat函数

使用C语言模拟使用strcat函数 strcat 函数是 C 标准库中的字符串拼接函数&#xff0c;它用于将一个字符串追加到另一个字符串的末尾。strcat 函数的定义如下&#xff1a;它接受两个参数&#xff0c;第一个参数 dest 是目标字符串的指针&#xff0c;第二个参数 src 是源字符串的…

DHCP原理与配置

文章目录 DHCP原理与配置一、DHCP概述二、DHCP优势三、DHCP的分配方式四、DHCP工作原理五、DHCP的配置1、DHCP的配置命令2、DHCP的配置步骤 DHCP原理与配置 一、DHCP概述 使用动态主机配置协议DHCP&#xff08;Dynamic Host Configuration Protocol&#xff09;来配置IP 地址等…

使用VeryFL【02】python环境安装

新建虚拟环境 conda create --name vfl python3.7激活新建的虚拟环境 conda activate vfl安装pytorch 安装Brownie pip install eth-brownie -i https://pypi.tuna.tsinghua.edu.cn/simple

智能优化算法应用:基于乌燕鸥算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于乌燕鸥算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于乌燕鸥算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.乌燕鸥算法4.实验参数设定5.算法结果6.参考文…

Docker安全性:最佳实践和常见安全考虑

Docker 的快速发展和广泛应用使其成为现代应用开发的热门选择&#xff0c;然而&#xff0c;容器环境的安全性也受到关注。本文将深入研究 Docker 安全性的最佳实践&#xff0c;包括容器镜像安全、容器运行时安全、网络安全等方面&#xff0c;并提供丰富的示例代码&#xff0c;帮…

Appium自动化常用adb操作封装

一、前置说明 在Appium自动化中&#xff0c;经常需要使用adb命令与设备进行交互&#xff0c;所以有必要把常用的adb操作封装成一个类 二、代码实现 import os import platform import re import subprocessfrom common import path from common.exception import AndroidSDK…

Java实现快速排序及其动图演示

快速排序&#xff08;Quicksort&#xff09;是一种基于分治思想的排序算法。它通过选择一个基准元素&#xff0c;将数组分为两个子数组&#xff0c;其中一个子数组的所有元素都小于基准元素&#xff0c;另一个子数组的所有元素都大于基准元素&#xff0c;然后递归地对这两个子数…

实验:华为静态路由配置

1.实验目的&#xff1a; 掌握华为路由器和交换机的基本配置方法理解静态路由的原理和作用学习使用vlan和trunk技术划分和连接不同网段能够通过ping命令测试网络连通性和故障排除 2.实验内容&#xff1a; 使用ARI200路由器和S5735交换机搭建如下图所示的网络拓扑在路由器上配…

OpenCV-Python15:图像阈值处理

目录 目标 图像阈值及分割算法介绍 简单阈值算法 自适应阈值算法 Otsus 二值化算法 Otsus 二值化原理 目标 通过本文你将学到图像二值化、简单阈值处理、自适应阈值、Otsus 二值化等。将学习的函数有cv2.threshold,cv2.adaptiveThreshold 等。 图像阈值及分割算法介…

Spring Boot学习:ShardingSphere-JDBC数据分片配置

目录 前言sharding-jdbc配置配置解析table-strategy分片策略1、standard2、none3、inline4、complex 前言 Spring Boot学习专栏: 传送门 sharding-jdbc配置 下面是Spring Boot项目下的ShardingSphere-JDBC数据分片配置 #数据源名称&#xff0c;多数据源以逗号分隔 spring.s…

Numpy 实现C4.5决策树

C4.5 信息增益比实现决策树 信息增益比 g R ( D , A ) g ( D , A ) H ( D ) g_{R}(D, A)\frac{g(D, A)}{H(D)} gR​(D,A)H(D)g(D,A)​ 其中&#xff0c; g ( D , A ) g(D,A) g(D,A)是信息增益&#xff0c; H ( D ) H(D) H(D)是数据集 D D D的熵 代码实现 import numpy as …

Qt图像处理-Qt中配置OpenCV打开本地图片

本文讲解Qt中配置OpenCV过程并用实例展示如何使用OpenCV打开图片(windows环境下) 一、下载OpenCv 本文使用版本OpenCV-MinGW-Build-OpenCV-3.4.5 下载地址: https://codeload.github.com/huihut/OpenCV-MinGW-Build/zip/refs/heads/OpenCV-3.4.5 点击Code-local-Downlo…

Android基础概念的学习笔记

1 Android原生编程 1.1 基础概念的文档链接 Android原生应用的一般流程 & 项目文件结构Android.mk文件语法Application.mk文件介绍 1.2 【Q】&#xff1a;ndk-build命令对于Application.mk和Android.mk文件的处理顺序是什么样的呀&#xff1f; Note: Google的官方文档里面…

Linux基本命令操作

一、命令操作快捷键 1.Tab键&#xff1a;自动补齐 2.ctrlL &#xff1a;清屏 二、使用命令获取帮助信息 1. # ls --help 2. # man ls 三、目录和文件管理命令 1. pwd \\显示路径 2. cd \\进入或切换目录 3.​​​​​​​ ls -l \\显示详细信息 4. ​​​​​​​ ls -a \\…

实验5:NAT配置

1.实验目的&#xff1a; 了解NAT的基本概念和功能 掌握NAT的配置方法和命令 观察和分析NAT的工作原理和流程 2.实验内容&#xff1a; 在路由器上配置静态NAT&#xff0c;实现内网主机通过公网IP地址访问外网服务器在路由器上配置动态NAT&#xff0c;实现内网主机通过公网I…

STM32的基本定时器注意点

本文介绍了STM32基本定时器3个重要的寄存器PSC、ARR、CNT&#xff0c;以及缓冲机制和计数细节。 基本定时器的框图 预分频器寄存器(TIMx_PSC)可以在运行过程中修改它的数值&#xff0c;新的预分频数值将在下一个更新事件时起作用。因为更新事件发生时&#xff0c;会把 TIMx_PS…

CGAL的最优传输曲线重构

1、介绍 此程序包实现了一种重建和简化二维点集的方法。输入是一组具有质量属性的二维点&#xff0c;可能受到噪声和离群值的干扰。输出是一组线段和孤立点&#xff0c;它们近似于输入点&#xff0c;如下图所示。质量属性与每个点的近似重要性有关。 左&#xff1a;输入点集受到…