Redis快速入门到精通
Redis
Redis是一个开源的使用ANSI C语言编写、支持网络、 可基于内存亦可持久化的日志型、Key-Value型 NoSQL数据库,并提供多种语言的API。从2010年3 月15日起,Redis的开发工作由VMware主持。从 2013年5月开始,Redis的开发由Pivotal赞助。
一、配置选项
| 命令 | 示例 | 说明 |
|---|---|---|
| daemonize | deamonize yes | 是否启用后台运行,默认”no” |
| port | port 6379 | 设置端口号,默认6379 |
| lgfile | logfile日志文件 | 设置日志文件 |
| databases | databases 255 | 设置redis数据库总量 |
| dir | dir 数据文件目录 | 设置数据文件存储目录 |
| requirepass | requirepass 12345 | 设置使用密码 |
二、通用命令
| 命令 | 示例 | 说明 |
|---|---|---|
| select | select 0 | 选择0号数据库 |
| keys | keys * | 查询所有 |
| dbsize | dbsize | 返回key的总数 |
| exists | exists a | 检查key=a是否存在 |
| del | del a | 删除key=a的数据 |
| expire | expire hello 20 | 设置key=hello 20秒后过期 |
| ttl | ttl hello | 查看key=a的过期剩余时间 |
三、数据结构
1、String
1.1 字符串类型
| key | value |
|---|---|
| hello | world |
| counter | 3321 |
| bits | 1001010 |
1.2 字符串指令
| 命令 | 示例 | 说明 |
|---|---|---|
| get | get hello | 获得key=hello的value |
| set | set hello world | 设置key=hello,value=hello |
| mset | mset hello world java best | 一次性设置多个kv |
| mget | mget hello java | 一次性获取多个kv |
| del | del hello | 删除key=hello |
| incr/decr | incr/decr count | key值自增/自减1 |
| incrby/decrby | incrby/decrby count 10 | 自增/自减 10 |
2、Hash
2.1 Hash键值结构
- Hash类型用于存储结构化数据.
- Hash可以看做是Map中的Map

2.2 Hash 指令
| 命令 | 示例 | 说明 |
|---|---|---|
| hget | hget user:1:info age | 获取hash中key=age的值 |
| hset | hset user:1:info age 23 | 设置hash中age=23 |
| hmset | hmset user:2:info age 30 name kaka | 设置hash中age=30,name=kaka |
| hmget | hmget user:2:info age name | 获取hash中age & name |
| hgetall | hgetall user:2:info | 获取hash所有值 |
| hdel | hdel user:1:info age | 删除user:1的age |
3、List
- List列表是简单的字符串列表,按照插入顺序排序。你 可以添加一个元素到列表的头部(左边)或者尾部 (右边)
- 一个列表最多可以包含 2的32次方 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。
3.1 list指令
- rpush listkey c b a - 右侧插入
- lpush listkey f e d - 左侧插入
- rpop listkey - 右侧弹出
- lpop listkey - 左侧弹出
- llen listkey - 获取长度
- lrange listkey 0 2
- lrange listkey 1 -1 获取子集
4、Set
- Redis 的 Set 是 String 类型的无序集合。集合成员是 唯一的,这就意味着集合中不能出现重复的数据。
- Redis 中集合是通过哈希表实现的,所以添加,删除, 查找的速度极快。
- 集合中最大的成员数为 2的32次方 - 1 (4294967295, 每个集合可存储40多亿个成员)。
4.1 Set指令
| 命令 | 示例 | 说明 |
|---|---|---|
| sadd | sadd user:1:follow it | 添加user:1:follow属性it |
| srem | screm user:1:follow it | 移除user:1:follow属性it |
| scard | scard user:1:follow | 计算集合数量 |
| srandmember | srandmember user:1:follow 3 | 随机挑选3个元素 |
| spop | spop user:1:follow | 随机弹出元素 |
5、Zset
- Redis 的 Zset 是 String 类型的有序集合。集合成员是 唯一的,这就意味着集合中不能出现重复的数据

5.1 Zset指令
| 命令 | 示例 | 说明 |
|---|---|---|
| zadd | zadd player:rank 1000 ronaldo 900 messi | 添加集合中的元素 |
| zrank | zrank player:rank ronaldo | 获取ronaldo的排名 |
| zrem | zrem player:rank messi | 删除messi的数据 |
| zrange | zrange player:rank 0 -1 | 获得排序索引数据(0 -1是全部数据) |
| zcount | zcount player:rank 700 900 | 获得排序数据(score在700-900之间) |
| zrangebyscore | zrangebyscore player:rank 700 900 | 获得700-900的排序元素 |
Redis快速入门到精通的更多相关文章
- Redis从入门到精通:初级篇
原文链接:http://www.cnblogs.com/xrq730/p/8890896.html,转载请注明出处,谢谢 Redis从入门到精通:初级篇 平时陆陆续续看了不少Redis的文章了,工作中 ...
- Redis从入门到精通:初级篇(转)
原文链接:http://www.cnblogs.com/xrq730/p/8890896.html,转载请注明出处,谢谢 Redis从入门到精通:初级篇 平时陆陆续续看了不少Redis的文章了,工作中 ...
- Redis快速入门:安装、配置和操作
本文是有关Redis的系列技术文章之一.在之前的文章中介绍了<Redis快速入门:初识Redis>,对Redis有了一个初步的了解.今天继续为大家介绍Redis如何安装.配置和操作. 系列 ...
- Redis 快速入门
Redis 快速入门 谈到Redis,大家应该都不陌生.它是用c语言开发的一个高性能键值数据库,主要用于缓存领域.本章通过Redis的安装,Redis的五大数据类型,Redis的Java客户端,Red ...
- Scala快速入门到精通 视频教程 百度云网盘下载地址
Scala快速入门到精通 视频教程 百度云网盘下载地址 Scala快速入门到精通 下载地址链接:https://pan.baidu.com/s/1bqGIKyF 密码:ojwd
- Redis快速入门及实现
redis的概念 (1)Redis的优点 以下是Redis的一些优点. 异常快 - Redis非常快,每秒可执行大约110000次的设置(SET)操作,每秒大约可执行81000次的读取/获取(GET) ...
- Redis快速入门:初识Redis
[IT168 专稿]在之前的文章中介绍了<Redis快速入门:选择Key-Value Store>,今天给大家介绍Redis的入门知识.Redis是一个开源的使用ANSI C语言编写.支持 ...
- [你必须知道的NOSQL系列]专题二:Redis快速入门
一.前言 在前一篇博文介绍了MongoDB基本操作,本来打算这篇博文继续介绍MongoDB的相关内容的,例如索引,主从备份等内容的,但是发现这些内容都可以通过官方文档都可以看到,并且都非常详细,所以这 ...
- 二:Redis快速入门及应用
Redis的使用难吗?不难,Redis用好容易吗?不容易.Redis的使用虽然不难,但与业务结合的应用场景特别多.特别紧,用好并不容易.我们希望通过一篇文章及Demo,即可轻松.快速入门并学会应用. ...
随机推荐
- 『现学现忘』Docker常用命令 — 21、容器常用命令(三)
目录 13.进入正在运行的容器并以命令行交互 (1)方式一 (2)方式二 (3)attach和exec的区别 14.从容器内拷贝文件到主机上 15.Docker常用命令小结 (1)容器生命周期管理 ( ...
- RESTful API设计规范总结
RESTful 是目前最流行的 API 设计规范,用于 Web 数据接口的设计. 它的大原则容易把握,但是细节不容易做对.本文总结 RESTful 的设计细节,介绍如何设计出易于理解和使用的 API. ...
- openEuler网络配置+换源+桌面环境ukui等基本环境部署
镜像下载.域名解析.时间同步请点击阿里云开源镜像站 1.网络配置 你可以选择查看官方文档进行配置:配置网络 (openeuler.org) 接下来的操作基本都需要root权限,所以直接使用root用户 ...
- SQL Server 2008安全加固手册
1.身份鉴别 1.1避免使用空密码和弱口令 要求:应对登录操作系统和数据库系统的用户进行身份标识和鉴别. 目的:操作系统和数据库系统管理用户身份鉴别信息应具有不易被冒用的特点,口令应有复杂度要求并定期 ...
- kafka 学习(二--前言)
kafka 现在在企业应用和互联网项目中的应用越来越多了,本篇文章就从 kafka 的基础开始带你一展 kafka 的宏图 1. 什么是 Kafka Kafka 是一个分布式流式平台,它有三个关键能力 ...
- tomcat 部署war,umask上传文件后无法通过nginx反向代理访问上传后的文件
Catalina.sh文件,把umask修改为 0022 即可. 引用:https://tomcat.apache.org/tomcat-8.5-doc/security-howto.html
- Java如何跳出当前的多重嵌套循环?
在Java中,要想跳出多重循环,可以在外面的循环语句前定义一个标号,然后在里层循环体的代码中使用带有标号的break 语句,即可跳出外层循环.例如, outer: for(int i=0;i<1 ...
- Kafka 的高可靠性是怎么实现的?
可以参见我这篇文章:Kafka 是如何保证数据可靠性和一致性
- 在虚拟机里面安装wordpress
第一步: 安装Mariadb数据库 使用下面代码安装 1 yum install mariadb-server.x86_64 设置开机启动和启动 1 systemctl start mariadb 2 ...
- synchronized 和 ReentrantLock 的区别?
synchronized 是和 if.else.for.while 一样的关键字,ReentrantLock 是类, 这是二者的本质区别.既然 ReentrantLock 是类,那么它就提供了比 sy ...