zoukankan      html  css  js  c++  java
  • Redis入门

    简介:Redis是一个高性能的Key-Value数据库,redis开源,属于内存数据库,它可以用作数据库、缓存和消息中间件,它支持多种类型的数据结构,如字符串,哈希,列表,集合,有序集合等。 

    1、安装

      1.1 命令行安装

        `sudo apt install redis-server`

      1.2 命令说明

        `redis-server`  redis服务器

        `redis-cli`  redis命令行客户端

        `redis-benchmark`  redis性能测试工具

        `redis-check-aof`  AOF文件修复工具

        `redis-check-rdb`  RDB文件检索工具

    2、配置

      2.1 配置存放位置

        `/etc/redis/redis.conf`

      2.2 核心配置选项

        (1)绑定ip:如果需要远程访问,可将此行`bind 127.0.0.1`注释,或绑定一个真实ip

        (2)端口,默认为6379

        (3)是否以守护进程运行`daemonize yes`

          1)如果以守护进程运行,则不会在命令行阻塞,类似于服务

          2)如果以非守护进程运行,则当前终端将被阻塞

          3)设置为yes表示守护进程运行,设置为no表示非守护进程

          4)推荐设置为yes

        (4)数据文件`dbfilename dump.rdb`

        (5)数据文件存储路径`dir /var/lib/redis`

        (6)日志文件`logfile /var/log/redis/redis-server.log`

        (7)数据库,默认有16个`database 16`

        (8)主从复制,类似于双机备份`slaveof`

      2.3 参考

        https://blog.csdn.net/ljphilp/article/details/52934933

    3、客户端和服务端命令

      3.1 客户端命令

        (1)客户端的命令为`redis-cli`

        (2)可以使用help查看帮助文档`redis-cli --help`

        (3)数据库没有名称,默认有16个,通过0-15来表示,连接redis默认选择第一个数据库`select n`

      3.2 服务端命令

        (1)服务端的命令为`redis-server`

        (2)可以使用help查看帮助文档`redis-server --help`

        (3)启动`sudo service redis-server start`

        (4)停止`sudo service redis-server stop`

        (5)重启`sudo service redis restart`

        (6)查看redis服务器进程`ps -ef | grep redis`

        (7)杀死redis服务器`sudo kill -9 pid`

        (8)指定加载的配置文件`sudo redis-server /etc/redis/redis.conf`

    4、数据操作

      数据结构:(1)redis是key-value的数据结构,每条数据都是一个键值对

           (2)键的类型是字符串

           (3)键不能重复

      值的类型分为五种:(1)字符串string(2)哈希hash(3)列表list(4)集合set(5)有序集合zset

      数据操作行为:(1)保存(2)修改(3)获取(4)删除

      官方中文文档:http://redis.cn/documentation.html

      4.1 string类型

        字符串类型是redis中最为基础的数据存储类型,它在redis中是二进制安全的,这说明string类型可以接受任何格式的数据,如jepg图像数据或json对象描述信息。

        在redis中字符串类型的value最多可容纳的数据长度是512M。

        4.1.1 保存

          如果设置的键不存在则为添加,如果设置的键已经存在则修改

          (1)设置键值`set key value`

          (2)获取键值`get key`

          (3)设置键值及过期时间,以秒为单位`setex key seconds value`

            例如设置a的值为2,过期时间为4秒`setex a 4 2`

          (4)设置多个键值`mset key1 value1 key2 value2...`

          (5)追加值`append key value`

            

        4.1.2 获取

          (1)获取:根据键获取值`get key`,如果不存在此键则返回`nil`

          (2)根据多个键获取多个值:`mget key1 key2`

        4.1.3 删除

          (1)删除键时会将值删除:`del key`

      4.2 键命令

        查找键,参数支持正则表达式

          语法:`keys pattern`

          (1)查看所有键:`keys *`

          (2)查看名称中包含a的键:`keys a*`

          (3)判断键是否存在,如果存在返回1,不存在返回0:`exists key`

          (4)查看键对应的value的类型:`type key`

          (5)删除键及对应的值:`del key1 key2`

          (6)设置过期时间,以秒为单位,如果没有指定过期时间则一直存在,直到使用DEL移除

            `expire key seconds`

          (7)查看 有效时间,以秒为单位

            `ttl key`

      4.3 hash类型

        (1)hash用于存储对象,对象的结构为属性、值

        (2)值的类型为string

        4.3.1 增加、修改

          (1)设置单个属性:`hset key field value`

          (2)设置多个属性:`hmset key field1 value1 field value2 ...`

        4.3.2 获取

          (1)获取指定键所有的属性:`hkeys key`

          (2)获取一个属性的值:`hget key field`

          (3)获取多个属性的值:`hmget key field1 field2...`

          (4)获取所有属性的值:`hvals key`

        4.3.3 删除

          (1)删除整个hash键及值,使用del命令

          (2)删除属性,属性对应的值会被一起删除:`hdel key field1 field2...`

      4.4 list类型

        (1)列表的元素类型为string

        (2)按照插入顺序排序

        4.4.1 增加

          (1)在左侧插入数据:`lpush key value1 value2...`

          (2)在右侧插入数据:`rpush key value1 value2...`

          (3)在指定元素的前或后插入新元素:`linsert key before或after 现有元素 新元素`

        4.4.2 获取

          返回列表里指定范围内的元素

          (1)start、stop为元素的下表索引

          (2)索引从左侧开始,第一个元素为0

          (3)索引可以是负数,表示从尾部开始计数,如-1表示最后一个元素

          语法:`lrange key start stop`

        4.4.3 设置指定索引位置的元素值

          (1)索引从左侧开始,第一个元素为0

          (2)索引可以是负数,表示尾部开始计数,如-1表示最后一个元素

          语法:`lset key index value`

        4.4.4 删除

          删除指定元素

          (1)将列表中前count次出现的值为value的元素移除

          (2)count>0:从头往尾移除

          (3)count<0:从尾往头移除

          (4)count=0:移除所有

          语法:`lrem key count value`

      4.5 set类型

        (1)无序集合

        (2)元素为string类型

        (3)元素具有唯一性,不重复

        (4)说明:对于集合没有修改操作

        4.5.1 增加

          (1)添加元素:`sadd key member1 member2...`

        4.5.2 获取

          (1)返回所有的元素:`smembers key`

        4.5.3 删除

          (1)删除指定元素:`srem key member`

      4.6 zset类型

        (1)sorted set,有序集合

        (2)元素为string 类型

        (3)元素具有唯一性,不重复

        (4)每个元素都会关联一个double类型的score,表示权重,通过权重将元素从小到大排序

        (5)说明:没有修改操作

        4.6.1 增加

          语法:`zadd key score1 member1 score2 member2...`

        4.6.2 获取

          (1)返回指定范围内的元素

          (2)start、stop为元素的下标索引

          (3)索引从左侧开始,第一个元素为0

          (4)索引可以是负数,表示从尾部开始计数,如-1表示最后一个元素

          语法:`zrange key start stop`

          <1> 返回score值在min和max之间的成员:`zrangebyscore key min max`

          <2> 返回成员member的score值:`zscore key member`

        4.6.3 删除

          (1)删除指定元素:`zrem key member1 member2...`

          (2)删除权重在指定范围的元素:`zremrangebyscore key min max`

    5、与python交互

      引入模块:`from redis import *`

      这个模块中提供了StrictRedis对象(Strict严格),⽤于连接redis服务器,并按照不同类型提供 了不同⽅法,进⾏交互操作

      5.1 方法

        5.1.1 StrictRedis对象方法

          通过init创建对象,指定参数host、port与指定的服务器和端⼝连接,host默认为localhost,port默认为6379,db默认为0

          `sr = StrictRedis(host='localhost',prot=6379,db=0)`

          简写为:

          `sr = StrictRedis()`

        5.1.2 string的方法

          (1)set(2)setex(3)mset(4)append(5)get(6)mget

        5.1.3 keys的方法

          (1)exists(2)type)(3)delete(4)expire(5)getrange(6)ttl

        5.1.4 hash的方法

          (1)hset(2)hmset(3)hkeys(4)hget(5)hmget(6)hvals(7)hdel

        5.1.5 list的方法

          (1)lpush(2)rpush(3)linsert(4)lrange(5)lset(6)lrem

        5.1.6 set的方法

          (1)sadd(2)smembers(3)srem

        5.1.7 zset的方法

          (1)zadd(2)zrange(3)zrangebyscore(4)zscore(5)zrem(6)zremrangebyscore

      5.2 与python交互   

    # 导入包
    from redis import *
    # 创建一个StrictRedis对象
    sr = StricRedis(host="localhost",prot=6379,db=0)
    
    # 操作
    
    #⽅法set,添加键、值,如果添加成功则返回True,如果添加失败则返回False
    result = sr.set("name","python")
    
    # ⽅法get,添加键对应的值,如果键存在则返回对应的值,如果键不存在则返回None
    result = sr.get("name")
    
    #⽅法set,如果键已经存在则进⾏修改,如果键不存在则进⾏添加
    result = sr.set("name","it")
    
    #⽅法delete,删除键及对应的值,如果删除成功则返回受影响的键数,否则则返 回0
    result = sr.delete("name)
    
    #⽅法keys,根据正则表达式获取键
    result = sr.keys()

    6、搭配主从

      6.1 主从概念

        (1)⼀个master可以拥有多个slave,⼀个slave⼜可以拥有多个slave,如此下去,形成了强⼤的多级服务器集群架构

        (2)master用来写数据,slave用来读数据

        (3)通过主从配置可以实现读写分离

        (4)master和slave都是一个redis实例(redis服务)

        

       6.2 主从配置

        6.2.1 配置主

          (1)查看当前主机的ip:`ifconfig`

          (2)修改`etc/redis/redis.conf`文件

            `sudo vim /etc/redis/redis.conf`

            

           (3)重启redis服务

            `sudo service redis-server stop`

            `sudo redis-server redis.conf` #进去redis.conf文件目录输入这条命令

          (4)查看服务启动消息

            `ps aux | grep redis`

        6.2.2 配置从

          (1)复制`/etc/redis/redis.conf`文件

            `sudo cp redis.conf ./slave_redis.conf`

          (2)修改redis/slave_redis.conf文件

            (1)`修改绑定的ip号: bind 192.168.0.105` # 可以绑定本机,绑定本机时从不能和主有相同端口号

            (2)`修改port: port 6378` #本机默认端口号为6379,注意不能重复

            (3)默认注释slaveof,需要按照格式重写slaveof

                

           (3)启动从的服务

            `sudo redis-server /etc/redis/slave_redis.conf`

           (4)查看redis启动的所有服务

            `ps aux | grep redis`

            

           (5)查看主从关系

            `redis-cli -h 192.168.0.105 info Replication`

            

         6.2.3 数据操作

          (1)在master和slave终端下分别执行info命令

            `redis-cli -h 192.168.0.105 -p 6379`

            `redis-cli -h 192.168.0.105 -p 6379`

          (2)在master终端中写入`set a python`

            

          (3)在slave终端中读数据`get a`

             

    7、搭建集群

      集群的概念

      集群是一组互相独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。一个客户端与集群相互作用时,集群就像是一个独立的服务器。集群配置用于提高可用性和可缩放性。

      

       当请求到来时,首先由负载均衡服务器处理,把请求转发到另外的一台服务器上。

      redis集群

      分类:(1)软件层面(2)硬件层面

      软件层面:只有一台电脑,在这一台电脑上启动了多个redis服务。

      

       硬件层面:存在多台实体的电脑,每台电脑上都启动了一个redis或者多个redis服务。

      

       参考阅读:https://www.cnblogs.com/wuxl360/p/5920330.html

      7.1 配置主服务器

        当前ubuntu机器的ip为:192.168.0.103

        在桌面创建conf文件夹,进入并创建文件7000.conf、7001.conf、7002.conf,三个文件的配置区别在port、pidfile、cluster-config-file三项。

        (1)编辑7000.conf的内容为

    port 7000
    bind 192.168.0.103
    daemonize yes
    pidfile 7000.pid
    cluster-enabled yes
    cluster-config-file 7000_node.conf
    cluster-node-timeout 15000
    appendonly yes

        (2)编辑7001.conf的内容为

    port 7001
    bind 192.168.0.103
    daemonize yes
    pidfile 7001.pid
    cluster-enabled yes
    cluster-config-file 7001_node.conf
    cluster-node-timeout 15000
    appendonly yes

        (3)编辑7002.conf的内容为

    port 7002
    bind 192.168.0.103  
    daemonize yes
    pidfile 7002.pid
    cluster-enabled yes
    cluster-config-file 7002_node.conf
    cluster-node-timeout 15000
    appendonly yes

        (4)使用配置文件启动redis服务

    redis-server 7000.conf
    redis-server 7001.conf
    redis-server 7002.conf

        (5)查看进程

         

       7.2 配置从服务器  

        当前ubuntu机器的ip为:192.168.0.100

        在桌面创建conf文件夹,进入并创建文件7003.conf、7004.conf、7005.conf,三个文件的配置区别在port、pidfile、cluster-config-file三项。

        (1)编辑7003.conf的内容为

    port 7003
    bind 192.168.0.100
    daemonize yes
    pidfile 7003.pid
    cluster-enabled yes
    cluster-config-file 7003_node.conf
    cluster-node-timeout 15000
    appendonly yes

        (2)编辑7004.conf的内容为

    port 7004
    bind 192.168.0.100
    daemonize yes
    pidfile 7004.pid
    cluster-enabled yes
    cluster-config-file 7004_node.conf
    cluster-node-timeout 15000
    appendonly yes

        (3)编辑7005.conf的内容为

    port 7005
    bind 192.168.0.100  
    daemonize yes
    pidfile 7005.pid
    cluster-enabled yes
    cluster-config-file 7005_node.conf
    cluster-node-timeout 15000
    appendonly yes

        (4)使用配置文件启动redis服务

    redis-server 7003.conf
    redis-server 7004.conf
    redis-server 7005.conf

        (5)查看进程

          

      7.3 说明

        参考>>>6.2

      7.4 创建集群

        redis的安装包中包含了redis-trib.rb,用于创建集群

        在主服务器(192.168.0.103)上执行命令:

        (1)复制redis-trib.rb命令到/usr/local/bin/以便在任何目录下都可以调用此命令

          `sudo cp /usr/share/doc/redis-tools/examples/redis-trib.rb /usr/local/bin/`

        (2)安装ruby环境,redis-trib.rb由ruby开发,运行时需要ruby的支持

          `sudo apt-get install ruby`

        (3)升级ruby,防止版本过旧无法创建集群

          `gem source -l # 查看gem源地址`

          `gem sources --add https://gems.ruby-china.org/ --remove https://rubygems.org/  # 更换源`

          `sudo gem install redis  # 通过gem安装redis的相关依赖,并升级ruby`

        (4)执行redis-trib.rb命令创建集群

          ` redis-trib.rb create --replicas 1 192.168.0.103:7000 192.168.0.103:7001 192.168.0.103:7002 192.168.0.100:7003 192.168.0.100:7004 192.168.0.100:7005`

        (5)创建时的命令流

          

           集群搭建成功

      7.5 数据验证

        

        当前搭建的主服务器为7000、7001、7003,对应的从服务器是7005、7004、7002

        在192.168.0.100上连接7002,加参数-c表示连接到集群

        `redis-cli -h 192.168.0.100 -c -p 7002`

        

         当写入数据时,会自动跳转到响应的服务器,并写入数据成功。

      7.6 在服务器上写入数据的规则

        (1)redis cluster在设计的时候,就考虑到了去中⼼化,去中间件,也就是说,集群中的每个节点都是平等的关系,都是对等的,每个节点都保存各⾃的数据和整个集 群的状态。每个节点都和其他所有节点连接,⽽且这些连接保持活跃,这样就保证了我们只需要连接集群中的任意⼀个节点,就可以获取到其他节点的数据

        (2)Redis集群没有并使⽤传统的⼀致性哈希来分配数据,⽽是采⽤另外⼀种叫做哈希槽 (hash slot)的⽅式来分配的。redis cluster 默认分配了 16384 个slot,当我们 set⼀个key 时,会⽤CRC16算法来取模得到所属的slot,然后将这个key 分到哈希槽区间的节点上,具体算法就是:CRC16(key) % 16384。所以我们在测试的时候看到set和get 的时候,直接跳转到了7000端⼝的节点

        (3)Redis 集群会把数据存在⼀个 master 节点,然后在这个 master 和其对应的salve 之间进⾏数据同步。当读取数据时,也根据⼀致性哈希算法到对应的 master 节点获取数据。只有当⼀个master 挂掉之后,才会启动⼀个对应的 salve 节点,充当 master

        (4)需要注意的是:必须要3个或以上的主节点,否则在创建集群时会失败,并且当存活的主节点数⼩于总节点数的⼀半时,整个集群就⽆法提供服务了。

      7.7 与python的交互

        (1)安装包`pip install redis-py-cluster`

        (2)示例文件如下: 

    from rediscluster import *
    if __name__ == '__main__':
      try:
          # 构建所有的节点,Redis会使⽤CRC16算法,将键和值写到某个节点上
          startup_nodes = [
              {'host': '192.192.0.103', 'port': '7000'},
              {'host': '192.168.0.100', 'port': '7003'},
              {'host': '192.168.0.103', 'port': '7001'},
          ]
          # 构建RedisCluster对象
          src=RedisCluster(startup_nodes=startup_nodes,decode_responses=True)
          # 设置键为name、值为python的数据
          result=src.set('name','python')
          print(result)
          # 获取键为name
          name = src.get('name')
          print(name)
      except Exception as e:
          print(e)

     

          

      

  • 相关阅读:
    matplotlib添加坐标轴实现性格测试可视化
    一段代码实现Aplayer+网易云音乐接口
    cnblogs在手机端显示的一些坑
    【转】 最全的MySQL基础【燕十八传世】
    【转】 MySQL基础知识
    【转】 SSM整合
    【转】 Mybatis学习笔记-狂神版
    【转】 SpringMVC学习笔记
    【转】 mybatis 详解(十一)------ mybatis和spring整合
    【转】 mybatis 详解(十)------ 逆向工程
  • 原文地址:https://www.cnblogs.com/nuochengze/p/12835560.html
Copyright © 2011-2022 走看看