RedisHelper.cs 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using Newtonsoft.Json;
  7. using StackExchange.Redis;
  8. namespace ProjectBase.Data.Redis
  9. {
  10. public class RedisHelper
  11. {
  12. private int DbNum { get; set; } // 数据库连接数量
  13. private readonly ConnectionMultiplexer _conn;
  14. public string CustomKey;
  15. #region 构造函数
  16. public RedisHelper(int dbNum = 0)
  17. : this(dbNum, null)
  18. {
  19. }
  20. public RedisHelper(int dbNum, string readWriteHosts)
  21. {
  22. DbNum = dbNum;
  23. _conn =
  24. string.IsNullOrWhiteSpace(readWriteHosts) ?
  25. RedisConnection.Instance :
  26. RedisConnection.GetConnectionMultiplexer(readWriteHosts);
  27. }
  28. #endregion 构造函数
  29. #region String
  30. #region 同步方法
  31. /// <summary>
  32. /// 保存单个key value
  33. /// </summary>
  34. /// <param name="key">Redis Key</param>
  35. /// <param name="value">保存的值</param>
  36. /// <param name="expiry">过期时间</param>
  37. /// <returns></returns>
  38. public bool SetString(string key, string value, TimeSpan? expiry = default(TimeSpan?))
  39. {
  40. key = AddSysCustomKey(key);
  41. return Do(db => db.StringSet(key, value, expiry));
  42. }
  43. /// <summary>
  44. /// 保存多个key value
  45. /// </summary>
  46. /// <param name="keyValues">键值对</param>
  47. /// <returns></returns>
  48. public bool SetString(List<KeyValuePair<RedisKey, RedisValue>> keyValues)
  49. {
  50. List<KeyValuePair<RedisKey, RedisValue>> newkeyValues =
  51. keyValues.Select(p => new KeyValuePair<RedisKey, RedisValue>(AddSysCustomKey(p.Key), p.Value)).ToList();
  52. return Do(db => db.StringSet(newkeyValues.ToArray()));
  53. }
  54. /// <summary>
  55. /// 保存一个对象
  56. /// </summary>
  57. /// <typeparam name="T"></typeparam>
  58. /// <param name="key"></param>
  59. /// <param name="obj"></param>
  60. /// <param name="expiry"></param>
  61. /// <returns></returns>
  62. public bool SetString<T>(string key, T obj, TimeSpan? expiry = default(TimeSpan?))
  63. {
  64. key = AddSysCustomKey(key);
  65. string json = ConvertJson(obj);
  66. return Do(db => db.StringSet(key, json, expiry));
  67. }
  68. /// <summary>
  69. /// 获取单个key的值
  70. /// </summary>
  71. /// <param name="key">Redis Key</param>
  72. /// <returns></returns>
  73. public string GetString(string key)
  74. {
  75. key = AddSysCustomKey(key);
  76. return Do(db => db.StringGet(key));
  77. }
  78. /// <summary>
  79. /// 获取多个Key
  80. /// </summary>
  81. /// <param name="listKey">Redis Key集合</param>
  82. /// <returns></returns>
  83. public RedisValue[] GetString(List<string> listKey)
  84. {
  85. List<string> newKeys = listKey.Select(AddSysCustomKey).ToList();
  86. return Do(db => db.StringGet(ConvertRedisKeys(newKeys)));
  87. }
  88. /// <summary>
  89. /// 获取一个key的对象
  90. /// </summary>
  91. /// <typeparam name="T"></typeparam>
  92. /// <param name="key"></param>
  93. /// <returns></returns>
  94. public T GetString<T>(string key)
  95. {
  96. key = AddSysCustomKey(key);
  97. return Do(db => ConvertObj<T>(db.StringGet(key)));
  98. }
  99. /// <summary>
  100. /// 为数字增长val
  101. /// </summary>
  102. /// <param name="key"></param>
  103. /// <param name="val">可以为负</param>
  104. /// <returns>增长后的值</returns>
  105. public double IncrementString(string key, double val = 1)
  106. {
  107. key = AddSysCustomKey(key);
  108. return Do(db => db.StringIncrement(key, val));
  109. }
  110. /// <summary>
  111. /// 为数字减少val
  112. /// </summary>
  113. /// <param name="key"></param>
  114. /// <param name="val">可以为负</param>
  115. /// <returns>减少后的值</returns>
  116. public double DecrementString(string key, double val = 1)
  117. {
  118. key = AddSysCustomKey(key);
  119. return Do(db => db.StringDecrement(key, val));
  120. }
  121. #endregion 同步方法
  122. #region 异步方法
  123. /// <summary>
  124. /// 保存单个key value
  125. /// </summary>
  126. /// <param name="key">Redis Key</param>
  127. /// <param name="value">保存的值</param>
  128. /// <param name="expiry">过期时间</param>
  129. /// <returns></returns>
  130. public async Task<bool> SetAsyncString(string key, string value, TimeSpan? expiry = default(TimeSpan?))
  131. {
  132. key = AddSysCustomKey(key);
  133. return await Do(db => db.StringSetAsync(key, value, expiry));
  134. }
  135. /// <summary>
  136. /// 保存多个key value
  137. /// </summary>
  138. /// <param name="keyValues">键值对</param>
  139. /// <returns></returns>
  140. public async Task<bool> SetAsyncString(List<KeyValuePair<RedisKey, RedisValue>> keyValues)
  141. {
  142. List<KeyValuePair<RedisKey, RedisValue>> newkeyValues =
  143. keyValues.Select(p => new KeyValuePair<RedisKey, RedisValue>(AddSysCustomKey(p.Key), p.Value)).ToList();
  144. return await Do(db => db.StringSetAsync(newkeyValues.ToArray()));
  145. }
  146. /// <summary>
  147. /// 保存一个对象
  148. /// </summary>
  149. /// <typeparam name="T"></typeparam>
  150. /// <param name="key"></param>
  151. /// <param name="obj"></param>
  152. /// <param name="expiry"></param>
  153. /// <returns></returns>
  154. public async Task<bool> SetAsyncString<T>(string key, T obj, TimeSpan? expiry = default(TimeSpan?))
  155. {
  156. key = AddSysCustomKey(key);
  157. string json = ConvertJson(obj);
  158. return await Do(db => db.StringSetAsync(key, json, expiry));
  159. }
  160. /// <summary>
  161. /// 获取单个key的值
  162. /// </summary>
  163. /// <param name="key">Redis Key</param>
  164. /// <returns></returns>
  165. public async Task<string> GetAsyncString(string key)
  166. {
  167. key = AddSysCustomKey(key);
  168. return await Do(db => db.StringGetAsync(key));
  169. }
  170. /// <summary>
  171. /// 获取多个Key
  172. /// </summary>
  173. /// <param name="listKey">Redis Key集合</param>
  174. /// <returns></returns>
  175. public async Task<RedisValue[]> GetAsyncString(List<string> listKey)
  176. {
  177. List<string> newKeys = listKey.Select(AddSysCustomKey).ToList();
  178. return await Do(db => db.StringGetAsync(ConvertRedisKeys(newKeys)));
  179. }
  180. /// <summary>
  181. /// 获取一个key的对象
  182. /// </summary>
  183. /// <typeparam name="T"></typeparam>
  184. /// <param name="key"></param>
  185. /// <returns></returns>
  186. public async Task<T> GetAsyncString<T>(string key)
  187. {
  188. key = AddSysCustomKey(key);
  189. string result = await Do(db => db.StringGetAsync(key));
  190. return ConvertObj<T>(result);
  191. }
  192. /// <summary>
  193. /// 为数字增长val
  194. /// </summary>
  195. /// <param name="key"></param>
  196. /// <param name="val">可以为负</param>
  197. /// <returns>增长后的值</returns>
  198. public async Task<double> IncrementAsyncString(string key, double val = 1)
  199. {
  200. key = AddSysCustomKey(key);
  201. return await Do(db => db.StringIncrementAsync(key, val));
  202. }
  203. /// <summary>
  204. /// 为数字减少val
  205. /// </summary>
  206. /// <param name="key"></param>
  207. /// <param name="val">可以为负</param>
  208. /// <returns>减少后的值</returns>
  209. public async Task<double> DecrementAsyncString(string key, double val = 1)
  210. {
  211. key = AddSysCustomKey(key);
  212. return await Do(db => db.StringDecrementAsync(key, val));
  213. }
  214. #endregion 异步方法
  215. #endregion String
  216. #region Hash
  217. #region 同步方法
  218. /// <summary>
  219. /// 判断某个数据是否已经被缓存
  220. /// </summary>
  221. /// <param name="key"></param>
  222. /// <param name="dataKey"></param>
  223. /// <returns></returns>
  224. public bool IsExistsHash(string key, string dataKey)
  225. {
  226. key = AddSysCustomKey(key);
  227. return Do(db => db.HashExists(key, dataKey));
  228. }
  229. /// <summary>
  230. /// 存储数据到hash表
  231. /// </summary>
  232. /// <typeparam name="T"></typeparam>
  233. /// <param name="key"></param>
  234. /// <param name="dataKey"></param>
  235. /// <param name="t"></param>
  236. /// <returns></returns>
  237. public bool SetHash<T>(string key, string dataKey, T t)
  238. {
  239. key = AddSysCustomKey(key);
  240. return Do(db =>
  241. {
  242. string json = ConvertJson(t);
  243. return db.HashSet(key, dataKey, json);
  244. });
  245. }
  246. /// <summary>
  247. /// 移除hash中的某值
  248. /// </summary>
  249. /// <param name="key"></param>
  250. /// <param name="dataKey"></param>
  251. /// <returns></returns>
  252. public bool DeleteHash(string key, string dataKey)
  253. {
  254. key = AddSysCustomKey(key);
  255. return Do(db => db.HashDelete(key, dataKey));
  256. }
  257. /// <summary>
  258. /// 移除hash中的多个值
  259. /// </summary>
  260. /// <param name="key"></param>
  261. /// <param name="dataKeys"></param>
  262. /// <returns></returns>
  263. public long DeleteHash(string key, List<RedisValue> dataKeys)
  264. {
  265. key = AddSysCustomKey(key);
  266. //List<RedisValue> dataKeys1 = new List<RedisValue>() {"1","2"};
  267. return Do(db => db.HashDelete(key, dataKeys.ToArray()));
  268. }
  269. /// <summary>
  270. /// 从hash表获取数据
  271. /// </summary>
  272. /// <typeparam name="T"></typeparam>
  273. /// <param name="key"></param>
  274. /// <param name="dataKey"></param>
  275. /// <returns></returns>
  276. public T GetHash<T>(string key, string dataKey)
  277. {
  278. key = AddSysCustomKey(key);
  279. return Do(db =>
  280. {
  281. string value = db.HashGet(key, dataKey);
  282. return ConvertObj<T>(value);
  283. });
  284. }
  285. /// <summary>
  286. /// 为数字增长val
  287. /// </summary>
  288. /// <param name="key"></param>
  289. /// <param name="dataKey"></param>
  290. /// <param name="val">可以为负</param>
  291. /// <returns>增长后的值</returns>
  292. public double IncrementHash(string key, string dataKey, double val = 1)
  293. {
  294. key = AddSysCustomKey(key);
  295. return Do(db => db.HashIncrement(key, dataKey, val));
  296. }
  297. /// <summary>
  298. /// 为数字减少val
  299. /// </summary>
  300. /// <param name="key"></param>
  301. /// <param name="dataKey"></param>
  302. /// <param name="val">可以为负</param>
  303. /// <returns>减少后的值</returns>
  304. public double DecrementHash(string key, string dataKey, double val = 1)
  305. {
  306. key = AddSysCustomKey(key);
  307. return Do(db => db.HashDecrement(key, dataKey, val));
  308. }
  309. /// <summary>
  310. /// 获取hashkey所有Redis key
  311. /// </summary>
  312. /// <typeparam name="T"></typeparam>
  313. /// <param name="key"></param>
  314. /// <returns></returns>
  315. public List<T> KeysHash<T>(string key)
  316. {
  317. key = AddSysCustomKey(key);
  318. return Do(db =>
  319. {
  320. RedisValue[] values = db.HashKeys(key);
  321. return ConvetList<T>(values);
  322. });
  323. }
  324. #endregion 同步方法
  325. #region 异步方法
  326. /// <summary>
  327. /// 判断某个数据是否已经被缓存
  328. /// </summary>
  329. /// <param name="key"></param>
  330. /// <param name="dataKey"></param>
  331. /// <returns></returns>
  332. public async Task<bool> IsExistsAsyncHash(string key, string dataKey)
  333. {
  334. key = AddSysCustomKey(key);
  335. return await Do(db => db.HashExistsAsync(key, dataKey));
  336. }
  337. /// <summary>
  338. /// 存储数据到hash表
  339. /// </summary>
  340. /// <typeparam name="T"></typeparam>
  341. /// <param name="key"></param>
  342. /// <param name="dataKey"></param>
  343. /// <param name="t"></param>
  344. /// <returns></returns>
  345. public async Task<bool> SetAsyncHash<T>(string key, string dataKey, T t)
  346. {
  347. key = AddSysCustomKey(key);
  348. return await Do(db =>
  349. {
  350. string json = ConvertJson(t);
  351. return db.HashSetAsync(key, dataKey, json);
  352. });
  353. }
  354. /// <summary>
  355. /// 移除hash中的某值
  356. /// </summary>
  357. /// <param name="key"></param>
  358. /// <param name="dataKey"></param>
  359. /// <returns></returns>
  360. public async Task<bool> DeleteAsyncHash(string key, string dataKey)
  361. {
  362. key = AddSysCustomKey(key);
  363. return await Do(db => db.HashDeleteAsync(key, dataKey));
  364. }
  365. /// <summary>
  366. /// 移除hash中的多个值
  367. /// </summary>
  368. /// <param name="key"></param>
  369. /// <param name="dataKeys"></param>
  370. /// <returns></returns>
  371. public async Task<long> DeleteAsyncHash(string key, List<RedisValue> dataKeys)
  372. {
  373. key = AddSysCustomKey(key);
  374. //List<RedisValue> dataKeys1 = new List<RedisValue>() {"1","2"};
  375. return await Do(db => db.HashDeleteAsync(key, dataKeys.ToArray()));
  376. }
  377. /// <summary>
  378. /// 从hash表获取数据
  379. /// </summary>
  380. /// <typeparam name="T"></typeparam>
  381. /// <param name="key"></param>
  382. /// <param name="dataKey"></param>
  383. /// <returns></returns>
  384. public async Task<T> GeAsyncHash<T>(string key, string dataKey)
  385. {
  386. key = AddSysCustomKey(key);
  387. string value = await Do(db => db.HashGetAsync(key, dataKey));
  388. return ConvertObj<T>(value);
  389. }
  390. /// <summary>
  391. /// 为数字增长val
  392. /// </summary>
  393. /// <param name="key"></param>
  394. /// <param name="dataKey"></param>
  395. /// <param name="val">可以为负</param>
  396. /// <returns>增长后的值</returns>
  397. public async Task<double> IncrementAsyncHash(string key, string dataKey, double val = 1)
  398. {
  399. key = AddSysCustomKey(key);
  400. return await Do(db => db.HashIncrementAsync(key, dataKey, val));
  401. }
  402. /// <summary>
  403. /// 为数字减少val
  404. /// </summary>
  405. /// <param name="key"></param>
  406. /// <param name="dataKey"></param>
  407. /// <param name="val">可以为负</param>
  408. /// <returns>减少后的值</returns>
  409. public async Task<double> DecrementAsyncHash(string key, string dataKey, double val = 1)
  410. {
  411. key = AddSysCustomKey(key);
  412. return await Do(db => db.HashDecrementAsync(key, dataKey, val));
  413. }
  414. /// <summary>
  415. /// 获取hashkey所有Redis key
  416. /// </summary>
  417. /// <typeparam name="T"></typeparam>
  418. /// <param name="key"></param>
  419. /// <returns></returns>
  420. public async Task<List<T>> KeysAsyncHash<T>(string key)
  421. {
  422. key = AddSysCustomKey(key);
  423. RedisValue[] values = await Do(db => db.HashKeysAsync(key));
  424. return ConvetList<T>(values);
  425. }
  426. #endregion 异步方法
  427. #endregion Hash
  428. #region List
  429. #region 同步方法
  430. /// <summary>
  431. /// 移除指定ListId的内部List的值
  432. /// </summary>
  433. /// <param name="key"></param>
  434. /// <param name="value"></param>
  435. public void RemoveList<T>(string key, T value)
  436. {
  437. key = AddSysCustomKey(key);
  438. Do(db => db.ListRemove(key, ConvertJson(value)));
  439. }
  440. /// <summary>
  441. /// 获取指定key的List
  442. /// </summary>
  443. /// <param name="key"></param>
  444. /// <returns></returns>
  445. public List<T> ListRange<T>(string key)
  446. {
  447. key = AddSysCustomKey(key);
  448. return Do(redis =>
  449. {
  450. var values = redis.ListRange(key);
  451. return ConvetList<T>(values);
  452. });
  453. }
  454. /// <summary>
  455. /// 入队
  456. /// </summary>
  457. /// <param name="key"></param>
  458. /// <param name="value"></param>
  459. public void ListRightPush<T>(string key, T value)
  460. {
  461. key = AddSysCustomKey(key);
  462. Do(db => db.ListRightPush(key, ConvertJson(value)));
  463. }
  464. /// <summary>
  465. /// 出队
  466. /// </summary>
  467. /// <typeparam name="T"></typeparam>
  468. /// <param name="key"></param>
  469. /// <returns></returns>
  470. public T ListRightPop<T>(string key)
  471. {
  472. key = AddSysCustomKey(key);
  473. return Do(db =>
  474. {
  475. var value = db.ListRightPop(key);
  476. return ConvertObj<T>(value);
  477. });
  478. }
  479. /// <summary>
  480. /// 入栈
  481. /// </summary>
  482. /// <typeparam name="T"></typeparam>
  483. /// <param name="key"></param>
  484. /// <param name="value"></param>
  485. public void ListLeftPush<T>(string key, T value)
  486. {
  487. key = AddSysCustomKey(key);
  488. Do(db => db.ListLeftPush(key, ConvertJson(value)));
  489. }
  490. /// <summary>
  491. /// 出栈
  492. /// </summary>
  493. /// <typeparam name="T"></typeparam>
  494. /// <param name="key"></param>
  495. /// <returns></returns>
  496. public T ListLeftPop<T>(string key)
  497. {
  498. key = AddSysCustomKey(key);
  499. return Do(db =>
  500. {
  501. var value = db.ListLeftPop(key);
  502. return ConvertObj<T>(value);
  503. });
  504. }
  505. /// <summary>
  506. /// 获取集合中的数量
  507. /// </summary>
  508. /// <param name="key"></param>
  509. /// <returns></returns>
  510. public long ListLength(string key)
  511. {
  512. key = AddSysCustomKey(key);
  513. return Do(redis => redis.ListLength(key));
  514. }
  515. #endregion 同步方法
  516. #region 异步方法
  517. /// <summary>
  518. /// 移除指定ListId的内部List的值
  519. /// </summary>
  520. /// <param name="key"></param>
  521. /// <param name="value"></param>
  522. public async Task<long> ListRemoveAsync<T>(string key, T value)
  523. {
  524. key = AddSysCustomKey(key);
  525. return await Do(db => db.ListRemoveAsync(key, ConvertJson(value)));
  526. }
  527. /// <summary>
  528. /// 获取指定key的List
  529. /// </summary>
  530. /// <param name="key"></param>
  531. /// <returns></returns>
  532. public async Task<List<T>> ListRangeAsync<T>(string key)
  533. {
  534. key = AddSysCustomKey(key);
  535. var values = await Do(redis => redis.ListRangeAsync(key));
  536. return ConvetList<T>(values);
  537. }
  538. /// <summary>
  539. /// 入队
  540. /// </summary>
  541. /// <param name="key"></param>
  542. /// <param name="value"></param>
  543. public async Task<long> ListRightPushAsync<T>(string key, T value)
  544. {
  545. key = AddSysCustomKey(key);
  546. return await Do(db => db.ListRightPushAsync(key, ConvertJson(value)));
  547. }
  548. /// <summary>
  549. /// 出队
  550. /// </summary>
  551. /// <typeparam name="T"></typeparam>
  552. /// <param name="key"></param>
  553. /// <returns></returns>
  554. public async Task<T> ListRightPopAsync<T>(string key)
  555. {
  556. key = AddSysCustomKey(key);
  557. var value = await Do(db => db.ListRightPopAsync(key));
  558. return ConvertObj<T>(value);
  559. }
  560. /// <summary>
  561. /// 入栈
  562. /// </summary>
  563. /// <typeparam name="T"></typeparam>
  564. /// <param name="key"></param>
  565. /// <param name="value"></param>
  566. public async Task<long> ListLeftPushAsync<T>(string key, T value)
  567. {
  568. key = AddSysCustomKey(key);
  569. return await Do(db => db.ListLeftPushAsync(key, ConvertJson(value)));
  570. }
  571. /// <summary>
  572. /// 出栈
  573. /// </summary>
  574. /// <typeparam name="T"></typeparam>
  575. /// <param name="key"></param>
  576. /// <returns></returns>
  577. public async Task<T> ListLeftPopAsync<T>(string key)
  578. {
  579. key = AddSysCustomKey(key);
  580. var value = await Do(db => db.ListLeftPopAsync(key));
  581. return ConvertObj<T>(value);
  582. }
  583. /// <summary>
  584. /// 获取集合中的数量
  585. /// </summary>
  586. /// <param name="key"></param>
  587. /// <returns></returns>
  588. public async Task<long> ListLengthAsync(string key)
  589. {
  590. key = AddSysCustomKey(key);
  591. return await Do(redis => redis.ListLengthAsync(key));
  592. }
  593. #endregion 异步方法
  594. #endregion List
  595. #region SortedSet 有序集合
  596. #region 同步方法
  597. /// <summary>
  598. /// 添加
  599. /// </summary>
  600. /// <param name="key"></param>
  601. /// <param name="value"></param>
  602. /// <param name="score"></param>
  603. public bool SortedSetAdd<T>(string key, T value, double score)
  604. {
  605. key = AddSysCustomKey(key);
  606. return Do(redis => redis.SortedSetAdd(key, ConvertJson<T>(value), score));
  607. }
  608. /// <summary>
  609. /// 删除
  610. /// </summary>
  611. /// <param name="key"></param>
  612. /// <param name="value"></param>
  613. public bool SortedSetRemove<T>(string key, T value)
  614. {
  615. key = AddSysCustomKey(key);
  616. return Do(redis => redis.SortedSetRemove(key, ConvertJson(value)));
  617. }
  618. /// <summary>
  619. /// 获取全部
  620. /// </summary>
  621. /// <param name="key"></param>
  622. /// <returns></returns>
  623. public List<T> SortedSetRangeByRank<T>(string key)
  624. {
  625. key = AddSysCustomKey(key);
  626. return Do(redis =>
  627. {
  628. var values = redis.SortedSetRangeByRank(key);
  629. return ConvetList<T>(values);
  630. });
  631. }
  632. /// <summary>
  633. /// 获取集合中的数量
  634. /// </summary>
  635. /// <param name="key"></param>
  636. /// <returns></returns>
  637. public long SortedSetLength(string key)
  638. {
  639. key = AddSysCustomKey(key);
  640. return Do(redis => redis.SortedSetLength(key));
  641. }
  642. #endregion 同步方法
  643. #region 异步方法
  644. /// <summary>
  645. /// 添加
  646. /// </summary>
  647. /// <param name="key"></param>
  648. /// <param name="value"></param>
  649. /// <param name="score"></param>
  650. public async Task<bool> SortedSetAddAsync<T>(string key, T value, double score)
  651. {
  652. key = AddSysCustomKey(key);
  653. return await Do(redis => redis.SortedSetAddAsync(key, ConvertJson<T>(value), score));
  654. }
  655. /// <summary>
  656. /// 删除
  657. /// </summary>
  658. /// <param name="key"></param>
  659. /// <param name="value"></param>
  660. public async Task<bool> SortedSetRemoveAsync<T>(string key, T value)
  661. {
  662. key = AddSysCustomKey(key);
  663. return await Do(redis => redis.SortedSetRemoveAsync(key, ConvertJson(value)));
  664. }
  665. /// <summary>
  666. /// 获取全部
  667. /// </summary>
  668. /// <param name="key"></param>
  669. /// <returns></returns>
  670. public async Task<List<T>> SortedSetRangeByRankAsync<T>(string key)
  671. {
  672. key = AddSysCustomKey(key);
  673. var values = await Do(redis => redis.SortedSetRangeByRankAsync(key));
  674. return ConvetList<T>(values);
  675. }
  676. /// <summary>
  677. /// 获取集合中的数量
  678. /// </summary>
  679. /// <param name="key"></param>
  680. /// <returns></returns>
  681. public async Task<long> SortedSetLengthAsync(string key)
  682. {
  683. key = AddSysCustomKey(key);
  684. return await Do(redis => redis.SortedSetLengthAsync(key));
  685. }
  686. #endregion 异步方法
  687. #endregion SortedSet 有序集合
  688. #region key
  689. /// <summary>
  690. /// 删除单个key
  691. /// </summary>
  692. /// <param name="key">redis key</param>
  693. /// <returns>是否删除成功</returns>
  694. public bool KeyDelete(string key)
  695. {
  696. key = AddSysCustomKey(key);
  697. return Do(db => db.KeyDelete(key));
  698. }
  699. /// <summary>
  700. /// 删除多个key
  701. /// </summary>
  702. /// <param name="keys">rediskey</param>
  703. /// <returns>成功删除的个数</returns>
  704. public long KeyDelete(List<string> keys)
  705. {
  706. List<string> newKeys = keys.Select(AddSysCustomKey).ToList();
  707. return Do(db => db.KeyDelete(ConvertRedisKeys(newKeys)));
  708. }
  709. /// <summary>
  710. /// 判断key是否存储
  711. /// </summary>
  712. /// <param name="key">redis key</param>
  713. /// <returns></returns>
  714. public bool KeyExists(string key)
  715. {
  716. key = AddSysCustomKey(key);
  717. return Do(db => db.KeyExists(key));
  718. }
  719. /// <summary>
  720. /// 重新命名key
  721. /// </summary>
  722. /// <param name="key">就的redis key</param>
  723. /// <param name="newKey">新的redis key</param>
  724. /// <returns></returns>
  725. public bool KeyRename(string key, string newKey)
  726. {
  727. key = AddSysCustomKey(key);
  728. return Do(db => db.KeyRename(key, newKey));
  729. }
  730. /// <summary>
  731. /// 设置Key的时间
  732. /// </summary>
  733. /// <param name="key">redis key</param>
  734. /// <param name="expiry"></param>
  735. /// <returns></returns>
  736. public bool KeyExpire(string key, TimeSpan? expiry = default(TimeSpan?))
  737. {
  738. key = AddSysCustomKey(key);
  739. return Do(db => db.KeyExpire(key, expiry));
  740. }
  741. #endregion key
  742. #region 发布订阅
  743. /// <summary>
  744. /// Redis发布订阅 订阅
  745. /// </summary>
  746. /// <param name="subChannel"></param>
  747. /// <param name="handler"></param>
  748. public void Subscribe(string subChannel, Action<RedisChannel, RedisValue> handler = null)
  749. {
  750. ISubscriber sub = _conn.GetSubscriber();
  751. sub.Subscribe(subChannel, (channel, message) =>
  752. {
  753. if (handler == null)
  754. {
  755. Console.WriteLine(subChannel + " 订阅收到消息:" + message);
  756. }
  757. else
  758. {
  759. handler(channel, message);
  760. }
  761. });
  762. }
  763. /// <summary>
  764. /// Redis发布订阅 发布
  765. /// </summary>
  766. /// <typeparam name="T"></typeparam>
  767. /// <param name="channel"></param>
  768. /// <param name="msg"></param>
  769. /// <returns></returns>
  770. public long Publish<T>(string channel, T msg)
  771. {
  772. ISubscriber sub = _conn.GetSubscriber();
  773. return sub.Publish(channel, ConvertJson(msg));
  774. }
  775. /// <summary>
  776. /// Redis发布订阅 取消订阅
  777. /// </summary>
  778. /// <param name="channel"></param>
  779. public void Unsubscribe(string channel)
  780. {
  781. ISubscriber sub = _conn.GetSubscriber();
  782. sub.Unsubscribe(channel);
  783. }
  784. /// <summary>
  785. /// Redis发布订阅 取消全部订阅
  786. /// </summary>
  787. public void UnsubscribeAll()
  788. {
  789. ISubscriber sub = _conn.GetSubscriber();
  790. sub.UnsubscribeAll();
  791. }
  792. #endregion 发布订阅
  793. #region 其他
  794. public ITransaction CreateTransaction()
  795. {
  796. return GetDatabase().CreateTransaction();
  797. }
  798. public IDatabase GetDatabase()
  799. {
  800. return _conn.GetDatabase(DbNum);
  801. }
  802. public IServer GetServer(string hostAndPort)
  803. {
  804. return _conn.GetServer(hostAndPort);
  805. }
  806. /// <summary>
  807. /// 设置前缀
  808. /// </summary>
  809. /// <param name="customKey"></param>
  810. public void SetSysCustomKey(string customKey)
  811. {
  812. CustomKey = customKey;
  813. }
  814. #endregion 其他
  815. #region 辅助方法
  816. private string AddSysCustomKey(string oldKey)
  817. {
  818. var prefixKey = CustomKey ?? RedisConnection.SysCustomKey;
  819. return prefixKey + oldKey;
  820. }
  821. private T Do<T>(Func<IDatabase, T> func)
  822. {
  823. var database = _conn.GetDatabase(DbNum);
  824. return func(database);
  825. }
  826. private string ConvertJson<T>(T value)
  827. {
  828. string result = value is string ? value.ToString() : JsonConvert.SerializeObject(value);
  829. return result;
  830. }
  831. private T ConvertObj<T>(RedisValue value)
  832. {
  833. return JsonConvert.DeserializeObject<T>(value);
  834. }
  835. private List<T> ConvetList<T>(RedisValue[] values)
  836. {
  837. List<T> result = new List<T>();
  838. foreach (var item in values)
  839. {
  840. var model = ConvertObj<T>(item);
  841. result.Add(model);
  842. }
  843. return result;
  844. }
  845. private RedisKey[] ConvertRedisKeys(List<string> redisKeys)
  846. {
  847. return redisKeys.Select(redisKey => (RedisKey)redisKey).ToArray();
  848. }
  849. #endregion 辅助方法
  850. }
  851. }