Redis

  1. Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,官方提供测试数据,50个并发执行100000个请求,读的速度是110000次/s,写的速度是81000次/s ,且Redis通过提供多种键值数据类型来适应不同场景下的存储需求。

  • 目前为止Redis支持的键值数据类型如下:
  1. 字符串类型 string
  2. 哈希类型 hash
  3. 列表类型 list
  4. 集合类型 set
  5. 有序集合类型 sortedset

  1. redis的应用场景
  • 缓存(数据查询、短连接、新闻内容、商品内容等等)
  • 聊天室的在线好友列表
  • 任务队列。(秒杀、抢购、12306等等)
  • 应用排行榜
  • 网站访问统计
  • 数据过期处理(可以精确到毫秒
  • 分布式集群架构中的session分离



命令操作

  1. redis的数据结构:
  • redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构
    • value的数据结构:
    1. 字符串类型 string
    2. 哈希类型 hash
    3. 列表类型 list
    4. 集合类型 set
    5. 有序集合类型 sortedset

字符串类型 string
  1. 存储: set key value
    set username zhangsan

  2. 获取: get key
    get username

  3. 删除: del key
    del username

哈希类型 hash
  1. 存储: hset key field value
    hset myhash username lisi

    hset myhash password 123

  2. 获取:
  • hget key field: 获取指定的field对应的值
    hget myhash username   -->   "lisi"
  • hgetall key:获取所有的field和value
    hgetall myhash
1) "username"
2) "lisi"
3) "password"
4) "123"
  1. 删除: hdel key field
    hdel myhash username

列表类型 list
  • 可以添加一个元素到列表的头部(左边)或者尾部(右边)
  1. 添加:

    1. lpush key value: 将元素加入列表左表
      lpush myList a

      lpush myList b
    2. rpush key value:将元素加入列表右边
      rpush myList c
  2. 获取:
    lrange key start end :范围获取
    lrange myList 0 -1

1) "b"
2) "a"
3) "c"
  1. 删除:
    lpop key: 删除列表最左边的元素,并将元素返回

    rpop key: 删除列表最右边的元素,并将元素返回

集合类型 set : 不允许重复元素
  1. 存储:sadd key value
    sadd myset a

  2. 获取:smembers key:获取set集合中所有元素
    smembers myset

  3. 删除:srem key value:删除set集合中的某个元素
    srem myset a

有序集合类型 sortedset:
  • 不允许重复元素,且元素有顺序.每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
  1. 存储:zadd key score value
    zadd mysort 60 zhangsan

    zadd mysort 50 lisi

    zadd mysort 80 wangwu

  2. 获取:zrange key start end [withscores]

  • 不加[withscores]
    zrange mysort 0 -1
1) "lisi"
2) "zhangsan"
3) "wangwu"
  • 加上[withscores]
    zrange mysort 0 -1 withscores
1) "zhangsan"
2) "60"
3) "wangwu"
4) "80"
5) "lisi"
6) "500"
  1. 删除:zrem key value
    zrem mysort lisi

通用命令
  1. keys * : 查询所有的键
  2. type key : 获取键对应的value的类型
  3. del key:删除指定的key value

持久化

  1. redis是一个内存数据库,当redis服务器重启,获取电脑重启,数据会丢失,我们可以将redis内存中的数据持久化保存到硬盘的文件中。

  2. redis持久化机制:

    1. RDB: 默认方式:在一定的间隔时间中,检测key的变化情况,然后持久化数据
    	#编辑redis.windwos.conf文件可以进行参数配置
    	
    	#   after 900 sec (15 min) if at least 1 key changed
    		save 900 1
    		
    	#   after 300 sec (5 min) if at least 10 keys changed
    		save 300 10
    		
    	#   after 60 sec if at least 10000 keys changed
    		save 60 10000
    

    要使得配置生效: 需重新启动redis服务器,并打开CMD输入下列指令,指定配置文件名称

    redis安装路径>redis-server.exe redis.windows.conf



    1. AOF: 日志记录的方式,可以记录每一条命令的操作。可以每一次命令操作后,持久化数据
    1. 编辑redis.windwos.conf文件
    appendonly no(关闭aof) --> appendonly yes (开启aof)
    				
    # appendfsync always : 每一次操作都进行持久化
    
    appendfsync everysec : 每隔一秒进行一次持久化
    
    # appendfsync no	 : 不进行持久化
    
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值