redis 学习(常用命令及demo)

本文介绍了Redis,一种先进的Key-Value存储系统,用于处理大量数据的高并发读写。内容涵盖Redis的主要数据类型(String、Hashes、List、Sets、Zset)及其常用操作,包括设置、获取、修改、删除等。还提到了Redis的持久化机制、主从复制、事务处理、发布订阅等功能,以及其在NoSQL领域的应用。
摘要由CSDN通过智能技术生成

redis

NOSQL 介绍:
是一项全新的数据库革命性运动,是一个非关系型数据库,在超大规模和高并发的SNS类型网站中应用广泛。
NoSql是以key-value形式存储,特点是:非关系型、分布式、开源的水平可扩展。
特点优势:

  • 处理超大量数据
  • 运行在便宜pc集群上
  • 击碎了性能瓶颈

应用场景:
1. 对数据高并发读写
2. 对海量数据的高效率存储和访问
3. 对数据的高可扩展性和高可用性

redis

Redis is an open source, BSD licensed, advanced key-value cache and store. It is often referred to as a data structure server since keys can contain strings, hashes, lists, sets, sorted sets, bitmaps and hyperloglogs.
redis是一个开源的,先进的key-value缓存存储。它常作为缓存数据库,键可包含字符串、哈希、链表、集合(有序&无序)

支持 push/pop add/move 以及集合的操作,数据保存在内存中,会周期写入硬盘中。

redis数据类型:
string hash list set zset

string是最简单的类型,一个key对应一个value,string类型是二进制安全的。redis的string可以包括任何数据,比如jpg或者序列化的对象。

String类型:

1.设置key的value(set)

    127.0.0.1:6379> set key pm
    OK
    127.0.0.1:6379> get key
    "pm"
    127.0.0.1:6379> 

2.如果不存在设置(setnx)

    127.0.0.1:6379> setnx key df
    (integer) 0
    127.0.0.1:6379> get key
    "pm"

3.设置键的有效期(setex 10s有效期)

    127.0.0.1:6379> setex key 10 value
    OK
    127.0.0.1:6379> get key
    "value"
    127.0.0.1:6379> get key
    (nil)
    127.0.0.1:6379>

4.设置替换(setrange)

127.0.0.1:6379> set key pmx@gmail.com
OK
127.0.0.1:6379> get key
"pmx@gmail.com"
127.0.0.1:6379> setrange key 4 qq
(integer) 13
127.0.0.1:6379> get key
"pmx@qqail.com"
127.0.0.1:6379>

5.一次性设置多个key(mset)

127.0.0.1:6379> mset key1 value1 key2 value2 key3 value3
OK
127.0.0.1:6379> get key1
"value1"
127.0.0.1:6379> get key2
"value2"
127.0.0.1:6379> get key3
"value3"
127.0.0.1:6379> 

6.如果不存在设置(msetnx),如果有一个不成功(已存在),全部失效。

127.0.0.1:6379> msetnx key4 value4 key5 value5
(integer) 0
127.0.0.1:6379> 

7.获得旧值并设置新值

127.0.0.1:6379> get key4
"value4"
127.0.0.1:6379> getset key4 kkkk
"value4"

8.截取字符并返回(getrange)

127.0.0.1:6379> get key
"pmx@qqail.com"
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> getrange key 0 2
"pmx"
127.0.0.1:6379>

9.批量返回数据(mget)

127.0.0.1:6379> mget key1 key2 kye3

10.递增/递减(incr incrby/decr decrby)

127.0.0.1:6379> incrby key 10
(integer) 11
127.0.0.1:6379> incrby key 10
(integer) 21

11.追加value & 查看字符串长度

127.0.0.1:6379> append key 10
(integer) 4
127.0.0.1:6379> get key
"2110"
127.0.0.1:6379> strlen key
(integer) 4
127.0.0.1:6379> 

2.hashes类型:

hash一个string类型的field和value的映射表。它的添加、删除操作都是O(1),特别适合存储对象。

1.设置hash field(hset)

127.0.0.1:6379> hset user:001 name pmx
(integer) 1

2.如果不存在设置(hsetnx)与setnx类似

127.0.0.1:6379> hsetnx user:001 name mm
(integer) 0
127.0.0.1:6379> hget user:001 name
"pmx"

3.批量设置多个field、得到多个field(hmset,hmget)

127.0.0.1:6379> hmset user:001 name mx age 17
OK
127.0.0.1:6379> hget user:001 name
"mx"
127.0.0.1:6379> hmget user:001 name age
1) "mx"
2) "17"

4.给指定hash field加上固定值(hincrby)

127.0.0.1:6379> hincrby user:001 age 8
(integer) 25

5.判断field是否存在(hexists)得到field个数(hlen)删除field

127.0.0.1:6379> hexists user:001 age
(integer) 1
127.0.0.1:6379> hlen user:001
(integer) 2
127.0.0.1:6379> hdel user:001 age
(integer) 1
127.0.0.1:6379> hlen user:001
(integer) 1

6.得到hash的所有 字段 & 值 &得到所有(hkeys & hvals & hgetall)

127.0.0.1:6379> hmset user:002 key1 value1 key2 value2 key3 value3
OK
127.0.0.1:6379> hkeys user:002
1) "key1"
2) "key2"
3) "key3"
127.0.0.1:6379> hvals user:002
1) "value1"
2) "value2"
3) "value3"
127.0.0.1:6379> hgetall user:002
1) "key1"
2) "value1"
3) "key2"
4) "value2"
5) "key3"
6) "value3"

3.list类型

1.左压栈(lpush)右压栈(rpush) 左出栈(lpop)右出栈(rpop)(可以作队列用)插入(linsert)

127.0.0.1:6379> lpush mystack world
(integer) 1
127.0.0.1:6379> lpush mystack hello
(integer) 2
127.0.0.1:6379> lpop mystack
"hello"
127.0.0.1:6379> lpop mystack
"world"
127.0.0.1:6379> lpush mystack hello
(integer) 1
127.0.0.1:6379> lpush mystack world
(integer) 2
127.0.0.1:6379> rpop mystack
"hello"
127.0.0.1:6379> rpop mystack
"world"
127.0.0.1:6379> lpush mystack kkkk
(integer) 1
127.0.0.1:6379> linsert mystack before kkkk jjjj
(integer) 2
127.0.0.1:6379> lrange mystack 0 -1
1) "jjjj"
2) "kkkk"
127.0.0.1:6379> 

2.设置list中指定下标的元素值(lset)(仿数组)删除(lrem)
注:lrem n value n<0时 从尾删除,n=0时全部删除

127.0.0.1:6379> lrange mystack 0 -1
1) "jjjj"
2) "kkkk"
127.0.0.1:6379> lset mystack 0 mmmm
OK
127.0.0.1:6379> lrange mystack 0 -1
1) "mmmm"
2) "kkkk"
127.0.0.1:6379> lrange mystack 0 -1
1) "one"
2) "one"
3) "one"
4) "mmmm"
5) "kkkk"
127.0.0.1:6379> lrem mystack 2 one
(integer) 2

3.保留指定key的值范围内的数据(ltrim)

127.0.0.1:6379> lrange mystack 0 -1
1) "jjjj"
2) "mmmm"
3) "kkkk"
127.0.0.1:6379> ltrim mystack 1 -1
OK
127.0.0.1:6379> lrange mystack 0 -1
1) "mmmm"
2) "kkkk"
127.0.0.1:6379> 

4.从第一个list尾部移除元素并添加第二个list的头部(rpoplpush)

127.0.0.1:6379> rpoplpush mystack mystack1
"kkkk"
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> lrange mystack 0 -1
1) "mmmm"
127.0.0.1:6379> lrange mystack1 0 -1

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

127.0.0.1:6379> lrange mystack 0 -1
1) "ssdsd"
2) "kkld"
3) "mmmm"
127.0.0.1:6379> lindex mystack 2
"mmmm"

6.返回key对应list的长度(llen)

127.0.0.1:6379> llen mystack
(integer) 3

4.sets类型

set是集合,string类型的无序集合, set是通过hash table实现的,添加、删除和查找的复杂度都是O(1)。对集合可以取并集、交集、查集。sns好友推荐取差集推荐。

1.向集合中添加元素。(sadd)查看集合元素(smembers)

127.0.0.1:6379> sadd myset one
(integer) 1
127.0.0.1:6379> sadd myset two
(integer) 1
127.0.0.1:6379> sadd myset one
(integer) 0
127.0.0.1:6379> smembers myset
1) "two"
2) "one"

2.删除集合中元素(srem)

127.0.0.1:6379> srem myset one
(integer) 1

3.随机返回并删除一个元素(spop)

127.0.0.1:6379> smembers myset
1) "two"
2) "three"
3) "one"
127.0.0.1:6379> spop myset
"one"

4.返回两个集合的差集(sdiff)以第一个为标准(可以做sns好友推荐)

127.0.0.1:6379> smembers myset
1) "two"
2) "three"
127.0.0.1:6379> smembers myset1
1) "two"
2) "lll"
3) "kkk"
127.0.0.1:6379> sdiff myset myset1
1) "three"
127.0.0.1:6379> sdiff myset1 myset2
1) "two"
2) "lll"
3) "kkk"

5.返回两个集合的差集并存储(sdiffstore)

127.0.0.1:6379> sdiffstore myset2 myset1 myset
(integer) 2

6.返回所有给定key的交集(sinter)以及存储(sinterstore)

127.0.0.1:6379> sinter myset1 myset2
1) "lll"
2) "kkk"
127.0.0.1:6379> sinter myset1 myset2 myset
(empty list or set)
127.0.0.1:6379> sinterstore myset4  myset1 myset2
(integer) 2
127.0.0.1:6379> smembers myset4
1) "lll"
2) "kkk"

7.返回所有给定key的并集(sunion)以及存储(sunionstore)

127.0.0.1:6379> sadd myset1 myset1
(integer) 1
127.0.0.1:6379> sadd myset2 myset2
(integer) 1
127.0.0.1:6379> sunionstore myset myset1 myset2
(integer) 2
127.0.0.1:6379> smembers myset
1) "myset2"
2) "myset1"
127.0.0.1:6379> 

8.从第一个key对应的set中移除member并添加到第二个set中(smove)

127.0.0.1:6379> smove myset1 myset2 myset1
(integer) 1
127.0.0.1:6379> smembers myset1
(empty list or set)
127.0.0.1:6379> smembers myset2
1) "myset2"
2) "myset1"

9.返回名称为key集合中元素的个数(scard)判断某元素是否为集合元素(sismember)

127.0.0.1:6379> scard myset
(integer) 2
127.0.0.1:6379> smembers myset
1) "myset2"
2) "myset1"
127.0.0.1:6379> sismember myset myset
(integer) 0
127.0.0.1:6379> sismember myset myset1
(integer) 1

10.随机删除名称为key的set的一个元素,不删除(srandmember)

127.0.0.1:6379> srandmember myset
"myset1"
127.0.0.1:6379> srandmember myset
"myset2"
127.0.0.1:6379> srandmember myset
"myset2"

5.有序结合(zset)

sorted set是set的一个升级版本,它在set的基础上增加了一个顺序属性,这一属性在添加元素时可以指定,每次指定后,zset会自动重新按照新的值调整顺序。

1.向有序集合中添加元素(zadd)

127.0.0.1:6379> zadd myset 1 one
(integer) 1
127.0.0.1:6379> zadd myset 2 two
(integer) 1
127.0.0.1:6379> zadd myset 3 two
(integer) 0
127.0.0.1:6379> zrange myset 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "3"
  1. 删除名称为key的zset中元素的member(zrem)
127.0.0.1:6379> zrem myset one
(integer) 1
127.0.0.1:6379> zrange myset 0 -1
1) "two"

3.如果在名称为key的zset中已经存在元素member,则该元素的score增加increment,否则向该集合中添加该元素,其score的值为increment(zincrby)

127.0.0.1:6379> zincrby myset 2 one
"4"
127.0.0.1:6379> zrange myset 0 -1 withscores
1) "two"
2) "3"
3) "one"
4) "4"
127.0.0.1:6379> zincrby myset -2 one
"2"

4.返回名称为key的zset中member元素的排名(按score从小到大排序[下标]值)(zrank)以及反转(zrevrank)降序

127.0.0.1:6379> zrange myset 0 -1 withscores
1) "one"
2) "2"
3) "two"
4) "3"
127.0.0.1:6379> zrank myset two
(integer) 1
127.0.0.1:6379> zrevrank myset one
(integer) 1
  1. zrangebyscore
127.0.0.1:6379> zrangebyscore myset 2 2 withscores
1) "one"
2) "2"

6.返回集合中score在给定区间的数量(zcount)

127.0.0.1:6379> zcount myset 2 5
(integer) 2

7.返回集合中元素个数

127.0.0.1:6379> zcount myset 2 5
(integer) 2

8.返回集合中所有元素个数(zcard)

127.0.0.1:6379> zcard myset
(integer) 2

9.删除集合中排名在给定区间的元素(zremrangebyrank)(zremrangebyscore)

127.0.0.1:6379> zrange myset 0 -1 withscores
1) "one"
2) "2"
3) "two"
4) "3"
5) "five"
6) "5"
127.0.0.1:6379> zremrangebyrank myset 2 2
(integer) 1
127.0.0.1:6379> zrange myset 0 -1
1) "one"
2) "two"
127.0.0.1:6379> zremrangebyscore myset 2 2
(integer) 1
127.0.0.1:6379> zrange myset 0 -1
1) "two"

键值相关命令:

1.keys * 得到所有键

2.exists 是否存在键

3.del 删除key

  1. expire 设置一个key过期时间(ttl查看过期时间)移除key的过期时间(persist)
127.0.0.1:6379> set age 20
OK
127.0.0.1:6379> 
127.0.0.1:6379> expire age 10
(integer) 1
127.0.0.1:6379> ttl age
(integer) 8
127.0.0.1:6379> ttl age
(integer) -2
127.0.0.1:6379> get age
(nil)
127.0.0.1:6379[1]> set age 20
OK
127.0.0.1:6379[1]> expire age 20
(integer) 1
127.0.0.1:6379[1]> persist age
(integer) 1

5.移动数据库

127.0.0.1:6379> select 0
OK
127.0.0.1:6379> set age 20
OK
127.0.0.1:6379> get age
"20"
127.0.0.1:6379> move age 1
(integer) 1
127.0.0.1:6379> get age
(nil)
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> get age
"20"

6.随机返回一个key(randomkey)

127.0.0.1:6379> randomkey
"posts:count"
127.0.0.1:6379> randomkey
"post:43"
127.0.0.1:6379> randomkey
"post:content"

7.重命名key(rename )

127.0.0.1:6379> rename key2 key_new
OK

8.返回值的类型(type)

127.0.0.1:6379> type post
string
127.0.0.1:6379> type car
hash
127.0.0.1:6379> type list
none
127.0.0.1:6379> type myset
zset
127.0.0.1:6379> type mylist
list

9.测试服务是否存活 (ping) 打印显示 (echo)退出(quit)

127.0.0.1:6379> ping
PONG

10.返回当前数据库中key的数目(dbsize)服务器信息(info)

127.0.0.1:6379> dbsize
(integer) 22
127.0.0.1:6379> info
# Server
redis_version:3.0.0
redis_git_sha1:00000000
redis_git_dirty:0
redis_build_id:3946449f969be394
redis_mode:standalone

11.实时存储收到的请求(config get [*] )

12.删除当前选择数据库中的所有key(flushdb)

13.清除所有数据库所有key(flushall)

redis高级应用

1.安全性(设置连接密码,尽量复杂,放置暴力破解,[每分钟可达到150w次密码尝试])
1.在redis.conf中设置requirepass 123456
2.redis-cli 中连接1. ./redis-cli -a 123456 2. ./redis-cli –>auth

2.主从复制
1.redis主从复制特点
1.Master可以复制多个slave
2.多个slave可以连接同一个master,还可以连接其他slave
3.主从复制不会阻塞master,在同步数据时,master可以继续处理client。
4.提高系统的伸展性
2.配置主从服务器:
1.在slave中redis.conf开启slaveof 192.168.1.1 6379
2.masterauth 123456
3.info 查看主从(role)
3. 事务处理(multi)不回滚
1.开启事务multi
2.取消事务discard
[注]乐观锁:大多数是基于数据版本的记录机制实现的。即为数据增加一个版本标识,在基于数据库表的版本解决方案中,一般是通过为数据库表添加一个version字段来实现读取数据时,将此版本号一同读出,之后更新时,对此版本号加1。此时,将提交数据的版本号与数据库表对应纪录的当前版本号进行比对,如果提交的数据版本号大于数据库当前版本号,则予以更新,否则认为过期数据。[版本控制器]

3.持久化机制
redis是一个支持持久化的内存数据库,redis需要经常讲内存中的数据库同步到硬盘来保持持久化。
redis持久化有两种:

1.snapshootting(快照,默认dump.rdb,数据)
save 900 1 #900秒如果超过1个key被修改,发起快照保存
save 300 10 #300秒内容如超过10个key被修改,发起保存快照
2.append-only file(缩写aof,操作)

    appendonly yes//启用aof模式
    #appendfsync always //收到写命令立即写入磁盘,完全持久话 
    appendonly everysec//每秒写入磁盘一次,在性能上折中
    #appendfsync no//依赖os 性能最好,持久化没保证

3.发布与订阅消息(publish & subscribe)

client 1
127.0.0.1:6379> subscribe tv1
client 2
127.0.0.1:6379> subscribe tv1

client 3
127.0.0.1:6379> publish tv1 qwe
(integer) 2

127.0.0.1:6379> subscribe tv1
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "tv1"
3) (integer) 1
1) "message"
2) "tv1"
3) "qwe"

4.虚拟内存的使用
redis的虚拟内存和操作系统虚拟内存不一样,是把不经常访问的数据从内存交换到磁盘中,从而腾出宝贵的内存空间用于其他需要访问的数据。

1.配置
vm-enabled yes #开启vm功能
vm-swap-file /tmp/redis.swap #交换出来的value保存文件路径
vm-max-memory 100000 #redis使用最大内存上线
vm-page-size 32 #每个页面大小32字节
vm-pages 134217728 #最多使用多少页面
vm-max-threads 4 #用于执行value对象换入的工作线程数量

really-use-vm yes

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值