最近梳理了一下redis的基本知识。本文会从redis的简单使用、redis的数据类型、redis持久化三个方面做简单阐述和总结。

一、Redis基本操作

1、key的规则

不能使用\n空格。其他都可以

2、key操作

exists key 测试制定key是否存在

del key1 key2 删除key

type key 返回给定key的类型

keys pattern 返回模糊匹配 如:keys *

rename oldkey newkey 改名字

dbsize 返回当前库key数量

expire key seconds 给key设定有效时间

ttl key 返回key剩余有效时间

select db-index 切换库
move key db-index 将key从当前库移动到另一个库

flushdb 删除当前库中所有key

flushall 删除所有库中所有key

二、Redis五种数据类型和基本操作

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

1、String类型

string是基本类型。

操作:

set key value 设置值

mset key1 value1 key2 value2 一次设置多个key值

mget key1 key2 key3 一次获取多个key

incr key 自增加一

decr key 自减一

incrby key integer 加integer

decrby key integer 减integer

append key value 追加value

substr key start end 截取字符串。包括start和end

2、list类型

list类型是一个属相链表。通过push,pop操作从链表头或尾进行添加删除操作。使得list既可以用作栈,也可以作为队列。

操作:

lpush key value key头部添加元素

rpop key key的尾部删除元素,并返回删除元素

llen key 对应list的 长度,key不存在返回0,如果key对应的不是list则返回错误。

lrange key start end 返回指定区间元素

rpush key string 尾部添加

lpop key 头部删除

ltrim key start end 截取list,只保留指定区间内元素

lindex key 2 获取key的第一个元素

3、set集合类型

redis的set是Sting类型的无序集合,set元素最大可以包含(2的32次方-1)个元素。

每个集合的元素不能重复。

操作:

sadd key member 添加set集合元素

srem key mamber 移除

smove p1 p2 member 从p1中移除然后添加到p2

scard key 返回set的元素个数

smember key member 判断member是否存在set中

sinter key1 key2 交集

sunion key1 key2 并集

sdiff key1 key2 差集

smember key 查看集合

适用场景:

tom朋友圈有:1 2 3 4 5,doc朋友圈有:2 3 4 5 6,求tom和doc的朋友交集等。

4、sort set排序集合类型

和set一样sort set也是String类型的集合。不同的是没个元素都会关联一个权。

通过权值可以有序的获取集合中的元素

操作:

zadd key score member 添加key。socre权,member值

zrem key member 移除

zincrby key incr member key中的member加incr

zrank key mamber 查看mmber从小到大排名

zrevrank key member 查看mmber从大到小排名

zrange key start end 按照权正排序

zrevrange key start end 按照权反排序

zcard key 查看集合个数

zscore key element 查看给定元素对应的score

zremrangebyrank key min max 删除集合中给定区间的元素

适用场景:

获得热点帖子信息等。

5、hash类型

操作:

hset key field value 设置hash值

hget key field 获取key

*hmget key field1 field2.. 获取指定key值

*hmget key field1 value1 .. 同时设置多个值

hinrcby key field integer 指定值增加

hexists key field 是否存在

hdel key field 删除

hlen key 获取field的数量

hkeys key 获取所有field

hvals key 获取所有value

*hgetall key 获取所有field和value

三、Redis持久化

redis重启时会把数据放在硬盘一份儿,重启后再拷贝回来。

1,snap shotting快照持久化

一次性把redis中全部数据保存一份在硬盘中,数据大时不适用。

2,append only file(AOF持久化)

appendfsync always 每次写命令都强制写入磁盘

appendfsync everysec 每秒

appendfsync no 依赖os,cpu闲的时候才写入磁盘

操作:

bgsave 异步保存数据到磁盘(快照保存)。

lastsave 返回上次成功保存到磁盘的unix时间戳

shutdown 同步保存到服务器并关闭redis服务器

bgrewriteaof AOF备份文件优化处理:对appendonly.aof优化压缩。

如:./redis-cli bgrewriteaof

./redis-cli -h 127.0.0.1 -p 6379 bgsave 手动发起快照

主从配置

redis.conf中:slaveof IP PORT

redis知识点杂记的更多相关文章

  1. [转帖]redis知识点总结

    redis面试常问知识点总结 https://www.toutiao.com/i6740199554127233543/ 原创 波波说运维 2019-10-02 00:01:00 概述 今天主要分享一 ...

  2. redis知识点及常见面试题

    redis知识点及常见面试题 参考: https://zm8.sm-tc.cn/?src=l4uLj4zF0NCIiIjRnJGdk5CYjNGckJLQrIqNiZaJnpOWjIvQno2Llpy ...

  3. redis 知识点收集 注意理解底层

    学redis,首先要明白其特性,其次要理解明白redis与操作系统底层的关系,这点很重要.这是一个优秀的学习方法,作为计算机专业,应当时刻想着技术和操作系统计算机组成数据结构的联系,听起来有些书生气死 ...

  4. 【面试】吃透了这些Redis知识点,面试官一定觉得你很NB(干货 | 建议珍藏)

    万字长文,干货满满. 是数据结构而非类型 很多文章都会说,redis支持5种常用的数据类型,这其实是存在很大的歧义.redis里存的都是二进制数据,其实就是字节数组(byte[]),这些字节数据是没有 ...

  5. redis知识点汇总

    1. redis是什么 2. 为什么用redis 3. redis 数据结构 4. redis中的对象类型 5. redis都能做什么?怎么实现的的? 6. redis使用过程中需要注意什么 7. 数 ...

  6. redis知识点

    为什么使用 ①解决应用服务器的cpu和内存压力 ②减少io的读操作,减轻io的压力 ③关系型数据库的扩展性不强,难以改变表结构 优点: ①nosql数据库没有关联关系,数据结构简单,拓展表比较容易 ② ...

  7. redis 知识点

    默认端口  6379 单个value 最大可以保存1G 默认RDB(异步刷盘方式) 禁用持久化修改redis.conf,找到save配置,改为save "" 即可 1. 特点 Re ...

  8. Redis知识点总结

    1.单线程 单线程模型来处理客户端的请求,对读写等事件的相应是通过对epoll函数的包装来做到的,Redis的实际处理速度完全依靠主线程的执行效率. Epoll是Linux内核为处理大批量文件描述符而 ...

  9. Redis散杂记

    Redis是一款很火的KV模式的内存数据库,与众不同的特点: 1.数据存储在内存 内存的读取速度仅次于CPU的寄存器.各等级缓存,“英雄”自动敏捷属性,特点就是快.高效.因此不需要类似存储磁盘的数据库 ...

随机推荐

  1. profile default

    SAPDBHOST = 10.199.0.26 j2ee/dbtype = hdb j2ee/dbname = ISD j2ee/dbhost = 10.199.0.26 dbs/hdb/dbname ...

  2. 分布式计算课程补充笔记 part 1.5

    ▶ 编写 SLURM 脚本 #!/bin/bash #SBATCH -J name # 任务名 #SBATCH -p gpu # 分区名,可为 cpu 或 gpu #SBATCH -N # 节点数 # ...

  3. BerOS File Suggestion(字符串匹配map)

    BerOS File Suggestion(stl-map应用) Polycarp is working on a new operating system called BerOS. He asks ...

  4. springBoot拦截器的使用

    拦截器是动态拦截Action调用的对象.它提供了一种机制可以使开发者可以定义在一个action执行的前后执行的代码,也可以在一个action执行前阻止其执行.同时也是提供了一种可以提取action中可 ...

  5. ArcGIS自定义工具箱-修复损坏的工作空间

    ArcGIS自定义工具箱-修复损坏的工作空间 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:替换数据源的工作空间 用途:针对损坏的数据源,批量进行修复 案例数 ...

  6. 作为一名程序员,在面试中如何展现你Python的coding能力?

    来源商业新知,原文标题:如何在一场面试中展现你对Python的coding能力? 如果你已经通过了招聘人员的电话面试,那么下面正是该展现你代码能力的时候了.无论是练习,作业,还是现场白板面试,这都是你 ...

  7. hadoop的job执行在yarn中内存分配调节————Container [pid=108284,containerID=container_e19_1533108188813_12125_01_000002] is running beyond virtual memory limits. Current usage: 653.1 MB of 2 GB physical memory used

    实际遇到的真实问题,解决方法: 1.调整虚拟内存率yarn.nodemanager.vmem-pmem-ratio (这个hadoop默认是2.1) 2.调整map与reduce的在AM中的大小大于y ...

  8. flume知识点总结

    首先介绍一下在flume中常用的一个数据格式,以及使用该格式的优缺点:  从flume写数据到hdfs中的时候,使用二进制格式相对于使用纯文本来说是一种更好的选择,因为大多数二进制格式都有一些方法指明 ...

  9. SpringJDBC中jdbcTemplate 的使用

    一:定义 SpringJDBC是spring官方提供的一个持久层框架,对JDBC进行了封装,提供了一个JDBCTemplated对象简化JDBC的开发.但Spring本身不是一个orm框架,与hibe ...

  10. 解决yum安装ftp提示仓库 的 GPG 密钥已安装,但是不适用于此软件包。

    遇到的问题: 在linux系统使用yum install ftp安装ftp,报以下错误 warning: rpmts_HdrFromFdno: Header V3 RSA/SHA1 Signature ...