Redis入门指南:从零开始学习Redis

发表时间: 2022-02-08 21:20



目录


一、Redis简介

二、Redis安装

三、Redis数据类型及常用命令

四、相关学习资源



一、Redis简介


1、Redis简介

Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。

Redis 与其他 key - value 缓存产品有以下三个特点:

  • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
  • Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
  • Redis支持数据的备份,即master-slave模式的数据备份。


2、关系型非关系型数据库的差别

关系型数据库

关系型数据库最典型的数据结构是表,由二维表及其之间的联系所组成的一个数据组织。


优点:

1、易于维护:都是使用表结构,格式一致;

2、使用方便:SQL语言通用,可用于复杂查询;

3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。


缺点:

1、读写性能比较差,尤其是海量数据的高效率读写;

2、固定的表结构,灵活度稍欠;

3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。

常见数据库:MySQL、Oracle、SQLServer、PostgreSQL...


非关系型数据库

非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合,可以是文档或者键值对等。


优点:

1、格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础类型。

2、速度快:nosql可以使用硬盘或者随机存储器作为载体,而关系型数据库只能使用硬盘;

3、高扩展性;

4、成本低:nosql数据库部署简单,基本都是开源软件


缺点:

1、不提供sql支持,学习和使用成本较高;

2、无事务处理;

3、数据结构相对复杂,复杂查询方面稍欠。

常见数据库:Redis、mongoDB、Hbase...


非关系型数据库的分类

1、文档型

2、key-value型

3、列式数据库

4、图形数据库


二、Redis安装


1、Windows环境

1、Redis下载

Redis下载地址:https://github.com/microsoftarchive/redis/releases

下载Redis-x64-xxx.zip


2、启动Redis服务端

进入cmd切换到Redis目录下,执行:redis-server.exe redis.windows.conf。

或者双击:redis-server.exe 。



3、启动Redis客户端

进入cmd切换到Redis目录下, 执行:redis-cli.exe -h 127.0.0.1 -p 6379,或者双击:redis-cli.exe。

注意:原来的不要关闭,不然就无法访问服务端了。

输入ping,响应PONG。

以上则表示连接Redis成功。


2、Linux环境

1、Redis下载

Redis下载地址:https://redis.io/download


2、Redis安装

#安装gcc环境 yum install gcc-c++ yum install gcc #下载(可通过上方地址下载或者直接通过wget下载) wget https://download.redis.io/releases/redis-6.0.9.tar.gz#解压tar -zvxf redis-6.0.9.tar.gz#重命名mv /usr/local/redis-6.0.9 /usr/local/redis#编译#PREFIX= 这个关键字的作用是编译的时候用于指定程序存放的路径。指定了redis必须存放在/usr/local/redis目录。#假设不添加该关键字Linux会将可执行文件存放在/usr/local/bin目录,库文件会存放在/usr/local/lib目录。配置文件会存放在/usr/local/etc目录。其他的资源文件会存放在usr/local/share目录。#这里指定号目录也方便后续的卸载,后续直接rm -rf /usr/local/redis 即可删除redis。cd /usr/local/redis && makecd /usr/local/redis && make PREFIX=/usr/local/redis install#启动redis#redis-server 后面是配置文件,目的是根据该配置文件的配置启动redis服务。#redis.conf配置文件允许自定义多个配置文件,通过启动时指定读取哪个即可。#把 redis.conf配置文件中的 bind 127.0.0.1 这一行给注释掉,这里的bind指的是只有指定的网段才能远程访问这个redis,注释掉后,就没有这个限制了。cd /usr/local/redis  && ./bin/redis-server& ./redis.conf#开机启动#添加如下代码到 /etc/rc.d/rc.local 中/usr/local/redis/bin/redis-server  /usr/local/redis/etc/redis.conf


3、Redis配置

在redis.conf里设置redis密码requirepass "Passwd@4321"masterauth "Passwd@4321"6379在redis.conf里设置为6377的从节点,6377主节点则无需设置slaveof 127.0.0.1 6377



三、Redis数据类型及常用命令


Redis支持五种数据类型:

string(字符串)

hash(哈希)

list(列表)

set(集合)

zset(有序集合)


1、String(字符串)

string 是 Redis 最基本的类型,就是一个 key 对应一个 value。string 类型的值最大能存储 512MB。

设置指定key的值set key1 redis获取指定key的值get key1删除指定keydel key1


2、Hash(哈希)

Redis hash 是一个 string 类型的 field(字段) 和 value(值) 的映射表,hash 特别适合用于存储对象。

Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)。

同时将多个 field-value (域-值)对设置到哈希表 key 中hmset key2 name "zhangsan" age 18 sex "男"获取在哈希表中指定 key 的所有字段和值hgetall key2获取存储在哈希表中指定字段的值hget key2 name获取所有哈希表中的字段hkeys key2删除一个或多个哈希表字段hdel key2 name


3、List(列表)

Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。

一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。

将一个或多个值插入到列表头部lpush key3 mylpush key3 namelpush key3 is zyx 获取列表指定范围内的元素lrange key3 0 10


4、Set(集合)

Redis的Set是string类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

add key4 myadd key4 nameadd key4 issmembers key4


5、zset(有序集合)

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

zadd key5 1 myzadd key5 2 namezadd key5 2 iszrange key5 0 10



四、相关学习资源


菜鸟教程:

https://www.runoob.com/redis/redis-tutorial.html

w3cschool:

https://www.w3cschool.cn/redis/redis-intro.html

Redis命令参考:http://doc.redisfans.com/

Redis在线练习:https://try.redis.io/



关注【嘎嘎软件测试】

搞测试,不迷路

呱呱大王本呱带你飞!

嘎嘎软件测试 将分享个人成长、团队管理、软件测试技能知识等内容做到有思想、有观点、有深度,欢迎订阅。