Redis 命令大全(发现欠缺会不断更新完善)

(有一个需求:将端口号6379的redis数据转移到6380的端口号中,步骤:面试

【1】获取6379全部key jedis.keys("*")redis

【2】判断类型jedis.type(key) 分为五种:string,list,set,zset,hash数据库

【3】获取key的剩余活动时间jedis.ttl(key) -1表明过时,-2表明不存在,整数表明还有多少时间过时windows

【4】根据五种不一样的类型获取端口号6379的数据缓存

    1.String:String val= jedis.get(key)安全

    2.List     : List<String> val =jedis.lrange(key,0,-1)服务器

    3.Set     : Set<String> val =jedis.smembers(key);app

    4.Zset   :这个不肯定。。。dom

    5.hash  : Map<String,String> map =jedis.hgetAll(key);  性能

【5】将五种不一样类型数据添加到端口号6380的redis服务中

    1.String:jedis.set(key,val)   jedis.expire(key,timeout) timeout为活动时间

    2.list      :遍历List<String>,添加jedis.rpush(key,value)

    3.hash   :遍历Map<String,String> 添加到jedis.hset(key,map的key,map的value)

    4.set    :遍历Set<String>  添加到jedis.sadd(key,value)

    5zset    :这个不敢肯定。。。。虽然出来了,等我后续更新吧

)

一.场景

    redis的应用场景:缓存(举个例子:【1】咱们购买一个商品,下订单的时候会把这个支付成功的订单放到redis队列里面,经过定时监听器把redis队列中的订单数据写进库中【2】咱们登陆一个网站,当你支付的时候会发现须要从新登陆下淘宝页面,这个时候就用到了缓存,也就是说当你支付的时候它首先会从缓存中获取你的用户信息,只有登陆的状况下才有用户信息,不存在过时,有的话能够直接跳转)

二.数据类型

1.String类型

String是最简单的类型,一个key对应一个value

String类型的数据最大1G。

在list、set和zset中包含的独立的元素类型都是Redis String类型。

2.List类型

链表类型,主要功能是push、pop、获取一个范围的全部值等。其中的key能够理解为链表的名字。

在Redis中,list就是Redis String的列表,按照插入顺序排序。好比使用LPUSH命令在list头插入一个元素,使用RPUSH命令在list的尾插入一个元素。当这两个命令之一做用于一个空的key时,一个新的list就建立出来了。

List的最大长度是2^32-1个元素。

3.Set类型

集合,和数学中的集合概念类似。操做中的key理解为集合的名字。

在Redis中,set就是Redis String的无序集合,不容许有重复元素。

Set的最大元素数是2^32-1。

Redis中对set的操做还有交集、并集、差集等。

4.ZSet(Sorted Set)类型

Zset是set的一个升级版本,在set的基础上增长了一个顺序属性,这一属性在添加修改元素时能够指定,每次指定后zset会自动安装指定值从新调整顺序。能够理解为一张表,一列存value,一列存顺序。操做中的key理解为zset的名字。

Zset的最大元素数是2^32-1。

对于已经有序的zset,仍然可使用SORT命令,经过指定ASC|DESC参数对其进行排序。

5.hash类型

hash是最接近关系数据库结构的数据类型,能够将数据库一条记录或程序中一个对象转换成hashmap存放在redis中。

三.命令(jedis)

【不过咱们通常存储的就是jedis.set(key,value)和jedis.setex(key,second,value)这种形式,他们两个的差距就是设置了缓存时间】

    1.对value操做的命令

     exists(key):确认一个key是否存在

     del(key):删除一个key

     type(key):返回值的类型

     keys(pattern):返回知足给定pattern的全部key

     randomkey:随机返回key空间的一个key

   rename(oldname, newname):将key由oldname重命名为newname,若newname存在则删除newname表示的key

     dbsize:返回当前数据库中key的数目

     expire:设定一个key的活动时间(s)

     ttl:得到一个key的活动时间

     select(index):按索引查询

     move(key, dbindex):将当前数据库中的key转移到有dbindex索引的数据库

     flushdb:删除当前选择数据库中的全部key

     flushall:删除全部数据库中的全部key

2.对String操做的命令

     set(key, value):给数据库中名称为key的string赋予值value

     get(key):返回数据库中名称为key的string的value

     getset(key, value):给名称为key的string赋予上一次的value

     mget(key1, key2,…, key N):返回库中多个string(它们的名称为key1,key2…)的value

     setnx(key, value):若是不存在名称为key的string,则向库中添加string,名称为key,值为value

     setex(key, time, value):向库中添加string(名称为key,值为value)同时,设定过时时间time

     mset(key1, value1, key2, value2,…key N, value N):同时给多个string赋值,名称为key i的string赋值value i

    msetnx(key1, value1, key2, value2,…key N, value N):若是全部名称为key i的string都不存在,则向库中添加string,名称           key i赋值为value i

     incr(key):名称为key的string增1操做

     incrby(key, integer):名称为key的string增长integer

     decr(key):名称为key的string减1操做

     decrby(key, integer):名称为key的string减小integer

     append(key, value):名称为key的string的值附加value

     substr(key, start, end):返回名称为key的string的value的子串

3.对List操做的命令

     rpush(key, value):在名称为key的list尾添加一个值为value的元素

     lpush(key, value):在名称为key的list头添加一个值为value的 元素

     llen(key):返回名称为key的list的长度

     lrange(key, start, end):返回名称为key的list中start至end之间的元素(下标从0开始,下同)

     ltrim(key, start, end):截取名称为key的list,保留start至end之间的元素

     lindex(key, index):返回名称为key的list中index位置的元素

     lset(key, index, value):给名称为key的list中index位置的元素赋值为value

     lrem(key, count, value):删除count个名称为key的list中值为value的元素。count为0,删除全部值为value的元素,count>0      从头到尾删除count个值为value的元素,count<0从尾到头删除|count|个值为value的元素。

     lpop(key):返回并删除名称为key的list中的首元素

     rpop(key):返回并删除名称为key的list中的尾元素

     blpop(key1, key2,… key N, timeout):lpop命令的block版本。即当timeout为0时,若遇到名称为key i的list不存在或该list为空,则命令结束。若是timeout>0,则遇到上述状况时,等待timeout秒,若是问题没有解决,则对key i+1开始的list执行pop操做。

     brpop(key1, key2,… key N, timeout):rpop的block版本。参考上一命令。

     rpoplpush(srckey, dstkey):返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部

4.对Set操做的命令

     sadd(key, member):向名称为key的set中添加元素member

     srem(key, member) :删除名称为key的set中的元素member

     spop(key) :随机返回并删除名称为key的set中一个元素

     smove(srckey, dstkey, member) :将member元素从名称为srckey的集合移到名称为dstkey的集合

     scard(key) :返回名称为key的set的基数

     sismember(key, member) :测试member是不是名称为key的set的元素

     sinter(key1, key2,…key N) :求交集

     sinterstore(dstkey, key1, key2,…key N) :求交集并将交集保存到dstkey的集合

     sunion(key1, key2,…key N) :求并集

     sunionstore(dstkey, key1, key2,…key N) :求并集并将并集保存到dstkey的集合

     sdiff(key1, key2,…key N) :求差集

     sdiffstore(dstkey, key1, key2,…key N) :求差集并将差集保存到dstkey的集合

     smembers(key) :返回名称为key的set的全部元素

     srandmember(key) :随机返回名称为key的set的一个元素

5.对zset(sorted set)操做的命令

     zadd(key, score, member):向名称为key的zset中添加元素member,score用于排序。若是该元素已经存在,则根据score更新该元素的顺序。

     zrem(key, member) :删除名称为key的zset中的元素member

     zincrby(key, increment, member) :若是在名称为key的zset中已经存在元素member,则该元素的score增长increment;不然向集合中添加该元素,其score的值为increment

     zrank(key, member) :返回名称为key的zset(元素已按score从小到大排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”

     zrevrank(key, member) :返回名称为key的zset(元素已按score从大到小排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”

     zrange(key, start, end):返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的全部元素

     zrevrange(key, start, end):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的全部元素

     zrangebyscore(key, min, max):返回名称为key的zset中score >= min且score <= max的全部元素

     zcard(key):返回名称为key的zset的基数

     zscore(key, element):返回名称为key的zset中元素element的score

     zremrangebyrank(key, min, max):删除名称为key的zset中rank >= min且rank <= max的全部元素

     zremrangebyscore(key, min, max) :删除名称为key的zset中score >= min且score <= max的全部元素

     zunionstore / zinterstore(dstkeyN, key1,…,keyN, WEIGHTS w1,…wN, AGGREGATE SUM|MIN|MAX):对N个zset求并集和交集,并将最后的集合保存在dstkeyN中。对于集合中每个元素的score,在进行AGGREGATE运算前,都要乘以对于的WEIGHT参数。若是没有提供WEIGHT,默认为1。默认的AGGREGATE是SUM,即结果集合中元素的score是全部集合对应元素进行SUM运算的值,而MIN和MAX是指,结果集合中元素的score是全部集合对应元素中最小值和最大值。

6.对Hash操做的命令

     hset(key, field, value):向名称为key的hash中添加元素field<—>value

     hget(key, field):返回名称为key的hash中field对应的value

     hmget(key, field1, …,field N):返回名称为key的hash中field i对应的value

     hmset(key, field1, value1,…,field N, value N):向名称为key的hash中添加元素field i<—>value i

     hincrby(key, field, integer):将名称为key的hash中field的value增长integer

     hexists(key, field):名称为key的hash中是否存在键为field的域

     hdel(key, field):删除名称为key的hash中键为field的域

     hlen(key):返回名称为key的hash中元素个数

     hkeys(key):返回名称为key的hash中全部键

     hvals(key):返回名称为key的hash中全部键对应的value

     hgetall(key):返回名称为key的hash中全部的键(field)及其对应的value

3、事务

事务命令:

开启事务:multi

提交事务:exec

回滚事务:discard

监听事务:watch(乐观锁)

4、Redis持久化

【1】Rdb

Rdb持久化优势:

1) 持久化文件将只包含一个文件

2) 对灾难恢复,主从复制 效率比较高。

3) 持久化工做:子进程

Rdb缺点:

1) 数据安全性不是很好

Rdb数据持久化同步策略:

        缺省状况下,Redis会将数据集的快照dump到dump.rdb文件中。此外,咱们也能够经过配置文件来修改Redis服务器dump快照的频率,在打开redis.conf文件以后,咱们搜索save,能够看到下面的配置信息:
    save 900 1              #900(15分钟)以后,若是至少有1key发生变化,则dump内存快照。
    save 300 10            #300(5分钟)以后,若是至少有10key发生变化,则dump内存快照。
    save 60 10000        #60(1分钟)以后,若是至少有10000key发生变化,则dump内存快照。

    

【2】Aof

Aof优势:1) 根据redis aof同步策略,数据有更高安全性

Aof缺点:1) 性能比rdb低

 

7、最后找了一个网上的面试题

【1】mySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点数据

相关知识:redis 内存数据集大小上升到必定大小的时候,就会施行数据淘汰策略。redis 提供 6种数据淘汰策略: 
volatile-lru:从已设置过时时间的数据集(server.db[i].expires)中挑选最近最少使用的数据淘汰 
volatile-ttl:从已设置过时时间的数据集(server.db[i].expires)中挑选将要过时的数据淘汰 
volatile-random:从已设置过时时间的数据集(server.db[i].expires)中任意选择数据淘汰 
allkeys-lru:从数据集(server.db[i].dict)中挑选最近最少使用的数据淘汰 
allkeys-random:从数据集(server.db[i].dict)中任意选择数据淘汰 
no-enviction(驱逐):禁止驱逐数据

可是具体怎么操做呢:这些参数都在redis.windows-service.conf文件中,这些参数都被注释了,你打开注释设置一下就行,别到时候都不知道在哪里设置。

你能够根据业务须要或者场景,而后结合淘汰的几个策略说明

相关文章
相关标签/搜索