NOSQL数据库之 Redis使用

redis概述及特点:

概述

(1)Redis是Remote Dictionary Server(远程数据服务)的缩写.

由意大利人antirez(Salvatore Sanfilippo)开发的一款内存高速缓存数据库

(2)该软件使用C语言编写,它的数据模型为key-value

(3)它支持存储的value类型很多,包括string(字符串)、hash(哈希)、list(链表)set(集合)、Zset(有序集合)

(4)为了保证效率数据都是缓存在内存中,它也可以周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件。

特点

1)高速读取数据(in-memory)

2)减轻数据库负担

3)有集合计算功能(优于普通数据库和同类别产品)

4)多种数据结构支持

 

redis 安装启动说明: 略。。。。。

 

数据类型讲解:::

1 字符串 (String):

        string是redis最基本的类型

        redisstring可以包含任何数据。包括jpg图片或者序列化的对象。

        单个value值最大上限是1G字节, 如果只用string类型,redis就可以被看作加上持久化特性(服务器重启之后,数据不丢失)的memcache

        (1) set  

        设置键,值

         语法:set  键名称  值

         例如:我们添加一个name=“xiaoqian”的键值对。

          注意:重新设置则直接覆盖

     (2)get

        获取key对应的string值,如果key不存在返回 nil,

        语法:get 键值

(3)incr

   对key的值做加加操作,并返回新的值,每执行一次值加1,值类型要是数据类型。

   语法:incr  key

(4)incrby

执行加法的命令,可以指定相加的值,

2、hash

hash可以用来存储对应的mysql中一行的数据,类似于关联数组。

(1)hset

设置哈希里面的field和vlaue的值。

语法:

hset  哈希的名称(键名称)  field   value

(2)hget

获取哈希里面的field的值

语法:hget 哈希的名称(键名称) 指定的field

(3)hmset

一次性设置多个field和value

语法: hmset  哈希的名称   field1  value1  field2  value2……

(4)hmget

一次性获取 多个field的value

语法:hmget  哈希的名称   field1  field2…….

(5)hgetall

获取指定哈希中所有的field和value

语法:

hgetall  哈希的名称

3、链表(list)

list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。

这使得list既可以用作栈,也可以用作队列。

上进上出 :  ,特点:数据 先进后出

下进上出 :队列,特点:数据 先进先出:

(1)lpush

从链表的头部添加元素

语法: lpush  链表的名称(键的名称) 元素

(2)lrange

获取链表里面的元素

语法:

lragne 链表的名称  开始下标   结束下标

注意:如果开始下标是0结束下标是-1则是返回链表中所有的元素。

注意:链表里面的元素是序号的(从0开始数),类似于索引数组。

(3)rpush

从链表的尾部添加元素

语法: rpush  链表的名称(键的名称) 元素

(4)ltrim

保留指定范围的元素

语法:ltrim 链表的名称   开始下标    结束下标

(5)lpop

从链表的头部删除一个元素,返回删除的元素

语法:lpop  链表的名称

注(list 链表可实现场景):::可以在list链表中只保留最新的10个数据,每进来一个新数据就删除一个旧数据。每次就可以从链表中直接获得需要的数据。Ipush name(链表名)  vlaue(链表值) ltrim name(链表名) 0 9  (下标 0 -9 )

4、集合(set)

redis的set是string类型的无序集合。

set元素最大可以包含(2的32次方-1)(整型最大值)个元素。

关于set集合类型除了基本的添加、删除操作,其他有用的操作还包含集合的取并集(union),交集(intersection),差集(difference)。通过这些操作可以很容易的实现sns中的好友推荐功能

(1)sadd

向集合中添加元素

语法:

sadd  集合名(键名) 元素名称

(2)smembers

获取集合中的元素

语法:

smembers 集合名

(3)sdiff

获取集合中的差集(在集合1中存在,不在集合2中存在的元素)

语法:sdiff 集合1  集合2

(4)sinter

获取交集(在两个集合中都存在的元素)

语法:sinter 集合1  集合2

(5)sunion

求并集(两个集合合并后,去掉重复的元素)

语法:sunion  集合1  集合2

(6)scard

获取集合中元素的个数

语法:scard 集合名称

5、(有序集合)zset

sorted set是set的一个升级版本,他在set的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新的值调整顺序。操作中的key理解为zset的名字。

(1)zadd

向有序集合中添加元素。如果该元素存在,则更新其顺序。

语法:zadd  集合名  序号  内容

(2)zrange

(把集合排序后,返回名次[start,stop]的元素

默认是升续排列

Withscores 是把score也打印出来)

按序号升序获取有序集合中的内容,

语法:zrange 集合名称 开始下标  结束下标

(3)zrevrange

按序号降序获取有序集合中的内容。

语法:zrevrange 集合名称 开始下标(索引) 结束下标(索引)

 

Redis常用命令

redis提供了丰富的命令对数据库和各种数据库类型进行操作,这些命令可以在linux终端使用。

1、键值相关的命令

2、服务器相关命令

(1)keys

返回当前数据库里面的键,可以使用通配符,* 表示:任意多个,?任意一个字符。

(2)exists

判断一个键是否存在。

语法:exists  键名称

(3)del

删除指定的键

语法: del  键名称

(4)expire

设置键的有效期

语法:expire  key  有效期(秒数)

(5)ttl

返回一个键剩余的过期时间.

(6)type

返回数据类型

语法: type  key

(7)select

选择数据库,在redis里面默认有0-15号数据库,默认是0号数据库,

可以通过redis.conf配置文件进行设置。

(8)dbsize

返回当前数据库里面键的个数

(9)flushdb

清空当前数据库里面所有的键,(慎重使用)

(10)flushall

清空所有数据库里面的所有的键,(慎重使用)

 

Redis安全认证

设置客户端连接后进行任何其他操作前需要使用的密码。

方法:打开redis的配置文件(redis.conf)

(1)#requirepass   设置的密码

注意:设置的密码是明文的,因此要对redis.conf配置文件,进行严格的授权。

(2)重启redis服务,让密码生效。

关闭redis服务   pkill redis-server

启动   /usr/local/redis/bin/redis-server   /usr/local/redis/redis.conf

(3)客户端验证方式:

注意:如果没有通过验证,则无法操作:

通过客户端登录到服务器时,添加  -a 选项。语法:redis-cli    –a 密码

Redid持久化机制

redis为了内存数据的安全考虑,会把内存中的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边。

数据保存到硬盘的过程就称为“持久化”效果。

redis支持两种持久化方式:

(1)snapshotting(快照)默认方式

(2)append-only file(缩写aof)的方式

1、snapshotting快照方式持久化

该持久化默认开启,一次性把redis中全部的数据保存一份存储在硬盘中(备份文件名字默认是dump.rdb),如果数据非常多(10-20G)就不适合频繁进行该持久化操作。

(1)如何开启,默认开启,有自己的触发条件:

注意:屏蔽该触发条件,即可关闭快照方式。

(2)可以设置保存位置,和备份的文件名

备份文件名字默认是dump.rdb,我们也可以自己修改,

可以通过配置文件,来完成修改

3)手动发起快照:

两种方式完成手动保存。

方式一:在登录状态:

则直接执行bgsave即可。

方式二 :在没有登录状态

./redis-cli bgsave 手动发起一次快照保存操作

(4)缺点:

由于快照方式是在一定间隔做一次的,所以如果redis意外down掉的话,就会丢失最后一次快照后的所有修改。

2、append-only-file  追加方式持久化AOF

本质:把用户执行的每个“写”指令(添加、修改、删除)都备份到文件中,还原数据的时候就是执行具体写指令而已。

(1)如何开启

appendonly   yes         //启用 aof 持久化方式

appendfilename  appendonly.aof   //保存命令的文件(可以指定路径)

打开redis.conf配置文件,进行打开配置。

(2)触发条件

# appendfsync always   //每次收到写命令就立即强制写入磁盘,最慢的,但是保证完全的持久化,不推荐使用

appendfsync everysec   //每秒钟强制写入磁盘一次,在性能和持久化方面做了很好的折中,推荐

# appendfsync no   //完全依赖 os,性能最好,持久化没保证

打开配置文件进行如下修改。

 

(3)aof文件的重写:

例如:可以把多个incr指令换为一个set指令

问题:

每个命令重写一次aof,如果某个key操作100次,产生100行记录,aof文件会很大,怎么解决?

比如,当执行多次incr  number操作,aof 文件中会保存多次incr number的命令。这样会增大aof文件容量,我们可以对aof文件重写,把里面重复的命令压缩成一条命令。

就比如执行10次incr number 压缩成set number 11

执行重写的命令是:

执行重写可以在登录状态下执行,直接输入bgrewriteaof,也可以在未登录状态下执行,

语法:./bin/redis-cli –a  密码   bgrewriteaof

注意点:如果两种持久化方式都开启,则以aof为准。

java 操作Redis技术 SpringDataRedis

 

目录

redis概述及特点:

redis 安装启动说明: 略。。。。。

数据类型讲解:::

1 字符串 (String):

2、hash

3、链表(list)

4、集合(set)

5、(有序集合)zset

Redis常用命令

(1)keys

(2)exists

(3)del

(4)expire

(5)ttl

(6)type

(7)select

(8)dbsize

(9)flushdb

(10)flushall

 

Redis安全认证

Redid持久化机制

1、snapshotting快照方式持久化

2、append-only-file  追加方式持久化AOF

(3)aof文件的重写:

java 操作Redis技术 SpringDataRedis

SpringDataRedis 简介


ListOperations:针对 list 类型的数据操作

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值