Redis高级应用
上一篇博文讲述了Redis的一些常用命令,可以对数据库及数据库服务器进行操作,本篇将讲述Redis的高级应用及配置
- 安全性
- 设置密码:修改redis.conf中的requirepass,在其后面添加密码即可
- 使用:
- 进入客户端时,添加参数u;即 redis-cli -u password
- 进入客户端后,使用命令 auth,即 auth password
- 使用:
- 设置密码:修改redis.conf中的requirepass,在其后面添加密码即可
- 主从复制
- 通过主从复制可以允许多个是slave server拥有和master server相同的数据库副本
- 特点:
- Master可以拥有多个slave
- 多个slave可以连接同一个master外,还可以连接到其他的slave
- 主从复制不会阻塞master,在同步数据时,master可以继续处理client请求
- 提高系统的伸缩性
- Redis主从复制过程
- Slave与master建立连接,发送sync同步命令
- Master会启动一个后台进程,将数据库快照保存到文件中,同时master主进程会开始收集新的写命令并缓存
- 后台完成保存后,就将此文件发送给slave
- Slave将此文件保存到硬盘上
- 配置主从服务器
- 配置slave服务器:
- 在slave的配置文件中修改slaveof,在其后面添加master的ip
- 在slave的配置文件中修改masterauth,在其后面添加master的密码
- 事务处理
- Redis只能保证一个client发起的事务可以连续执行,中间不插入其他client的命令
- 原理:但一个client在一个连续中发出multi命令时,这个连接会进入一个事务上下文,该连接后续的命令不会立即执行,而是先放入一个队列中,当执行exec命令时,redis会顺序的执行队列中的所有命令
- 打开事务:multi
- 执行并关闭事务:exec
- 关闭并取消事务:discard
- 监视:watch命令会监视给定的key,当exec时,如果监视的key从调用watch后发生变化,这整个事务将失败
- 乐观锁:基于数据库表的版本解决方案中,一般是通过为数据库表添加一个“version”字段来实现读取数据时,将此版本号一同读出,之后更新时,对此版 本号+1。此时,将提交数据的版本号与数据库表对应记录的当前版本号进行比对,如果提交的数据版本号大于数据库当前版本号,则予以更新,否则认为是过期数据
- 监视key:watch,如 watch key
- 关闭监视:unwatch,如 unwatch key
- 持久化机制
- Redis两种持久化方式
- snapshotting(快照)默认方式
- 将内存中数据以快照的方式写入二进制文件中,默认文件名为dump.rdb。
- 可通过配置自动化快照持久化的方式,修改redis.conf的save参数,配置redis在n秒内如果超过m个key被修改就自动做快照
- Append-only file(aof)
- 将操作写入文件中,当发生操作时,写入磁盘
- 修改redis.conf的appendonly为yes,开启aof方式
- 修改redis.conf的appendfsync的参数,设置aof方式
- always:收到写命令就立即写入磁盘
- everysec:没秒钟写入磁盘一次
- no:完全依赖os写入
- snapshotting(快照)默认方式
- Redis两种持久化方式
- 发布订阅消息
- 发布订阅(pub/sub)是一种消息通信模式,主要目的是解除消息发布者和消息订阅者之间的耦合,
- 订阅者可以通过subscribe和psubscribe命令向redis server订阅自己感兴趣的消息类型,redis将信息类型称为通道(channel)。当发布者通过publish命令向redis server发送特定类型的信息时,订阅该信息类型的全部client都会收到此信息
- 订阅消息:subscribe/psubscribe,如 subscribe/psubscribe key
- 发布消息:publish,如 publish key value
- 虚拟内存的使用
- 暂时把不经常访问的数据内存交换到磁盘中,从而腾出内存空间用于其他需要访问的数据
- 提高数据库容量的办法之一是使用虚拟内存把那些不经常访问的数据交换到磁盘中
- 配置
- vm-enabled:设置虚拟内存是否开启
- vm-swap-file:交换出来的value保存的文件路径
- vm-max-memory:redis使用的最大内存上限
- vm-page-size:每个页面的大小
- vm-pages:最多使用多少个页面
- vm-max-threads:用于执行value对象换入的工作线程数量
Redis高级应用的更多相关文章
- 分布式缓存技术redis学习系列(四)——redis高级应用(集群搭建、集群分区原理、集群操作)
本文是redis学习系列的第四篇,前面我们学习了redis的数据结构和一些高级特性,点击下面链接可回看 <详细讲解redis数据结构(内存模型)以及常用命令> <redis高级应用( ...
- NoSQL之Redis高级实用命令详解--安全和主从复制
Android IOS JavaScript HTML5 CSS jQuery Python PHP NodeJS Java Spring MySQL MongoDB Redis NOSQL Vim ...
- 分布式缓存技术redis学习(四)——redis高级应用(集群搭建、集群分区原理、集群操作)
本文是redis学习系列的第四篇,前面我们学习了redis的数据结构和一些高级特性,点击下面链接可回看 <详细讲解redis数据结构(内存模型)以及常用命令> <redis高级应用( ...
- 3.Redis高级功能
3.Redis高级功能3.1 慢查询分析3.1.1 慢查询的两个配置参数3.1.2 最佳实践3.1.3 单线程架构3.2 Redis Shell3.2.1 redis-cli 详解3.2.2 redi ...
- 分布式缓存技术redis系列(四)——redis高级应用(集群搭建、集群分区原理、集群操作)
本文是redis学习系列的第四篇,前面我们学习了redis的数据结构和一些高级特性,点击下面链接可回看 <详细讲解redis数据结构(内存模型)以及常用命令> <redis高级应用( ...
- redis 高级特性 不要太好用
Redis高级特性及应用场景 redis中键的生存时间(expire) redis中可以使用expire命令设置一个键的生存时间,到时间后redis会自动删除它. 过期时间可以设置为秒或者毫秒精度. ...
- Redis学习第八课:Redis高级实用特性(二)
Redis高级实用特性 4.持久化机制 Redis是一个支持持久化的内存数据库,也就是说Redis需要经常将内存中的数据同步到硬盘来保证持久化.Redis支持两种持久化方式:(1).snapshott ...
- Redis学习第八课:Redis高级实用特性(一)
Redis高级实用特性 注:我学习的环境是vmware7.1 + ubantu10.10+ redis 3.0.2 1.安全性 设置客户端连接后进行任何其他指定前需要的密码.因为redis速度相当快, ...
- redis高级应用(集群搭建、集群分区原理、集群操作)
文章主目录 Redis集群简介 Redis集群搭建 Redis集群分区原理 集群操作 参考文档 本文是redis学习系列的第四篇,前面我们学习了redis的数据结构和一些高级特性,点击下面链接可回看 ...
- 架构师养成记--32.Redis高级(安全 主从复制)
Redis高级命令及特性 keys * 返回满足的所有键值(*表示模糊匹配) exists 是否存在指定的key(返回1表示存在,0表示不存在) expire 设置某个key的过期时间,使用ttl查看 ...
随机推荐
- 微软必应词典客户端的案例分析——个人Week3作业
第一部分 调研,评测 Bug探索 Bug No1.高亮语义匹配错位 环境: windows8,使用必应词典版本PC版:3.5.0 重现步骤: 1. 搜索"funny face"这一 ...
- HTML5标准简介
最近前端的群都蛮热闹的,但我发现多数讨论的是javascript和css相关的问题,仿佛大家在努力创建各种交互.样式的时候,忘却了这一切的基础 – HTML. 其实我很喜欢HTML,觉得这个语言远比X ...
- ActiveReports 9 新功能:可视化查询设计器(VQD)介绍
在最新发布的ActiveReports 9报表控件中添加了多项新功能,以帮助你在更短的时间里创建外观绚丽.功能强大的报表系统,本文将重点介绍可视化数据查询设计器,无需手动编写任何SQL语句,主要内容如 ...
- ahjesus 获取当前方法被调用执行的具体位置,包括命名空间和方法
MethodBase method = ).GetMethod(); string ahjesus = method.ReflectedType.FullName + "." + ...
- ASP.NET Web API默认支持的媒体类型(SupportedMediaTypes)
JsonMediaTypeFormatter XmlMediaTypeFormatter ( application/xml text/xml) FormUrlEncodedMediaTypeFor ...
- java分派
变量被声明时的类型叫做变量的静态类型(Static Type) 又叫明显类型(Apparent Type).变量所引用的对象的真实类型又叫做变量的实际类型(Actual Type). 根据对象的类型而 ...
- access的逻辑类型
Alter TABLE [表名] ADD [新增字段] BOOLEAN或者Alter TABLE [表名] ADD [新增字段] YESNO 或者Alter TABLE [表名] ADD [新增字段] ...
- https和http
今天登网站的时候用https登的,没登上去用http找到网站了,于是就去百度了下他俩的区别简单的画了俩图.
- sharepoint获取exchange邮箱报错:该帐户无权模拟所请求的用户
现象: sharepoint获取exchange邮箱报错:该帐户无权模拟所请求的用户 处理办法: 1.Open the Exchange Management Shell 2.输入: New-Mana ...
- Java中的继承与组合(转载)
本文主要说明Java中继承与组合的概念,以及它们之间的联系与区别.首先文章会给出一小段代码示例,用于展示到底什么是继承.然后演示如何通过“组合”来改进这种继承的设计机制.最后总结这两者的应用场景,即到 ...