[Open Source] .NET 基于StackExchange.Redis的扩展
目录
简介
主从复制
备份与恢复
- API
- AddOrUpdate
- GetOrAdd
- DeleteByPattern
- SearchKeys
- TransExcute
- Subscribe/Publish
- Todo
- Sentinel
- .NET Core
- Configuration
- Log
- Async
简介
- Redis.Extension GitHub(欢迎Fork Star)
Redis.Extension nuget(Install-Package Redis.Extension)
- Redis 开源的分布式NoSQL,c语言开发,存储结构:key-value
- 持久化(容灾)
- snapshot(快照)
- Redis默认持久化方式,每次保存RDB的时候,fork()出1个子进程进行持久化
- dump.rdb
- 配置n秒超过m个key 开始快照
- 性能高,丢失数据比较多
- Append-only file(aof)
- 新命令到达则fsync一次,文件足够大的时候,rewrite一次。
- appendfilename "appendonly.aof" 设置存储文件
- appendfsync 设置频率
- auto-aof-rewrite 设置自动重写
- 性能稍慢,丢失数据非常少
- snapshot(快照)
5种数据类型:string,list(链表),hash(哈希),set(集合),zset(排序集合)
安装
- Windows
- 管理多个服务实例
- redis-server.exe --service-install redis.windows-service --service-name Redis --port 6369
- sc delete Redis
- 直接启动
- redis-server.exe redis.windows.conf
- 管理多个服务实例
- Linux
- 源码包
- docker
- Mac
- brew
- docker
主从复制
- 过程
- 当设置好slave服务器后,slave会建立和master的连接,然后发送sync命令。
- 无论是第一次同步建立的连接还是连接断开后的重新连接,master都会启动一个后台进程,将数据库快照保存到文件中,同时master主进程会开始收集新的写命令并缓存起来。
- 后台进程完成写文件后,master就发送文件给slave,slave将文件保存到磁盘上,然后加载到内存恢复数据库快照到slave上。
- 接着master就会把缓存的命令转发给slave。
- 而且后续master收到的写命令都会通过开始建立的连接发送给slave。
- 从master到slave的同步数据的命令和从client发送的命令使用相同的协议格式。
- 当master和slave的连接断开时slave可以自动重新建立连接。
- 如果master同时收到多个slave发来的同步连接命令,只会使用启动一个进程来写数据库镜像,然后发送给所有slave。
- 配置
- slaveof 127.0.0.1 6379
API
- 具体的API调用可以 可以直接参考ManagerTest。
- AddOrUpdate 支持指定具体时间点 缓存失效
- AddOrUpdate 支持指定具体时间点 缓存失效
- GetOrAdd 支持检测缓存 再读库操作
- DeleteByPattern 支持根据key模糊删除
- SearchKeys 支持查询Keys
- TransExcute 支持Redis事务执行
- Subscribe 支持快速订阅消息
- Publish 支持快速发布消息
备份与恢复
appendfilename "appendonly.aof"
snapshot "dump.rdb"
使用
- string: set | get
- hash: hmset | hgetall
- list: lpush | lrange
- set: sadd | smembers
- zset: zadd | zrange
- save bgsave
- subscribe publish
- keys *
- info
[Open Source] .NET 基于StackExchange.Redis的扩展的更多相关文章
- 在.Net下使用redis基于StackExchange.Redis
研究了下redis在.net下的使用,因为以前在java上用redis用的是jedis操作,在.net不是很熟悉,在网站上也看了一部分的.net下redis的使用,大部分都是ServiceStack. ...
- .net core 使用redis 基于 StackExchange.Redis
一.添加引用包 StackExchange.Redis Microsoft.Extensions.Configuration 二.修改配置文件 appsettings.json { " ...
- 扩展 StackExchange.Redis 支持实体
一.StackExchange.Redis StackExchange.Redis是由Stack Overflow开发的C#语言Redis客户端,使用广泛,本文针对 StackExchange.Red ...
- redis的安装、启动、主从配置,以及.Net下StackExchange.Redis的使用
开门见山,Linux下配个环境真是苦逼死了,这里记录一下,囧 一.环境 服务端:Ubuntu16.04 LTS(虚拟机,redis官方没有window发布版本,而且在Linux下运行更稳定) 客户端: ...
- 在.Net下使用redis基于StackExchange.Redis--登录功能
研究了下redis在.net下的使用,因为以前在java上用redis用的是jedis操作,在.net不是很熟悉,在网站上也看了一部分的.net下redis的使用,大部分都是ServiceStack. ...
- Redis集群~StackExchange.redis连接Twemproxy代理服务器
回到目录 本文是Redis集群系列的一篇文章,主要介绍使用StackExchange.Redis进行Twemproxy(文中简称TW)代理服务的连接过程,事务上,对于TW来说,我们需要理解一下它的物理 ...
- [开源精品] .NET Redis Client 又多了一个选择,还在被 StackExchange.Redis Timeout 问题困扰吗?
前言 .NET 下 RedisClient SDK 选择挺多,国人常用免费的有 StackExchange.Redis/CSRedis/Newlife.Redis,收费的有 ServiceStack. ...
- Windows下Redis缓存服务器的使用 .NET StackExchange.Redis Redis Desktop Manager
Redis缓存服务器是一款key/value数据库,读110000次/s,写81000次/s,因为是内存操作所以速度飞快,常见用法是存用户token.短信验证码等 官网显示Redis本身并没有Wind ...
- Redis 详解 (一) StackExchange.Redis Client
这期我们来看StackExchange.Redis,这是redis 的.net客户端之一.Redis是一个开源的内存数据存储,可以用来做数据库,缓存或者消息代理服务.目前有不少人在使用ServiceS ...
随机推荐
- DDD理论学习系列(6)-- 实体
DDD理论学习系列--案例及目录 1.引言 实体对应的英语单词为Entity.提到实体,你可能立马就想到了代码中定义的实体类.在使用一些ORM框架时,比如Entity Framework,实体作为直接 ...
- python编码问题大终结
一.了解字符编码的知识储备 1. 文本编辑器存取文件的原理(nodepad++,pycharm,word) 打开编辑器就打开了启动了一个进程,是在内存中的,所以在编辑器编写的内容也都是存放与内存中的, ...
- (转)关于 Java 对象序列化您不知道的 5 件事
关于 Java 对象序列化您不知道的 5 件事 转自:http://developer.51cto.com/art/201506/479979.htm 数年前,当和一个软件团队一起用 Java 语言编 ...
- Windows 7安装Oracle 10g的方法
Windows7下安装Oracle 10g提示"程序异常终止,发生未知错误"的解决方法 1.修改Oracle 10G\database\stage\prereq\db\refhos ...
- 去除MyEclipse频繁弹出的Update Progress窗口
方法1: 1.关闭updating index Window => Preferences => Myeclipse Enterprise Workbench => Maven4My ...
- MVC中控制器当中需要绑定SelectList,也就是所谓的DropDownList
ViewData["moduleList"] = new SelectList(new El_Basic_ModuleInfo().Rows().AsEnumerable(), & ...
- 摘抄自知乎的redis相关
1.知乎日报的基础数据和统计信息是用 Redis 存储的,这使得请求的平均响应时间能在 10ms 以下.其他数据仍然需要存放在另外的地方,其实完全用 Redis 也是可行的,主要的考量是内存占用.就使 ...
- jenkins跑maven项目的时候报错,看评论
Started by user admin Building in workspace /var/jenkins_home/workspace/helloworld [WS-CLEANUP] Dele ...
- Testlink安装步骤Checking if C:\inetpub\wwwroot\testlink-1.9.3\gui\templates_c directory is writable Failed !
Testlink安装过程中问题现象: Checking if C:\inetpub\wwwroot\testlink-1.9.3\gui\templates_c directory is writab ...
- 无法为具有固定名称“MySql.Data.MySqlClient”的 ADO.NET 提供程序加载在应用程序配置文件中注册的实体框架提供程序类型“MySql.Data.MySqlClient.MySqlProviderServices,MySql.Data.Entity.EF6”
"System.InvalidOperationException"类型的未经处理的异常在 mscorlib.dll 中发生 其他信息: 无法为具有固定名称"MySql. ...