前言

总结自己的redis,日常使用不是特别频繁,所以比较基础。

开篇

redis 是无关系型数据库,因为其实内存数据库,所以常常和他的竞争对手memcached对比,因为两者原理基础相似,存储方式也是key和value的方式。

在memcached中value只能是字符串,而redis就有5种结构了。当然这并是不说mencached就比redis差,只是介绍出redis有哪些优点。

redis最大的优势或者说特点和普通的关系型数据库而言就在于是内存中,这意味着我们有很好都读写能力。

缺点也就很明显了,因为在内存中消耗的资源成本肯定比持久化存储的成本高。毕竟你要向公司申请一台redis,公司会考虑到今年给你们部门的开销,毕竟公司上层很可能不懂什么是技术,只知道资本主义那一套。

如果是技术出身的老板可能还会怼我们开发人员,因为他会在技术与资本之前权衡,但是往往选择资本主义,然后用着他的专业术语和我们沟通一番。

好了说到内存,那么肯定得考虑如何持久化,因为别的不说,你总得备份数据库吧,万一服务器抽风呢?

1.时间点存储,每隔一段时间存储一些数据或者说某个时间点来存储数据,总之就是规划时间这回事。然后这种方式被别人称为rdb,redis database。

2.AOF方式,(append only file)。这种方式就是通过操作日志的方式,每一次写(增删改)的操作都会被记录,这样就做到了持久化了。

上面的优劣点就不介绍了,因为第一章只是简单的介绍。

redis的数据结构

前文:我在远程操作,使用redis client作为演示。

redis 开启远程:修改 protected-mode 为 no ; 修改 daemonize 为 no ; 修改默认的,设置为 bind 0.0.0.0,然后添加一个密码,具体的可百度。当然这样是不安全的,只作为演示。

上图是我连接数据库后的,但是我只使用第一个,就算是生产环境一般也使用一个。

上文介绍到redis和memcached不同之处,在于由5种数据结构,看一下吧。

string 字符

set str string

key: str value string



当然我们命令行查看的方式:

get str

删除的话,就是del str,在此不演示了。

list 列表

添加一个list,key命名为keylist 值为item1

rpush keylist item1

当然我们也可以左边push进入:lpush keylist item2



你们看item2在item1的上方

删除的方式,一个是往左边弹出:



查看一下剩下什么:

lrange listkey 0 -1

因为redis client 是在是不好用,所以换回了putty,命令行模式。

往右边弹出:

rpop listkey

这样就没有任何数据了。

lrange listkey 0 -1

在列表中是支持索引的。

上图中使用了lindex 索引。但是是没有rindex。

集合

集合通过散列来实现的,这意味着每个字符都是不同的,集合同时是无序的。这和我们在高级语言中学习集合是一致的。

sadd setkey item1

往集合中增加一个值,如果key不存在就创建,返回了集合中的值的数量。

查询集合是使用:smembers setkey

中间有一个我打错了,望见谅。

查找的方式是:sismember setkey item1 如果存在返回1,不存在返回0



删除是srem setkey item1,删除了是1,没有删除是0。

散列

如果把其他类型比作游击队,那么散列名字虽然有个散字,但是却是一个团队。

这似乎补充了redis没有表的问题。

使用hset作为添加散列:

hset hashkey subhashkey1 item1-1

如果subhashkey1存在将会覆盖,且返回0。

查询的方式是hget,hget hashkey subhashkey1

查询散列中的keys,可以用hkeys hashkey.那么将会显示出subhashkey1,这里我就不展示。

如果使用hgetall hashkey,那么显示的将会是:

会显示所有的键值对,包括了值。

下图为删除的:

有序集合

写到这里,其实应该返回到集合去查看的。

前面解释了集合是通过散列实现的,集合是有索引的。

对应的是——哈希值:value。

在有序集合中,只是这个哈希值不再是系统帮助我们生成,而是我们手动输入,这样我们通过我们输入的值就可以找到value。

有两个一定要记住的术语:

1.有序集合的键被称作成员。

2.有序集合的值被称作分值。

我们通过zadd来添加。



上文可知,通知1是添加了,0是覆盖了。

对了,redis符合一句话,没有错误就是成功了,所以不存在返回0是出现错误。

zrange zsetkey 0 -1

是查询。

zrange zsetkey 0 -1 会有另外一个参数,就是展示出我们输入的成员。

如下图:

有一个zrangescore的,也特别重要:



它会根据我们的成员范围来查找。

最后一个是删除zrem,zrem删除的是分值,而不是成员,因为他是一个集合,而不是一个散列。

如果我们使用zrem通过成员去删除的话:



是不会成功的,返回结果为0,代表zrem中没有101这个分值,而不是说这条语句失败了。

总结

redis 的语句都特别好理解,但是在使用中一般都会出现问题,当然这些问题都会交给运维人员去解决(重启以及删库跑路),但是当持续崩的话,可能自己都会受到波及。

redis 一百二十篇(简单介绍)之第一篇的更多相关文章

  1. iOS开发网络篇—简单介绍ASI框架的使用

    iOS开发网络篇—简单介绍ASI框架的使用 说明:本文主要介绍网络编程中常用框架ASI的简单使用. 一.ASI简单介绍 ASI:全称是ASIHTTPRequest,外号“HTTP终结者”,功能十分强大 ...

  2. iOS开发UI篇—简单介绍静态单元格的使用

    iOS开发UI篇—简单介绍静态单元格的使用 一.实现效果与说明 说明:观察上面的展示效果,可以发现整个界面是由一个tableview来展示的,上面的数据都是固定的,且几乎不会改变. 要完成上面的效果, ...

  3. iOS开发Swift篇—简单介绍

    iOS开发Swift篇—简单介绍 一.简介 Swift是苹果于2014年WWDC(苹果开发者大会)发布的全新编程语言 Swift在天朝译为“雨燕”,是它的LOGO 是一只燕子,跟Objective-C ...

  4. Salesforce LWC学习(二十六) 简单知识总结篇三

    首先本篇感谢长源edward老哥的大力帮助. 背景:我们在前端开发的时候,经常会用到输入框,并且对这个输入框设置 required或者其他的验证,当不满足条件时使用自定义的UI或者使用标准的 inpu ...

  5. JMS【二】--ActiveMQ简单介绍以及安装

    现实的企业中,对于消息通信的应用一直都非常的火热,而且在J2EE的企业应用中扮演着特殊的角色,所以对于它研究是非常有必要的. 上篇博文JMS[一]--JMS基本概念,我们介绍了消息通信的规范JMS,我 ...

  6. Android 驱动(二) IIC简单介绍

    一. I2C简单介绍 I2C(Inter-Integrated Circuit)总线是一种由 Philips 公司开发的两线式串行总线,用于连接微控制器及其外围设备.I2C 总线最基本的长处就是简单性 ...

  7. 【转】深入浅出JMS(二)--ActiveMQ简单介绍以及安装

    现实的企业中,对于消息通信的应用一直都非常的火热,而且在J2EE的企业应用中扮演着特殊的角色,所以对于它研究是非常有必要的. 这篇博文介绍一款开源的JMS具体实现——ActiveMQ.ActiveMQ ...

  8. mongodb基础整理篇————简单介绍[一]

    前言 简单介绍一下文档数据库. 正文 mongodb 是一个以json为数据模型的文档数据库. 这里要介绍一下什么是json.因为有些人认为'{a:1,b:2}' 是json,而"this ...

  9. 一百二十九:CMS系统之七牛云存储介绍和配置

    将图片的存储.尺寸等图片本身的一些擦做,交给七牛云处理,自己只关注网站开发本身 七牛云官网:https://www.qiniu.com 操作 登录后,点击管理控制台 点击对象存储-->新建存储空 ...

随机推荐

  1. MySQL5.7主从复制slave报Last_Errno: 1146错误解决

    前提:由于slave磁盘未及时扩容原因导致磁盘即将写满,为了不影响业务将slave实例里一个10G的库drop了(项目前期建的库,数据现在已不使用了),然后又drop了master上的该库(对于大库建 ...

  2. X因素 开启它就能让你成为超级明星

    开启它就能让你成为超级明星" title="X因素 开启它就能让你成为超级明星"> "只要努力就能成为明星!"记得电影学院的不少老师都这样告诫学 ...

  3. Android(四)-JVM与DVM区别

    JVM与DVM区别 1.由来 Android是基于java的既然java已经有了java虚拟机,为什么android还要弄一个DVM了?最重要的就是版权问题,一开始就是用的 JVM,没过多久就被SUN ...

  4. 想清楚再入!VR硬件创业能“要你命”

    每一次跨时代新产品的出现,总会让科技行业疯狂一阵儿,十年前是智能手机,今天自然是VR.自2015年开始,VR火的越来越让人欣喜,让人兴奋,更让人越来越看不清,越来越害怕.数不清的大小品牌义无反顾的杀入 ...

  5. 函数节流throttle和防抖debounce

    throttle 函数节流 不论触发函数多少次,函数只在设定条件到达时调用第一次函数设定,函数节流 1234567891011 let throttle = function(fn,intervalT ...

  6. C++走向远洋——35(友元,时间)

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:time.cpp * 作者:常轩 * 微信公众号:Worldhe ...

  7. flask 参数校验

    校验参数是否存在,不存在返回400 @app.route('/check',methods=['POST']) def check(): values = request.get_json() req ...

  8. Zookeeper的使用场景和集群配置

    Zookeeper的介绍 ZK在分布式系统的应用 Zookeeper搭建 集群角色介绍 ZK的常用命令 一.Zookeeper的介绍 官方:ZooKeeper是一个分布式的,开放源码的分布式应用程序协 ...

  9. 大厂面试题:集群部署时的分布式 session 如何实现?

    面试官心理分析 面试官问了你一堆 dubbo 是怎么玩儿的,你会玩儿 dubbo 就可以把单块系统弄成分布式系统,然后分布式之后接踵而来的就是一堆问题,最大的问题就是分布式事务.接口幂等性.分布式锁, ...

  10. 奉上简单的.Net后端开发模板

    假定一个场景,开始做开发的你,领导走到你的面前说道:"小伙子,看了简历和最近的工作表现,很不错,现在交给一个任务,开发一个简单的CMS后端接口吧,前端有人配合你",当时你内心读白: ...