RedisHelpers.cs 34 KB

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