zoukankan      html  css  js  c++  java
  • Redis学习记录(二)

    1.Key命令

    设置key的过期时间。

    expire key second:设置key的过期时间

    ttl key:查看key的有效期(如果显示正数说明该key正在倒计时,如果是-1说明该key永久保存,是持久化的,如果是-2该key不存在)

    persist key:清除key的过期时间。key持久化

    使用场景:电商活动有时间限制

    2.Redis的持久化方案

    redis的所有数据都是保存到内存中。

    Rdb:快照形式,定期把内存中当前时刻的数据保存到磁盘。redis默认支持到持久化方案。

    aof形式:append only file。把所有对redis数据库操作的命令,增删改操作的命令。保存到文件中。数据库恢复时把所有的命令执行一遍即可。

    redis.conf配置文件中配置。

    Rdb

    Aof的配置:

    两种持久化方案同时开启使用aof文件来恢复数据库。但是开启redis持久化。会影响redis数据库性能,所以一般默认不开启持久化

    3.Redis的特性

    3.1 多数据库

    一个redis实例可以包含多个数据库,客户端可以指定连接某个redis实例的哪个数据库,就如同一个mysql中创建了多个数据库,客户端连接时指定连接哪个数据库。

    可以根据redis的图形化界面,看到一个redis实例最多提供16个数据库,下表从0到15,客户端默认链接第0号数据库,也可以通过select选择链接那个数据库:

    以下是连接库的命令

    连接1号库:

    连接2号库

    将key一直到1号库:

    3.2 消息订阅与发布

    (1) subscribe channel:订阅频道,例:subscribe mychat,订阅mychat这个频道

    (2) psubscribe channel*:批量订阅频道,例:psubscribe s*,订阅以"s"开头的频道

    (3) publish channel content:在指定的频道中发布消息,例:publish mychat 'today is a newday'

    步骤:

    (1) 在第一个连接中,订阅cctv频道。此时如果没有人"发布"消息,当前窗口处于等待状态

    (2) 在另个连接窗口中,在cctv频道中发布消息(这种消息订阅与发布的实时性很强)

    3.3 redis事务

    命令解释:

    (1)multi:开启事务用于标记事务的开始,其后执行的命令都将被存入命令队列,直到执行exec时,这些命令才会被原子的执行,类似于关系型数据库中的:begin transaction

    (2)exec:提交事务,类似于关系型数据库中commit

    (3)discard:事务回滚,类似与关系型数据中的rollback

  • 相关阅读:
    2-7
    2-6
    2-5
    2-4
    2-3
    2-1
    2-2
    1-1
    5-7
    第六章例6-1
  • 原文地址:https://www.cnblogs.com/FanJava/p/9641721.html
Copyright © 2011-2022 走看看