Redis安装和主要功能简介
Redis安装和主要功能简介
Redis(https://redis.io/), 是一个内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。
安装Redis
我很少在开发机中直接装各种数据库,我一般使用Docker,针对Redis也不例外,我还是使用Docker。
这是Redis在DockerHub里的地址:https://hub.docker.com/_/redis,里面有文档。
启动docker,下载redis镜像:docker pull redis

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

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

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

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

通过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

使用StackExchange.Redis

ConnectionMultiplexer已经实现了IDisposable接口,之所以没有使用using表达式,是因为该对象应该重复利用的,具体请看文档。
我之前通过redis-cli设置了key为name的值,这里我通过name这个key把相对应的值找出来,并打印在控制台:

如果所示,连接上了数据库,并把值输出到了控制台,OK。
使用C#写入值
这个也没什么特别的,看代码:

运行结果:

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有关的部分:

里面的save 900 1.。。。这部分是指,900秒过后,如果至少1个key改变了,那么就做一个快照。
下面的就是300秒过后,如果10个key改变了,那就做一个快照。。。
这些就是进行快照动作的触发条件。
AOF相关

AOF模式默认是不开启的,也就是no。如果想开启,那就改成yes即可。
使用自定义配置运行Redis容器
RDB & AOF
把上述文件下载到本地,进行修改:

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

首先把之前的容器删除吧,然后再建立一个。
这次建立docker容器的时候需要使用volume:

说明一下:
-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,还是使用容器:

然后我设置一个key的值:

这时就达到了RDB的最后一个条件,所以触发了快照动作。
我就不再实验了。。。
我再打开一下redis容器的bash,然后看一下aof文件是否生成:

可以看到每次操作后aof文件都会更新(里面可以认为就是事务的log)。
Master-Slave Replication 主从复制
简单讲一下Redis的主从复制,首先把之前的容器都删掉。。。
然后我们先建立docker 网络:

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

这样的话其它的ip地址也可以连接过来了。
然后创建master容器:

注意里面使用了之前创建的桥接网络。
检查一下redis-net这个网络:


可以看到该网络里有一个容器master-redis,其ip为172.20.0.2。
然后把redis.conf再复制一份,名字为redis2.conf。
在redis2.conf的Replication部分里,把下面这部分取消注释,并修改为:

注意这个ip地址和master-redis的ip要一样。
现在我们可以运行这个redis的slave容器了:

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

打开master的redis-cli:

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

设置密码
把之前的容器都清理掉。。。
主从复制的master通常需要设置密码,修改redis.conf文件,找到requirepass这部分,取消注释并设置密码:

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

首先我填写一个错误的密码。
然后运行两个容器,看看什么效果:

可以看到提示密码不正确,无法进行复制。
然后删掉slave容器,再把redis2.conf的密码修正一下:

然后再运行slave容器:

这次可以看到连接成功了。
其它的配置方式
redis-server的命令行参数

如上图,这就对port和replicaof进行配置,而没有使用redis2.conf(所以该命令前面的-v部分也是没有什么作用的)。
CONFIG SET
前面我们使用了自定义的配置文件来运行Redis,但是这样的话需要重启Redis Server。
而如果使用CONFIG SET(https://redis.io/commands/config-set)的话,那就不需要重启redis server直接就可以修改配置,但是这样做不会修改redis.conf等配置文件的。
首先需要使用redis-cli,然后进行配置即可,例如:

这就是添加了一个快照的设置:每20秒如果有两个变化就做一个快照。
Redis安装和主要功能简介的更多相关文章
- Redis 安装,配置,简介,数据类型(一)
Redis 安装 Window 下安装 下载地址:https://github.com/MSOpenTech/redis/releases. Redis 支持 32 位和 64 位.这个需要根据你 ...
- Redis in .NET Core 入门:(1) 安装和主要功能简介
Redis(https://redis.io/), 是一个内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 安装Redis 我很少在开发机中直接装各种数据库,我一般使用Docker,针对 ...
- Redis安装及配置
Redis缓存数据库 借鉴出处 http://www.runoob.com/redis/redis-install.html http://www.runoob.com/redis/redis-con ...
- redis安装和简介(2)
承接上篇未完成的配置...此次使用的的 Redis-x64-3.2.100 版本 一.打开redis服务器 方式一:打开 redis-server.exe 显示如下图: 图中: 显示运行进程号.当前运 ...
- windows下redis安装及配置
1.简介: redis是一个高性能的key-value数据库:redis能读的速度为11万次/秒,写的速度是8.1万次/秒 redis支持丰富的数据类型:String, List, Hash(map) ...
- 【Redis学习】:Windows环境下的Redis安装与配置
Redis简介 REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统. Redis是一个开源的使用ANSI C ...
- redis安装篇
Redis简介 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15日起,Redis的开发工作 ...
- Redis安装(单机及各类集群,阿里云)
Redis安装(单机及各类集群,阿里云) 前言 上周,我朋友突然悄悄咪咪地指着手机上的一篇博客说,这是你的博客吧.我看了一眼,是之前发布的<Rabbit安装(单机及集群,阿里云>.我朋友很 ...
- Redis安装即python使用
一:简介 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted ...
随机推荐
- LRU缓存淘汰算法
什么是LRU算法? LRU是Least Recently Used的缩写,即最近最少使用,在有限的内容块中存储最近使用次数最多的数据,当内容块已满时,把最少使用的数据删除以便存储新的内容.
- Java IO流-File类
2017-10-24 23:50:22 File类 File类:文件和目录路径名的抽象表示形式.该文件或者目录不一定真实存在. * 构造方法 File类有四种构造方法,主要采用的构造方法师第二种,也就 ...
- WinForm一次只打开一个程序
WinForm如果我们希望一次只打开一个程序,那么我们在程序每次运行的时候都需要检测线程是否存在该程序,如果存在就呼出之前的窗体,C#代码如下: using System; using System. ...
- C#获取类库(DLL)的绝对路径
C#中当我们在写公共的类库的时候难免会调用一些xml配置文件,而这个配置文件的路径则非常重要,常用的方式就是写在web.config中,而我们也可以将配置文件直接放在dll的同级目录,那么怎么获得当前 ...
- vs2010打包安装
[WinForm] VS2010发布.打包安装程序(超全超详细) 2017年02月17日 21:47:09 y13156556538 阅读数:16487更多 个人分类: C#winform 1. ...
- WebForm页面数据绑定总结
总述 绑定语法 第一种: <%= str%> 例子:'<%= DateTime.Now %>'适用条件:用于非服务器端控件的属性第二种: <%= str%> 从出现 ...
- OAF 交互式列车 上一步 下一步的简单使用
在实际的需求中,我们往往会遇到在下一步的时候验证某些参数,而上一步不需要验证. 这个是非常粗暴的解决方式 if( "goto".equals(pageContext.getPara ...
- elasticsearch 路由文档到分片
路由文档到分片 当你索引一个文档,它被存储在单独一个主分片上.Elasticsearch是如何知道文档属于哪个分片的呢?当你创建一个新文档,它是如何知道是应该存储在分片1还是分片2上的呢? 进程不能是 ...
- vEthernet(默认交换机) 无法访问网络
VMware 开启虚拟机 最近公司由无线网转为有线时,我用VMware Workstation Pro装的几个系统,其中一个 ubuntu无法访问网页,在ubuntu运行ifconfig -a ,直接 ...
- POJ 1947 Rebuilding Roads 树形dp 难度:2
Rebuilding Roads Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 9105 Accepted: 4122 ...