redis新手入门(Redis系列一文带你入门Redis)

目录

一、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

redis新手入门(Redis系列一文带你入门Redis)(1)

2、启动Redis服务端

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

或者双击:redis-server.exe 。

redis新手入门(Redis系列一文带你入门Redis)(2)

3、启动Redis客户端

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

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

redis新手入门(Redis系列一文带你入门Redis)(3)

输入ping,响应PONG。

redis新手入门(Redis系列一文带你入门Redis)(4)

以上则表示连接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 && make cd /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 删除指定key del key1

2、Hash(哈希)

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

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

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

3、List(列表)

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

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

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

4、Set(集合)

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

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

add key4 my add key4 name add key4 is smembers key4

5、zset(有序集合)

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

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

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

zadd key5 1 my zadd key5 2 name zadd key5 2 is zrange 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/

关注【嘎嘎软件测试】

搞测试,不迷路

呱呱大王本呱带你飞!

redis新手入门(Redis系列一文带你入门Redis)(5)

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

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页