目录
一、Redis简介
二、Redis安装
三、Redis数据类型及常用命令
四、相关学习资源
一、Redis简介
1、Redis简介
Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。
Redis 与其他 key - value 缓存产品有以下三个特点:
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/
关注【嘎嘎软件测试】
搞测试,不迷路
呱呱大王本呱带你飞!
嘎嘎软件测试 将分享个人成长、团队管理、软件测试技能知识等内容做到有思想、有观点、有深度,欢迎订阅。