目录

一.通用命令

二.数据结构与内部编码

三.单线程架构


一.通用命令

Redis有五种数据结构,它们是键值对中的值,对于键来说有一些通用的命令.Redis的全局通用命令有:keys,dbsize,exists key,del key [key …],expire key seconds,type key.

1.keys(查看所有键)

虽然keys *命令比较方便实用,但一般不建议在生产环境使用,是因为生产环境的简直对比较多,keys命令比较重,它的查询复杂度为O(n),加入你有几百万个键,这样查询的速度会比较慢,而且Redis是单线程的,这样还会阻塞其它的命令.还有这样取出的数据意义并不大.但是我们有其它的方法可以解决这样的问题,例如:热备从节点,scan命令.这些在后面会仔讲解.

127.0.0.1:> keys  *
) "_ROUTE_KEY"
) "mylist"
127.0.0.1:> set hello world
OK
127.0.0.1:> set java jedis
OK
127.0.0.1:> set python redis-py
OK
127.0.0.1:> keys *
) "python"
) "mylist"
) "_ROUTE_KEY"
) "java"
) "hello"

2.dbsize(键总数)

dbsize命令会返回当前数据库的键总数,例如上面我们插入了五条数据,这里就返回了结果:5. 但是dbsize命令不会遍历数据库中所有的键,而是直接获取Redis内置的键总数变量,因此他的时间复杂度为O(1),这点个keys命令不同.

127.0.0.1:> dbsize
(integer)
127.0.0.1:>

3.exists key(检查键是否存在)

使用exists 命令,如果键存在则返回1,不存在则返回0,如下所示:

127.0.0.1:> set a b
OK
127.0.0.1:> exists a
(integer)
127.0.0.1:> del a
(integer)
127.0.0.1:> exists a
(integer)
127.0.0.1:>

4.del  key  [key …](删除键)

del是一个通用的命令,不管何种类型的数据,都可以将其删除,如果所删除的键存在,则返回 1,不存在则返回 0,如下:

127.0.0.1:> del java
(integer)
127.0.0.1:> del b
(integer)

5.expire key seconds(键过期)

Redis支持对键添加过期时间,当超出所设置的时间,会自动删除键,而且在设置键过期时间之后,我们还可以通过ttl命令来查看key剩余的过期时间,或者通过persist命令来去掉key的过期时间.当键被过期后,用ttl命令查看,则返回结果:2,具体如下:

127.0.0.1:> expire hello
(integer)
127.0.0.1:> ttl hello
(integer) -

6.type key(键的数据结构类型)

如下,python是字符串类型,返回结果便为string,键mylist 是列表类型,返回结果则是list:

127.0.0.1:> type python
string
127.0.0.1:> type mylist
list

二.数据结构与内部编码

type命令所返回的实际上就是当前key的数据结构类型,他们分别是string(字符串),hash(哈希),list(列表),set(集合),zset(有序集合),但这只是Redis对外的数据结构.实际上每种数据结构还有自己底层的内部编码实现,例如list就包含了linkedlist和ziplist两种内部编码,不过我们也可以通过object encoding命令来查询内部编码.

图1:

图2:

三.单线程架构

Redis使用了单线程架构和I/O多路复用模型来实现高性能的内存数据库服务.

1.单线程模型

首先来看下客户端与服务端的简单模型图,如图3所示,可以从图中看出每次客户端都只是经历:发送命令,执行命令和返回结果三个过程.

图3:

其中,这最主要的还是因为Redis是单线程来处理命令的,所以一条命令从客户端发送到服务端,不会立马被执行,所有的命令都会放到一个队列之中,然后逐个被执行,这就是redis的但线程的基本模型.

图4:

图5:

2.为什么单线程这么快?

1)纯内存访问,Redis讲所有数据放在内存中,内存的响应时长大约为100纳秒,这是Redis达到每秒万级别访问的重要基础.

2)非阻塞I/O,Redis使用epoll作为I/O多路复用技术的实现,再加上Redis的事件处理模型将epoll中的连接,读写,关闭都转换为事件,不在网络I/O上浪费过多的时间,如图6所示:

3)单线程避免了线程切换和竞态产生的消耗.

图6:

参考:redis开发与运维

最后语:不积跬步,无以至千里;不积小流,无以成江海。对于知识总要温故,这样才能知新!

版权声明:尊重博主原创文章,转载请注明出处 https://www.cnblogs.com/hsdy

Redis API的理解与使用的更多相关文章

  1. NoSQL初探之人人都爱Redis:(2)Redis API与常用数据类型简介

    一.Redis API For .Net 首先,不得不说Redis官方提供了众多的API开发包,但是目前Redis官方版本不支持.Net直接进行连接,需要使用一些第三方的开源类库.目前最流行的就是Se ...

  2. 【转】NoSQL初探之人人都爱Redis:(2)Redis API与常用数据类型简介

    一.Redis API For .Net 首先,不得不说Redis官方提供了众多的API开发包,但是目前Redis官方版本不支持.Net直接进行连接,需要使用一些第三方的开源类库.目前最流行的就是Se ...

  3. Redis API与常用数据类型简介

    Redis API与常用数据类型简介 一.Redis API For .Net 首先,不得不说Redis官方提供了众多的API开发包,但是目前Redis官方版本不支持.Net直接进行连接,需要使用一些 ...

  4. redis 单线程的理解

    单线程模型 Redis客户端对服务端的每次调用都经历了发送命令,执行命令,返回结果三个过程.其中执行命令阶段,由于Redis是单线程来处理命令的,所有每一条到达服务端的命令不会立刻执行,所有的命令都会 ...

  5. 2.API的理解和使用

    标题 : 2.API的理解和使用 目录 : Redis 序号 : 2 ​ zset的成员是唯一的,但分数(score)却可以重复. ​ 有序集合的内部编码 1.ziplist(压缩列表):当有序集合的 ...

  6. qnx:从API开始理解QNX -- 消息传递

    从API开始理解QNX -- 消息传递    http://www.openqnx.com/chinese/viewtopic.php?f=5&t=2161 1. 频道与连接    Chann ...

  7. 第八章· Redis API 开发

    Redis 开发 1.源码安装Python环境 Python官网:https://www.python.org/ #下载Python3.6.4安装包 [root@db03 ~]# wget https ...

  8. Redis 入门到分布式 (二)API的理解和使用

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 内容: 通用命令 单线程架构 数据结构和内部编码 一.常用的通用命令: keys       计算所有的 ...

  9. 【redis 学习系列】API的理解与使用(二)

    3.哈希 几乎所有的语言都支持了哈希(hash)类型.在Redis中,哈希类型是指键值本身又是一个键值对结构,形如:value = {{field, value} ... {field, value} ...

随机推荐

  1. 配置Sharepoint之后。外网无法访问的问题

    Sharepoint配置完成了,projectserver也已经配置完毕.突然遇到一个情况就是外网访问不了,这可麻烦了,费了半天事访问不了等于0啊.没办法,研究吧.在群里问了大神,终于解决了.现将解决 ...

  2. 使用Visual Studio Code开发Arduino

    首发于MSPrecious成长荟 https://zhuanlan.zhihu.com/p/30868224 使用Visual Studio Code开发Arduino 1.下载安装 VS Code ...

  3. my target

    目前看来 任何模块 改代码不是问题target是写得一手好代码.设计模式. 语法日积月累.c++ 先看media

  4. 美团2018年CodeM大赛-初赛B轮 B 配送(最短路)

    美团2018年CodeM大赛-初赛B轮 B 配送 题意 题解 对于每个任务,只要从上个任务的终点出发即可. 时间.地点很少,可以算出每个地点-时间的最小花费. 以题目描述的起点终点起始结束时间建图,很 ...

  5. Spring配置文件中的parent与abstract

    在看项目的Spring配置文件时,发现消息队列的配置采用了继承方式配置Bean,在这梳理总结一下. 其实在基于spring框架开发的项目中,如果有多个bean都是一个类的实例,如配置多个数据源时,大部 ...

  6. js字符串和数组

    sustr  substring  slice的联系与区别 str.substr(2,5) //从索引2开始截取5个字符,原有字符串str不变 str.substring(2,5) //从索引2开始截 ...

  7. svg压缩工具svgo安装使用

    svgo是基于node.js的插件,所以需要先安装node.js 1.安装完node.js后,打开node.js命令窗口,输入npm install -g svgo,安装成后会出现下边的内容 2.对s ...

  8. bzoj 3339 Rmq Problem / mex

    题目 我的树状数组怎么那么慢啊 就是一道水题,我们考虑一下对于一个区间\([l,r]\)什么样的数能被计算 显然需要对于一个\(j\),需要满足\(j<l\)且\(nxt_{j}>r\), ...

  9. 随手练——HDU 1237 表达式求值(输入格式典型)

    坑了老子半天,结果是 float 范围不够!!! 基本思想: 开一个符号栈,一个数字栈: 碰到数字就入栈,碰到符号就与栈顶符号进行对比,如果当前符号优先级小于栈顶符号,数字栈弹出两个数进行栈顶符号运算 ...

  10. 通过css使文字有渐变的效果

    <style> .color{ background-image: -webkit-gradient(linear, left center, right center, from(rgb ...