目录

  • 简介

  • 主从复制

  • 备份与恢复

  • 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 设置自动重写
      • 性能稍慢,丢失数据非常少
  • 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的扩展的更多相关文章

  1. 在.Net下使用redis基于StackExchange.Redis

    研究了下redis在.net下的使用,因为以前在java上用redis用的是jedis操作,在.net不是很熟悉,在网站上也看了一部分的.net下redis的使用,大部分都是ServiceStack. ...

  2. .net core 使用redis 基于 StackExchange.Redis

    一.添加引用包 StackExchange.Redis Microsoft.Extensions.Configuration   二.修改配置文件 appsettings.json   { " ...

  3. 扩展 StackExchange.Redis 支持实体

    一.StackExchange.Redis StackExchange.Redis是由Stack Overflow开发的C#语言Redis客户端,使用广泛,本文针对 StackExchange.Red ...

  4. redis的安装、启动、主从配置,以及.Net下StackExchange.Redis的使用

    开门见山,Linux下配个环境真是苦逼死了,这里记录一下,囧 一.环境 服务端:Ubuntu16.04 LTS(虚拟机,redis官方没有window发布版本,而且在Linux下运行更稳定) 客户端: ...

  5. 在.Net下使用redis基于StackExchange.Redis--登录功能

    研究了下redis在.net下的使用,因为以前在java上用redis用的是jedis操作,在.net不是很熟悉,在网站上也看了一部分的.net下redis的使用,大部分都是ServiceStack. ...

  6. Redis集群~StackExchange.redis连接Twemproxy代理服务器

    回到目录 本文是Redis集群系列的一篇文章,主要介绍使用StackExchange.Redis进行Twemproxy(文中简称TW)代理服务的连接过程,事务上,对于TW来说,我们需要理解一下它的物理 ...

  7. [开源精品] .NET Redis Client 又多了一个选择,还在被 StackExchange.Redis Timeout 问题困扰吗?

    前言 .NET 下 RedisClient SDK 选择挺多,国人常用免费的有 StackExchange.Redis/CSRedis/Newlife.Redis,收费的有 ServiceStack. ...

  8. Windows下Redis缓存服务器的使用 .NET StackExchange.Redis Redis Desktop Manager

    Redis缓存服务器是一款key/value数据库,读110000次/s,写81000次/s,因为是内存操作所以速度飞快,常见用法是存用户token.短信验证码等 官网显示Redis本身并没有Wind ...

  9. Redis 详解 (一) StackExchange.Redis Client

    这期我们来看StackExchange.Redis,这是redis 的.net客户端之一.Redis是一个开源的内存数据存储,可以用来做数据库,缓存或者消息代理服务.目前有不少人在使用ServiceS ...

随机推荐

  1. 微信小程序多张图片上传

    微信小程序上传图片每次只能上传一张,所有很多朋友就会问想要多张图片上传怎么办? 首先,我们来看一看wx.chooseImage(object)和wx.uploadFile(OBJECT)这两个个api ...

  2. 官方 React 快速上手脚手架 create-react-app

    此文简单讲解了官方 React 快速上手脚手架的安装与介绍. 1. React 快速上手脚手架 create-react-app 为了快速地进行构建使用 React 的项目,FaceBook 官方发布 ...

  3. 遇到bug我会怎么做

    我今天遇到一个问题,ztree显示数据,本来这个功能是没有问题的,但是当我新加入了几个页面筛选条件时,将集合传入ztree ,页面缺一直没显示出来,弄了两个小时,代码我都仔细排查了一次,发现没有问题, ...

  4. os模块学习小随笔

    os模块为python解释器与操作系统交互的接口 os.popen()   -------Open a pipe to or from command. The return value is an ...

  5. solr学习笔记-开篇

    由于工作需要,近期接触了一下全文检索的相关技术,从lucenen到solr开始慢慢一路摸爬滚打,仅以此文记录自己的学习里程和记录下各种坑. 本次学习基于以下环境版本: java7,solr5.5.4( ...

  6. Mysql数据库存储emoji表情

    emoji表情需要使用编码格式未utf8mb4,mysql数据库版本要5.5以上,我用的是5.6,因为只有5.5以上支持utf8mb4. 1.数据库编码设定为utf8mb4,如果建库时指定的是utf8 ...

  7. 【MFC】利用双缓冲和随机函数rand()实现蒲公英飞舞

    原始日期:2014-05-29 22:44 这几天有些懒,几乎没怎么学MFC了,好容易有个题目:用双缓冲实现蒲公英飞舞,想来想去也没想到好方法,索性动手开始 写了 ,这一写,得,出来了,呵呵,无意中产 ...

  8. IT学习网站

    网站 网站定位 http://www.51cto.com/ 中国领先的IT技术网站. http://www.iteye.com/ 内容齐全,功能丰富的中文IT技术门户和社区网站. http://www ...

  9. 如何离线安装Visual Studio 2017

    1. 官方下载在线安装文件 vs_community.exe https://www.visualstudio.com/zh-hans/thank-you-downloading-visual-stu ...

  10. Petya勒索病毒疫苗出现,分分钟让电脑对病毒免疫

    继wannacry之后,Petya勒索软件攻击再次席卷全球,对欧洲.俄罗斯等多国政府.银行.电力系统.通讯系统.企业以及机场造成了不同程度的影响. 研究发现,Petya 会锁定磁盘的 MFT 和 MB ...