.NET中Redis安装部署及使用方法
Redis是一个用的比较广泛的Key/Value的内存数据库,新浪微博、Github、StackOverflow 等大型应用中都用其作为缓存,Redis的官网为http://redis.io/。
Redis 是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、 list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是 原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性 的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object- C,Python,Ruby,Erlang等客户端,使用很方便。
Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步, 从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。存盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使 得从数据库在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。
在这篇文章中我们将记录一下Redis的安装,以及如何在.NET中使用Redis。
工具下载位置:http://pan.baidu.com/s/1jILIzLs,包括服务端配置以及查看缓存的工具。
一、Redis服务端以服务方式运行
服务端是以服务的形式运行,将Redis服务端解压到某个目录,然后以管理员方式运行cmd执行命令进行安装:
redis-server.exe --service-install redis.windows.conf --loglevel verbose
注意卸载服务的命令为:
redis-server.exe --service-uninstall redis.windows.conf --loglevel verbose
注意事项,修改Redis端口及密码的配置在文件redis.windows-service.conf中:(使用redis284.rar中解压文件)
修改端口,压缩文件中配置的是6488:
修改密码
修改库的数量
配置完成后,执行
redis-server.exe --service-install redis.windows.conf --loglevel verbose
到控制面板查看服务已经安装成功了,注意首次安装时默认没有启动,单击启动即可。
工具配置,安装后如下图
连接成功后,就可以查看缓存中的数据了
二、Redis服务端以控制台方式运行
解压下载的redis64-2.6.12.1.rar文件,如下图:
第一步(配置本地服务)
第二部(安装和配置客户端)
文件中的“redis-desktop-manager-0.8.2.3849.exe“是2015-11-23 从Redis的官网下载的客户端安装包,如果有更新可以去官网下载最新的Redis,这是链接:http://redis.io/
1.点击客户端安装程序,下一步....,完成打开客户端界面就可以了,省略安装截图。
2.打开界面,客户端默认读取到6379的端口,会创建一个6379的Redis服务器
由于我更改了6379的端口号,导致Redis客户端默认创建的localhost服务器启动不成功,这里只需要右击修改一下端口号就可以了。
三、C#访问Redis
下载ServiceStack.Redis
和MongoDB一样,在.NET中使用Redis其实也是使用第三方驱动,官网推荐的是使用ServiceStack.Redis 下载后解压得到如下dll
.NET项目中使用Redis
ServerStack中有很多方法可以在.NET中调用,其类结构图如下:
Redis公共类库参考
using System;
using System.Collections.Generic;
using System.Linq;namespace RDIFramework.Utilities
{using ServiceStack.Redis;using ServiceStack.Redis.Generic;/// <summary>/// Redis公共辅助类库/// </summary>public class RedisHelper : IDisposable{public RedisClient Redis = new RedisClient("127.0.0.1", 6379);//缓存池PooledRedisClientManager prcm = new PooledRedisClientManager();//默认缓存过期时间单位秒public int secondsTimeOut = 30 * 60;/// <summary>/// 缓冲池/// </summary>/// <param name="readWriteHosts"></param>/// <param name="readOnlyHosts"></param>/// <returns></returns>public static PooledRedisClientManager CreateManager(string[] readWriteHosts, string[] readOnlyHosts){return new PooledRedisClientManager(readWriteHosts, readOnlyHosts,new RedisClientManagerConfig{MaxWritePoolSize = readWriteHosts.Length * 5,MaxReadPoolSize = readOnlyHosts.Length * 5,AutoStart = true,});// { RedisClientFactory = (IRedisClientFactory)RedisCacheClientFactory.Instance.CreateRedisClient("127.0.0.1", 6379) }; }/// <summary>/// 构造函数/// </summary>/// <param name="openPooledRedis">是否开启缓冲池</param>public RedisHelper(bool openPooledRedis = false){if (openPooledRedis){prcm = CreateManager(new string[] { "127.0.0.1:6379" }, new string[] { "127.0.0.1:6379" });Redis = prcm.GetClient() as RedisClient;}}#region Key/Value存储/// <summary>/// 设置缓存/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key">缓存建</param>/// <param name="t">缓存值</param>/// <param name="timeout">过期时间,单位秒,-1:不过期,0:默认过期时间</param>/// <returns></returns>public bool Set<T>(string key, T t, int timeout = 0){if (timeout >= 0){if (timeout > 0){secondsTimeOut = timeout;}Redis.Expire(key, secondsTimeOut);}return Redis.Add<T>(key, t);}/// <summary>/// 获取/// </summary>/// <typeparam name="T"></typeparam>/// <param name="key"></param>/// <returns></returns>public T Get<T>(string key){return Redis.Get<T>(key);}/// <summary>/// 删除/// </summary>/// <param name="key"></param>/// <returns></returns>public bool Remove(string key){return Redis.Remove(key);}public bool Add<T>(string key, T t, int timeout){if (timeout >= 0){if (timeout > 0){secondsTimeOut = timeout;}Redis.Expire(key, secondsTimeOut);}return Redis.Add<T>(key, t);}#endregion#region 链表操作/// <summary>/// 根据IEnumerable数据添加链表/// </summary>/// <typeparam name="T"></typeparam>/// <param name="listId"></param>/// <param name="values"></param>/// <param name="timeout"></param>public void AddList<T>(string listId, IEnumerable<T> values, int timeout = 0){Redis.Expire(listId, 60);IRedisTypedClient<T> iredisClient = Redis.As<T>();if (timeout >= 0){if (timeout > 0){secondsTimeOut = timeout;}Redis.Expire(listId, secondsTimeOut);}var redisList = iredisClient.Lists[listId];redisList.AddRange(values);iredisClient.Save();}/// <summary>/// 添加单个实体到链表中/// </summary>/// <typeparam name="T"></typeparam>/// <param name="listId"></param>/// <param name="Item"></param>/// <param name="timeout"></param>public void AddEntityToList<T>(string listId, T Item, int timeout = 0){IRedisTypedClient<T> iredisClient = Redis.As<T>();if (timeout >= 0){if (timeout > 0){secondsTimeOut = timeout;}Redis.Expire(listId, secondsTimeOut);}var redisList = iredisClient.Lists[listId];redisList.Add(Item);iredisClient.Save();}/// <summary>/// 获取链表/// </summary>/// <typeparam name="T"></typeparam>/// <param name="listId"></param>/// <returns></returns>public IEnumerable<T> GetList<T>(string listId){IRedisTypedClient<T> iredisClient = Redis.As<T>();return iredisClient.Lists[listId];}/// <summary>/// 在链表中删除单个实体/// </summary>/// <typeparam name="T"></typeparam>/// <param name="listId"></param>/// <param name="t"></param>public void RemoveEntityFromList<T>(string listId, T t){IRedisTypedClient<T> iredisClient = Redis.As<T>();var redisList = iredisClient.Lists[listId];redisList.RemoveValue(t);iredisClient.Save();}/// <summary>/// 根据lambada表达式删除符合条件的实体/// </summary>/// <typeparam name="T"></typeparam>/// <param name="listId"></param>/// <param name="func"></param>public void RemoveEntityFromList<T>(string listId, Func<T, bool> func){using (IRedisTypedClient<T> iredisClient = Redis.As<T>()){var redisList = iredisClient.Lists[listId];T value = redisList.Where(func).FirstOrDefault();redisList.RemoveValue(value);iredisClient.Save();}}#endregion//释放资源public void Dispose(){if (Redis != null){Redis.Dispose();Redis = null;}GC.Collect();}}
}
转载于:https://www.cnblogs.com/wolaiye320/p/5663546.html
.NET中Redis安装部署及使用方法相关推荐
- .NET中Redis安装部署及使用方法简介附-开源Redis操作辅助类
Redis是一个用的比较广泛的Key/Value的内存数据库,新浪微博.Github.StackOverflow 等大型应用中都用其作为缓存,Redis的官网为http://redis.io/. Re ...
- Redis安装部署配置说明
1. redis简介 Redis是个高性能的key-value数据库,它的key具有丰富的数据结构:string,hash,list set和sorted set.作为NOSQL,比 ...
- Redis 安装部署介绍
Redis 安装部署 •单点 •主从复制Replication •高可用 Sentinel •集群Cluster Redis Standalone 1:官方站点: https://redis.io下载 ...
- 所有类型的Redis安装部署
所有类型的Redis安装部署 1.虚机安装单台redis A.下载包 ● 官网下载网页链接:https://redis.io/download wget https://github.com/redi ...
- php redis 删除key 通配符,php中redis批量删除key的方法是什么
php中redis批量删除key的方法是什么 发布时间:2020-08-28 14:42:05 来源:亿速云 阅读:159 作者:小新 小编给大家分享一下php中redis批量删除key的方法是什么, ...
- tomcat中三种部署项目的方法(转)
tomcat中三种部署项目的方法 第一种方法:在tomcat中的conf目录中,在server.xml中的,<host/>节点中添加: <Context path="/h ...
- SVN在Eclipse中的安装步骤以及使用方法和建立分支
SVN在Eclipse中的安装步骤以及使用方法和建立分支 一. 前提描述 在开发项目的过程中难免会遇到版本的不同步开发,其中某个版本会用来修改bug,另外的版本用来开发新的功能.这便是我写这个文档的一 ...
- Redis 安装部署教程
Redis 安装部署教程 通过https://github.com/tporadowski/redis/releases 地址下载Redis-x64-5.0.14.1.msi文件 下载完成,解压,双击 ...
- NoSQLRedis的介绍和Redis安装部署,通过yum在线安装Redis,通过源码安装Redis;
目录 1.Redis简介 1).Redis是什么? 2).Redis能干嘛? 3).可以从哪里去下载Redis? 4).使用Redis进行的多种操作 5).Redis与其他数据库和软件的对比 2.Re ...
最新文章
- hue集成hbase出现TSocket read 0 bytes
- java判断星期天_java实现一个月的最后一个星期天
- 隐藏JqueryMobile中的Header与Footer
- jeesite1.X 集成多数据源
- VS2010 C++下编译调试MongoDB“.NET研究”源码
- 小程序功能模块-在线考试2.10.3源码
- 用Python给你的女神带上口罩~
- 电子邮件地址抓取工具
- Gartner发布2011十大关键技术
- python数据包pandas_python | 数据分析(二)- Pandas数据包
- [奶奶看了都会]京东自动签到薅羊毛-完整教程
- 产品经理必备 [Axure组件、PRD模板、竞品分析、数据分析等模板]
- 大数据 与 云计算 的关系
- 第20节 信息化基础知识
- 一元三次方程c语言程序,求解一元三次方程近似解的几种算法(C语言)
- VSCode配置git图文
- 电脑蓝屏代码0x0000007E,技术信息iUSBXCH.sys
- PHP - AES 加密解密
- 纯HTML编写仿淘宝粉丝福利购页面-优惠券、商品列表、图片悬浮等布局
- python爬虫爬取今日头条_python 简单爬取今日头条热点新闻(一)
热门文章
- Linux下svn 安装搭建配置流程
- 面试题40. 最小的k个数
- python网格搜索法_Python中基于网格搜索算法优化的深度学习模型分析糖尿病数据...
- python搭建邮件服务器地址_python 配置邮件发送服务器发送邮件
- Beeple最大藏家Metapurse拍卖B.20项目中所有NFT资产,底价5800万美元
- 以太坊2.0合约余额新增3872 ETH
- Coinlist将在4月1日到3日举行Rally(RLY)代币销售
- TokenInsight:反映区块链行业整体表现的TI指数较昨日同期下跌5.04%
- 今日恐慌与贪婪指数为93 贪婪程度有所缓解
- SAP License:SAP的2021关键词:协作