Redis in .NET Core 入门:(1) 安装和主要功能简介

时间:2022-09-21 21:47:56

Redis(https://redis.io/), 是一个内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。

安装Redis

我很少在开发机中直接装各种数据库,我一般使用Docker,针对Redis也不例外,我还是使用Docker。

这是Redis在DockerHub里的地址:https://hub.docker.com/_/redis,里面有文档。

启动docker,下载redis镜像:docker pull redis

Redis in .NET Core 入门:(1) 安装和主要功能简介

然后运行镜像并发布端口6379:

Redis in .NET Core 入门:(1) 安装和主要功能简介

然后运行redis-cli(这是Redis的一个命令行管理工具):

Redis in .NET Core 入门:(1) 安装和主要功能简介

进入redis-cli之后,我们可以设置一个key-value来试试:

Redis in .NET Core 入门:(1) 安装和主要功能简介

当你输入的时候,它是有提示的。

Redis in .NET Core 入门:(1) 安装和主要功能简介

通过get key(key为name),可以获得其对应的值。

准备.NET Core项目

建立一个.NET Core 控制台项目,并安装Redis的.NET Core客户端。

Redis有很多C#的客户端,这里有个列表:https://redis.io/clients#c

我这使用的是 StackExchange.Redis (https://stackexchange.github.io/StackExchange.Redis/)。

安装StackExchange.Redis

Redis in .NET Core 入门:(1) 安装和主要功能简介

使用StackExchange.Redis

Redis in .NET Core 入门:(1) 安装和主要功能简介

ConnectionMultiplexer已经实现了IDisposable接口,之所以没有使用using表达式,是因为该对象应该重复利用的,具体请看文档。

我之前通过redis-cli设置了key为name的值,这里我通过name这个key把相对应的值找出来,并打印在控制台:

Redis in .NET Core 入门:(1) 安装和主要功能简介

如果所示,连接上了数据库,并把值输出到了控制台,OK。

使用C#写入值

这个也没什么特别的,看代码:

Redis in .NET Core 入门:(1) 安装和主要功能简介

运行结果:

Redis in .NET Core 入门:(1) 安装和主要功能简介

Redis 的数据类型

Redis的主要数据类型有这些:

  • Key:就是key的意思。。。。
  • String:字符串
  • List:有序字符串的集合
  • Hashes:有点像对象,里面可以有若干个字段,字段都有自己的值,字段和值都是字符串类型的。
  • Set:无序唯一字符串的集合
  • Sorted-Set:跟Set很像,但是每一个字符串元素都对应一个浮点数值,该数值叫做分数。它里面的元素通常是按照分数来排序的。

Redis 如何持久化

一共有两种方式:

  • AOF(Append-only file)
  • RDB(Redis database file)

首先需要知道Redis的操作都是在内存中完成的,因为这样速度快。

AOF

然后你可以启用AOF,它会把每个操作都记录到系统文件里。所以如果Redis服务器重启了,它会根据AOF这个文件来重建整个数据集。

这个文件会很快就变得很大,但是Redis很聪明,它会使用里面最新版本的数据,并压缩文件到可控大小。

RDB

RDB是Redis的默认模式,它有点像数据库的快照,创建一些时间点的数据,如果发生灾难,你可以从这些数据里进行恢复。

当达到一些条件的时候,例如数据集里面在某段时间内新添加了一定条目的数据,Redis就会把数据做个快照,并写入一个RDB文件。

最佳实践是两者都用,使用AOF因为其速度和可用性,使用RDB做灾难恢复。

Redis的配置文件

https://raw.githubusercontent.com/antirez/redis/4.0/redis.conf 这是Redis 4.0 的一个标准配置文件。

RDB 快照相关

先看快照部分,也就是和RDB有关的部分:

Redis in .NET Core 入门:(1) 安装和主要功能简介

里面的save 900 1.。。。这部分是指,900秒过后,如果至少1个key改变了,那么就做一个快照。

下面的就是300秒过后,如果10个key改变了,那就做一个快照。。。

这些就是进行快照动作的触发条件。

AOF相关

Redis in .NET Core 入门:(1) 安装和主要功能简介

AOF模式默认是不开启的,也就是no。如果想开启,那就改成yes即可。

使用自定义配置运行Redis容器

RDB & AOF

把上述文件下载到本地,进行修改:

Redis in .NET Core 入门:(1) 安装和主要功能简介

我添加了一个RDB的条件,5秒内1个Key被修改就会触发快照动作。

然后我启用了AOF:

Redis in .NET Core 入门:(1) 安装和主要功能简介

首先把之前的容器删除吧,然后再建立一个。

这次建立docker容器的时候需要使用volume:

Redis in .NET Core 入门:(1) 安装和主要功能简介

说明一下:

-v这部分是指volume,redis.conf在我电脑里的位置是:D:\Projects\Redis\redis.conf,所以我把该位文件的位置挂载到了容器里的/usr/local/etc/redis/redis.conf这个地方。

然后运行redis这个镜像,同时运行里面的redis-server,而redis-server的配置文件就是/usr/local/etc/redis/redis.conf。

现在这个redis-server运行起来了。

再打开一个redis-cli,还是使用容器:

Redis in .NET Core 入门:(1) 安装和主要功能简介

然后我设置一个key的值:

Redis in .NET Core 入门:(1) 安装和主要功能简介

这时就达到了RDB的最后一个条件,所以触发了快照动作。

我就不再实验了。。。

我再打开一下redis容器的bash,然后看一下aof文件是否生成:

Redis in .NET Core 入门:(1) 安装和主要功能简介

可以看到每次操作后aof文件都会更新(里面可以认为就是事务的log)。

Master-Slave Replication 主从复制

简单讲一下Redis的主从复制,首先把之前的容器都删掉。。。

然后我们先建立docker 网络:

Redis in .NET Core 入门:(1) 安装和主要功能简介

然后创建redis master的容器,不过首先修改一下redis.conf里的bind地址,原来是127.0.0.1,改为 bind 0.0.0.0:

Redis in .NET Core 入门:(1) 安装和主要功能简介

这样的话其它的ip地址也可以连接过来了。

然后创建master容器:

Redis in .NET Core 入门:(1) 安装和主要功能简介

注意里面使用了之前创建的桥接网络。

检查一下redis-net这个网络:

Redis in .NET Core 入门:(1) 安装和主要功能简介

Redis in .NET Core 入门:(1) 安装和主要功能简介

可以看到该网络里有一个容器master-redis,其ip为172.20.0.2。

然后把redis.conf再复制一份,名字为redis2.conf。

在redis2.conf的Replication部分里,把下面这部分取消注释,并修改为:

Redis in .NET Core 入门:(1) 安装和主要功能简介

注意这个ip地址和master-redis的ip要一样。

现在我们可以运行这个redis的slave容器了:

Redis in .NET Core 入门:(1) 安装和主要功能简介

然后我们可以看到主从复制成功了:

Redis in .NET Core 入门:(1) 安装和主要功能简介

打开master的redis-cli:

Redis in .NET Core 入门:(1) 安装和主要功能简介

操作一些操作,可以看到master和slave都几乎同步的做了一些动作,也就是主从复制:

Redis in .NET Core 入门:(1) 安装和主要功能简介

设置密码

把之前的容器都清理掉。。。

主从复制的master通常需要设置密码,修改redis.conf文件,找到requirepass这部分,取消注释并设置密码:

Redis in .NET Core 入门:(1) 安装和主要功能简介

在slave的redis2.conf里,找到masterauth这部分,填写master的密码:

Redis in .NET Core 入门:(1) 安装和主要功能简介

首先我填写一个错误的密码。

然后运行两个容器,看看什么效果:

Redis in .NET Core 入门:(1) 安装和主要功能简介

可以看到提示密码不正确,无法进行复制。

然后删掉slave容器,再把redis2.conf的密码修正一下:

Redis in .NET Core 入门:(1) 安装和主要功能简介

然后再运行slave容器:

Redis in .NET Core 入门:(1) 安装和主要功能简介

这次可以看到连接成功了。

其它的配置方式

redis-server的命令行参数

Redis in .NET Core 入门:(1) 安装和主要功能简介

如上图,这就对port和replicaof进行配置,而没有使用redis2.conf(所以该命令前面的-v部分也是没有什么作用的)。

CONFIG SET

前面我们使用了自定义的配置文件来运行Redis,但是这样的话需要重启Redis Server。

而如果使用CONFIG SET(https://redis.io/commands/config-set)的话,那就不需要重启redis server直接就可以修改配置,但是这样做不会修改redis.conf等配置文件的。

首先需要使用redis-cli,然后进行配置即可,例如:

Redis in .NET Core 入门:(1) 安装和主要功能简介

这就是添加了一个快照的设置:每20秒如果有两个变化就做一个快照。

Redis in .NET Core 入门:(1) 安装和主要功能简介的更多相关文章

  1. Redis安装和主要功能简介

    Redis安装和主要功能简介   Redis(https://redis.io/), 是一个内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 安装Redis 我很少在开发机中直接装各种数 ...

  2. Redis in .NET Core 入门:(5) Sorted SET

    第1篇:https://www.cnblogs.com/cgzl/p/10294175.html 第2篇 String:https://www.cnblogs.com/cgzl/p/10297565. ...

  3. Redis in .NET Core 入门:(4) LIST和SET

    第1篇:https://www.cnblogs.com/cgzl/p/10294175.html 第2篇 String:https://www.cnblogs.com/cgzl/p/10297565. ...

  4. Redis in .NET Core 入门:(3) Hash

    第1篇:https://www.cnblogs.com/cgzl/p/10294175.html 第2篇 String:https://www.cnblogs.com/cgzl/p/10297565. ...

  5. Redis in .NET Core 入门:(2) String

    第1篇:https://www.cnblogs.com/cgzl/p/10294175.html‘ 本文简单介绍一下Redis的常用数据类型String. 基本上都是文档上的内容,所以比较无聊.... ...

  6. CentOS开发ASP.NET Core入门教程

    作者:依乐祝 原文地址:https://www.cnblogs.com/yilezhu/p/9891346.html 因为之前一直没怎么玩过CentOS,大多数时间都是使用Win10进行开发,然后程序 ...

  7. ASP.NET Core 入门教程 10、ASP.NET Core 日志记录(NLog)入门

    一.前言 1.本教程主要内容 ASP.NET Core + 内置日志组件记录控制台日志 ASP.NET Core + NLog 按天记录本地日志 ASP.NET Core + NLog 将日志按自定义 ...

  8. Redis(一)入门

    最近,学习了一下,Redis 这个Nosql数据库,从安装到基本语法,作为入门.下面,整理一下基本知识. 参考的地址如下: http://www.runoob.com/redis/redis-java ...

  9. Entity Framework Core 入门(2)

    安装 EF Core 将 EF Core 添加到不同平台和常用 IDE 中的应用程序的所需步骤汇总. 分步入门教程 无需具备 Entity Framework Core 或任何特定 IDE 的原有知识 ...

随机推荐

  1. 使用Servlet和JSP实现一个简单的Web聊天室系统

    1 问题描述                                                利用Java EE相关技术实现一个简单的Web聊天室系统,具体要求如下. (1)编写一个登录 ...

  2. C# Stream 和 byte[] 之间的转换

    一. 二进制转换成图片 MemoryStream ms = new MemoryStream(bytes); ms.Position = ; Image img = Image.FromStream( ...

  3. CentOS7 PostgreSQL安装

    CentOS7 PostgreSQL安装 CentOS7 PostgreSQL安装 Install 安装 使用yum安装 yum install http://yum.postgresql.org/9 ...

  4. EntityFramework执行SQL语句

    在EF中执行Sql语句. using (var context = new EFRecipesEntities()) { string sql = @"insert into Chapter ...

  5. php会话(session)生命周期概念介绍及设置更改和回收

    http://www.169it.com/article/8429580816135935852.html https://my.oschina.net/jiec/blog/227252  sessi ...

  6. C#反射概念以及实例详解【转】

    2009-08-28 13:12 佚名 互联网 我要评论(1) 字号:T | T C#反射概念以及实例向你介绍了C#反射的基本内容以及C#反射实例的简单应用,希望对你了解和学习C#反射以及C#反射实例 ...

  7. 刷榜中ASO优化中下载量与评论之间的对应比

    刷榜中ASO优化中下载量与评论之间是怎么样对应,我们都知道,在ASO优化的过程中,ASO优化师在做下载量后的二至三天,都会顺带着做一下评论.这时候问题就来了,下载量与评论的比例关系应该如何确定呢?最近 ...

  8. (Code) Python implementation of phrase extraction from sentence

    import os import numpy as np import pandas as pd from tqdm import tqdm import numpy as np import str ...

  9. 用 jupyter notebook 打开 oui.txt 文件出现的问题及解决方案

    问题背景:下载了2018 IEEE 最新的 oui.txt 文件.里面包含了 设备 MAC 地址的前六位对应的厂商.要做的工作是,将海量设备的 MAC 地址与 oui.txt 文件的信息比对,统计出 ...

  10. spring boot(八)RabbitMQ使用

    RabbitMQ 即一个消息队列,主要是用来实现应用程序的异步和解耦,同时也能起到消息缓冲,消息分发的作用. 消息中间件在互联网公司的使用中越来越多,刚才还看到新闻阿里将RocketMQ捐献给了apa ...