zoukankan      html  css  js  c++  java
  • Redis的配置与数据类型

    redis

    window系统的redis是微软团队根据官方的linux版本高仿的

    官方原版: https://redis.io/

    中文官网:http://www.redis.cn

    1. redis下载和安装

    1.1 Linux安装redis

    1.yum安装

    # 安装redis
    yum install redis -y
    # 安装好,启动redis
    systemctl start redis
    redis-cli    # redis 客户端工具
    # 进入交互式环境后,执行ping,返回pong表示安装成功
    127.0.0.1:6379> ping
    PONG
    

    2.源码编译安装

    1.下载redis源码
    wget http://download.redis.io/releases/redis-4.0.10.tar.gz
    2.解压缩
    tar -zxf redis-4.0.10.tar.gz
    3.切换redis源码目录
    cd redis-4.0.10.tar.gz
    4.编译源文件
    make 
    5.编译好后,src/目录下有编译好的redis指令
    6.make install 安装到指定目录,默认在/usr/local/bin
    

    3.redis的可执行文件

    ./redis-benchmark  //用于进行redis性能测试的工具
    ./redis-check-dump //用于修复出问题的dump.rdb文件
    ./redis-cli        //redis的客户端
    ./redis-server     //redis的服务端
    ./redis-check-aof  //用于修复出问题的AOF文件
    ./redis-sentinel   //用于集群管理
    

    1.2 Windows安装redis

    下载地址: https://github.com/MicrosoftArchive/redis/releases

    使用以下命令启动redis服务端

    redis-server C:/tool/redis/redis.windows.conf
    

    关闭上面这个cmd窗口就关闭redis服务器服务了。

    redis作为windows服务启动方式

    redis-server --service-install redis.windows.conf
    

    启动服务:redis-server --service-start
    停止服务:redis-server --service-stop

    启动内置客户端连接redis服务:

    2. redis的配置

    redis 安装成功以后,window下的配置文件保存在软件 安装目录下,如果是mac或者linux,yum则默认安装/etc/redis/redis.conf

    此配置文件可以自定义

    2.1 redis的核心配置选项

    • 绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip

      bind 127.0.0.1

    • 端⼝,默认为6379

      port 6379

    • 是否以守护进程运⾏[这里的配置主要是linux和mac下面需要配置的]

      • 如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
      • 如果以⾮守护进程运⾏,则当前终端被阻塞
      • 设置为yes表示守护进程,设置为no表示⾮守护进程
      • 推荐设置为yes

      daemonize yes

    • 数据⽂件

      dbfilename dump.rdb

    • 数据⽂件存储路径

      dir /var/lib/redis/

    • ⽇志⽂件

      logfile /var/log/redis/redis-server.log

    • 数据库,默认有16个

      database 16

    • 主从复制,类似于双机备份。

      slaveof

    2.2 Redis的使用

    Redis 是一个高性能的key-value数据格式的内存缓存,NoSQL数据库。

    NOSQL:not only sql,泛指非关系型数据库。

    关系型数据库: (mysql, oracle, sql server, sqlite)

    1. 数据存放在表中,表之间有关系。
    2. 通用的SQL操作语言。
    3. 大部分支持事务。
    

    非关系型数据库[ redis,hadoop,mangoDB]:

    1. 没有数据表的概念,不同的nosql数据库存放数据位置不同。
    2. nosql数据库没有通用的操作语言。
    3. 基本不支持事务。   redis支持简单事务
    

    redis:
    内存型(数据存放在内存中)的非关系型(nosql)key-value(键值存储)数据库,
    支持数据的持久化(注: 数据持久化时将数据存放到文件中,每次启动redis之后会先将文
    件中数据加载到内存),经常用来做缓存(用来缓存一些经常用到的数据,提高读写速度)。

    redis是一款基于CS架构的数据库,所以redis有客户端,也有服务端。

    其中,客户端可以使用python等编程语言,也可以终端命令行工具

    redis客户端连接服务器:

    redis-cli -h `redis服务器ip` -p `redis服务器port`
    

    2.3 更改默认端口,并且使用redis密码登录

    redis没有用户概念,redis只有密码
    redis默认在工作在保护模式下。不允许远程任何用户登录(protected-mode)

    redis.conf设置

    protected-mode yes   #打开保护模式
    port 6380            #更改默认启动端口
    requirepass xxxxxx   #设置redis启动密码,xxxx是自定义的密码
    

    启动redis服务端

    redis-server /opt/redis-4.0.10/redis.conf
    # 指定配置文件启动redis
    

    使用密码登录redis,使用6380端口

    方法1,

    [root@linux ~ 09:48:41]# redis-cli -p 6380
    127.0.0.1:6380> auth xxxx
    OK
    

    方法2,此方案不安全,容易暴露密码

    [root@linux ~ 09:49:46]# redis-cli -p 6380 -a xxxx
    Warning: Using a password with '-a' option on the command line interface may not be safe.
    127.0.0.1:6380> ping
    PONG
    

    检查redis是否设置了密码

    127.0.0.1:6380> CONFIG get requirepass
    1) "requirepass"
    2) "xxxxxx"
    

    如果没有,也可以给redis设置密码(命令方式)

    CONFIG set requirepass "xxxxxx"
    

    3. redis数据类型

    1. string类型:
    	字符串类型是 Redis 中最为基础的数据存储类型,它在 Redis 中是二进制安全的,也就是byte类型
    	最大容量是512M。
    2. hash类型:
    		hash用于存储对象,对象的结构为属性、值,值的类型为string。
    		key:{
                域:值[这里的值只能是字符串],
                域:值,            
                域:值,
                域:值,
                ...
    		}
    3. list类型:
    		列表的元素类型为string。
    		key:[ 值1,值2,值3..... ]
    4. set类型:
    	无序集合,元素为string类型,元素唯一不重复,没有修改操作。
    	{值1,值4,值3,值5}
    5. zset类型:
    	有序集合,元素为string类型,元素唯一不重复,没有修改操作。
    

    3.1 string

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

    • 设置键值

      set key value

    • 例1:设置键为name值为xiaoming的数据

      set name xiaoming

    1553478355927

    • 设置键值及过期时间,以秒为单位

      setex key seconds value

    • 例2:设置键为aa值为aa过期时间为3秒的数据

      setex name 20 xiaoming

    关于设置保存数据的有效期

    # setex 添加保存数据到redis,同时设置有效期
    格式:
    	setex key time value
    # expire 给已有的数据重新设置有效期
    格式:
    	expire key time
    
    • 设置多个键值

      mset key1 value1 key2 value2 ...

    • 例3:设置键为a1值为python、键为a2值为java、键为a3值为c

      mset a1 python a2 java a3 c

    • 追加值

      append key value

    • 例4:向键为a1中追加值haha

      append a1 haha

    • 获取:根据键获取值,如果不存在此键则返回nil

      get key

    • 例5:获取键name的值

      get name

    • 根据多个键获取多个值

      mget key1 key2 ...

    • 例6:获取键a1、a2、a3的值

      mget a1 a2 a3

    • 自增自减:针对一个字符串是数值,可以通过命令快速+1或者-1

      incr key 自增+1

      decr key 自减-1

    • 示例:

      set num 10

      incr num

      结果 11

      incr num

      结果 12

      decr num

      结果 11

      decr num

      结果 10

    3.2 键操作

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

      keys pattern

    • 例1:查看所有键

      keys *

    • 例2:查看名称中包含a的键

      keys a*

    • 判断键是否存在,如果存在返回1,不存在返回0

      exists key1

    • 例3:判断键a1是否存在

      exists a1

    • 查看键对应的value的类型

      type key

    • 例4:查看键a1的值类型,为redis⽀持的五种类型中的⼀种

      type a1

    • 删除键及对应的值

      del key1 key2 ...

    • 例5:删除键a2、a3

      del a2 a3

    • 查看有效时间,以秒为单位

      ttl key

    • 例7:查看键bb的有效时间

      ttl bb

    3.3 hash

    结构:

    键key:{
       	域field:值value
    }
    
    • 设置单个属性

      hset key field value

    • 例1:设置键 user的属性namexiaohong

      hset user name xiaohong

    • 设置多个属性

      hmset key field1 value1 field2 value2 ...

    • 例2:设置键u2的属性namexiaohong、属性age11

      hmset u2 name xiaohongage 11

    • 获取指定键所有的属性

      hkeys key

    • 例3:获取键u2的所有属性

      hkeys u2

    • 获取⼀个属性的值

      hget key field

    • 例4:获取键u2属性name的值

      hget u2 name

    • 获取多个属性的值

      hmget key field1 field2 ...

    • 例5:获取键u2属性nameage的值

      hmget u2 name age

    • 获取所有属性的值

      hvals key

    • 例6:获取键u2所有属性的值

      hvals u2

    • 删除属性,属性对应的值会被⼀起删除

      hdel key field1 field2 ...

    • 例7:删除键u2的属性age

      hdel u2 age

    3.4 list

    列表的元素类型为string

    按照插⼊顺序排序

    • 在左侧插⼊数据

      lpush key value1 value2 ...

    • 例1:从键为a1的列表左侧加⼊数据a 、 b 、c

      lpush a1 a b c

    • 在右侧插⼊数据

      rpush key value1 value2 ...

    • 例2:从键为a1的列表右侧加⼊数据0、1

      rpush a1 0 1

    • 在指定元素的前或后插⼊新元素

      linsert key before或after 现有元素 新元素

    • 例3:在键为a1的列表中元素b前加⼊3

      linsert a1 before b 3

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

    • 索引从左侧开始,第⼀个元素为0

    • 索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素

      lset key index value

    • 例5:修改键为a1的列表中下标为1的元素值为z

      lset a 1 z

    • 删除元素

      lpop 删除最左边一个元素

      rpop 删除最右边一个元素

    • 删除指定元素

      • 将列表中前count次出现的值为value的元素移除
      • count > 0: 从头往尾移除
      • count < 0: 从尾往头移除
      • count = 0: 移除所有

      lrem key count value

    • 例6.1:向列表a2中加⼊元素a、b、a、b、a、b

      lpush a2 a b a b a b

    • 例6.2:从a2列表右侧开始删除2个b

      lrem a2 -2 b

    • 例6.3:查看列表a2的所有元素

      lrange a2 0 -1

    3.5 set

    • 添加元素

      sadd key member1 member2 ...

    • 例1:向键a3的集合中添加元素zhangsanlisiwangwu

      sadd a3 zhangsan sili wangwu

    • 删除元素

      srem key

    • 返回所有的元素

      smembers key

    • 例2:获取键a3的集合中所有元素

      smembers a3

    • 删除指定元素

      srem key value

    • 例3:删除键a3的集合中元素wangwu

      srem a3 wangwu

    • 交集,并集,差集

      sdiff 返回一个集合和其他集合的差集

      sinter 返回几个集合的交集

      sunion 返回几个集合的并集

    3.6 redis的几个站点地址

    中文官网: http://www.redis.cn/

    英文官网:https://redis.io

    参考命令:http://doc.redisfans.com/

    3.7 针对redis中的内容扩展

    flushall 清空数据库中的所有数据

    针对各种数据类型它们的特性,使用场景如下:
    字符串string: 用于保存一些项目中的普通数据,只要键值对的都可以保存,例如,保存 session,定时记录状态
    哈希hash:用于保存项目中的一些字典数据,但是不能保存多维的字典,例如,商城的购物车
    列表list:用于保存项目中的列表数据,但是也不能保存多维的列表,例如,队列,秒杀,医院的挂号
    无序集合set:用于保存项目中的一些不能重复的数据,可以用于过滤,例如,投票海选的时候,过滤候选人
    有序集合zset:用于保存项目中一些不能重复,但是需要进行排序的数据,分数排行榜.
    
  • 相关阅读:
    python自动化运维-编写rsync+sersync安装脚本实现文件实时同步
    引力产生的原因是什么
    Binder通信机制介绍
    Binder机制
    MySQL for Windows 解压缩版配置安装
    python 操作sqlite数据库
    python 生成验证码
    python 多线程
    python multiprocessing 多进程
    python @property 属性
  • 原文地址:https://www.cnblogs.com/zyyhxbs/p/11831020.html
Copyright © 2011-2022 走看看