#1.配置缓存内存限制和清理策略 #作为缓存服务器,如果不加以限制内存的话,就很有可能出现将整台服务器内存都耗光的情况,可以在redis的配置文件里面设置: #example: # 限定最多使用1.5GB内存 maxmemory 1536mb #如果内存到达了指定的上限,还要往redis里面添加更多的缓存内容,需要设置清理内容的策略: #默认为0,没有指定最大缓存,如果有新的数据添加,超过最大内存,则会使redis崩溃,所以一点要设置. #设置maxmemory之后,配合的要设置缓存数据回收策略…
本地缓存和分布式缓存 本地缓存:使用自带的map或者guava实现的是本地缓存,最主要的特点是轻量以及快速,生命周期随着jvm的销毁而结束,并且在多实例的情况下,每个实例都需要各自保存一份缓存,缓存不具有一致性. 分布式缓存:使用redis或memcached之类的称为分布式缓存,在多实例的情况下,各实例共用一份缓存数据,缓存具有一致性.缺点是需要保持redis或memcached服务的高可用,整个程序架构上较为复杂. 一.Redis和静态Map缓存区别: redis可以独立部署,这样网站代码更…
Redis 是一个键值对数据库服务器.基于内存存储数据,它常被用做缓存数据库,用来替代 memcached.官网:https://redis.io/ 什么是持久化? 持久化,指将数据存储到可永久保存的设备中. 例如,将内存中的数据存储到可永久保存的硬盘中. 为什么需要持久化? Redis 基于内存存储,内存掉电后数据会丢失 内存比硬盘贵得多,所以需要将一些不能丢失的数据持久化到硬盘上 甚至,一些特别重要的数据,是需要存到 MySQL 的. Redis 本身有持久化,为什么还要写进 mysql 呢…
redis的两种持久化方式: 1.RDB方式 概念:在指定的时间间隔内保存数据快照 实现方式: 找到redis的安装目录,修改redis的配置文件(redis.conf):① 修改备份的时间间隔:save  Time ② 修改备份文件的文件名:dbfilename  文件名.rdb ③ 修改备份文件的备份路径:dir  路径 手动方式: save  :会阻塞redis服务器,对于比较大的实例会造成长时间阻塞,线上环境不建议使用.运行save命令对应Redis日志如下: DB saved on d…
引言 终于可以有时间继续看书,整理自己的见解, 写下2019年第一篇自己的随笔.从去年9月份跳槽到新公司后,几乎天天的加班让整个人都盲目了,原本计划好的事情总是会被打乱.都说坚持一件事情很难,特别是写博客.确实我由于自己的懒惰以及工作的事情,导致“放弃”了三个的月随笔博文习惯,希望2019年再接再厉吧:    由于Redis在公司的架构中使用很多,但是大部分人包括我也一开始只是停留在会部署的地步,并没有深入理解为什么那么部署,以及Redis的一些特性,今天参考了一些资料以后,做了关于Redis持…
一.概述 Redis的强大性能很大程度上都是因为所有数据都是存储在内存中的,然而当Redis重启后,所有存储在内存中的数据将会丢失,在很多情况下是无法容忍这样的事情的.所以,我们需要将内存中的数据持久化!典型的需要持久化数据的场景如下: 将Redis作为数据库使用: 将Redis作为缓存服务器使用,但是缓存miss后会对性能造成很大影响,所有缓存同时失效时会造成服务雪崩,无法响应. 本文介绍Redis所支持的两种数据持久化方式. 二.Redis数据持久化 Redis支持两种数据持久化方式:RDB…
文章摘自:https://www.cnblogs.com/kismetv/p/9137897.html 前言 在上一篇文章中,介绍了Redis的内存模型,从这篇文章开始,将依次介绍Redis高可用相关的知识——持久化.复制(及读写分离).哨兵.以及集群. 本文将先说明上述几种技术分别解决了Redis高可用的什么问题:然后详细介绍Redis的持久化技术,主要是RDB和AOF两种持久化方案:在介绍RDB和AOF方案时,不仅介绍其作用及操作方法,同时介绍持久化实现的一些原理细节及需要注意的问题.最后,…
一.Redis高可用概述 在介绍Redis高可用之前,先说明一下在Redis的语境中高可用的含义. 我们知道,在web服务器中,高可用是指服务器可以正常访问的时间,衡量的标准是在多长时间内可以提供正常服务(99.9%.99.99%.99.999% 等等).但是在Redis语境中,高可用的含义似乎要宽泛一些,除了保证提供正常服务(如主从分离.快速容灾技术),还需要考虑数据容量的扩展.数据安全不会丢失等. 在Redis中,实现高可用的技术主要包括持久化.复制.哨兵和集群,下面分别说明它们的作用,以及…
disgear是笔者参考solrcloud架构基于redis实现的分布式的缓存,支持数据切分到多台机器上,支持HA,支持读写分离和主节点失效自动选举,目前把它开放到github上,开放给大家 github:https://github.com/yangbutao/disgear 总体设计 1. 系统需求 1) 性能 内存操作,读写性能要求比较高 2) 数据量 支持数据切分,分为多个Shard,每个shard负责一定范围的数据 3) 伸缩性 当单个节点的数据量比较大的时,可以对该节点进行数据切分,…
3 Redis主动同步设置方法 Redis主从同步 1.Redis主从同步特点 一个master可以拥有多个slave 多个slave可以连接同一个master,还可以连接到其他slave 主从复制不会阻塞master,在同步数据时,master可以继续处理client请求. 提高系统的伸缩性 2.Redis主从同步的过程 配置好slave服务器连接master后,slave会建立和master的连接,然后发送sync命令. 无论是第一次同步建立的连接还是连接断开后的重新连接,master都会启…