Redis性能管理及集群三种模式(一)

一、前期准备

  至少准备三台服务器为主从复制、哨兵的实验做准备

  一台主redis、两台从redis

二、Redis性能管理

  2.1 查看Redis内存使用

    查看Redis内存使用——info memory

  2.2 内存使用率

  • 1<内存碎片<1.5表示合理的
  • 内存碎片大于>1.5,需要输入shutdown save命令,让Redis数据库执行保存操作并关闭redis服务
  • 内存碎片<1,redis内存配置超出物理内存,需要增加可用物理内存

  2.3 内回收key

    内存清理策略,保证合理分配redis有限的内存资源

    当达到设置的最大阈值时,需选择一种key的回收策略,默认情况下回收策略是禁止删除

    配置文件中修改maxmemory-policy属性值:

    vim /etc/redis/6379.conf

    ------598------

  • maxmemory-policy noenviction
  • volatile-lru:使用LRU算法已从设置过期时间的数据集合中淘汰数据(移除最近最少使用的key,针对设置了TTL的key)
  • volatile-ttl:从已设置过期时间的数据集合中挑选即将过期的数据淘汰(移除最近过期的key)
  • volatitle-random:从已设置过期时间的数据集合中随机挑选数据淘汰(在设置了TTL的key里随机移除)
  • allkeys-lru:使用LRU算法从所有数据集合淘汰数据(移除最少使用的key,针对所有的key)
  • allkeys-random:从数据集合中任意选择数据淘汰(随机移除key)
  • noenviction:禁止淘汰数据(不删除直到写满时报错)

  2.4 缓存的穿透、击穿和雪崩

  • 穿透:黑客或者其他非正常用户频繁进行很多非正常的url访问,使得redis查询不到数据库
  • 击穿:redis某个key过期了,大量访问这个key(热门key)
  • 雪崩:redis某个key过期了,大量正常访问某个key

三、主从复制

  3.1 主从复制的原理

  1. 从服务器向主服务器发送sync同步数据请求
  2. 主redis会fork一个子进程,然后会产生RDB文件(完全备份的文件)的过程,客户端还在持续地写入redis
  3. RDB文件持久化完成后,主redis会将RDB文件和缓存起来的命令推送给从服务器
  4. 复制、推送完后,主redis会持续地同步操作命令,会利用AOF(增备)持久化功能
  5. 在下一台redis接入主从复制之前会持续地利用AOF的方式来同步数据给从服务器,当出现故障时通过投票选择新的master并将所有slave连接新的master。整个哨兵集群不得少于3个节点。

  3.2 主从复制的部署

  3.2.1 首先关闭防火墙

  3.2.2 重命名

  3.2.2.1 为主服务器重命名

  3.2.2.2 为从服务器1重命名

  3.2.2.3 为从服务器2重命名

  3.2.3 编辑hosts配置文件

  3.2.3.1 为主服务器编辑hosts配置文件

  3.2.3.2 为从服务器1编辑hosts配置文件

  3.2.3.3 为从服务器2编辑配置hosts配置文件

  3.2.4 为从服务器1远程拷贝文件

   3.2.5 编译安装

  3.2.6 为服务器2安装gcc、gcc-c++

  3.2.7 在从服务器2上编译安装

  3.2.8 切换到从服务1下运行脚本文件

  3.2.9 切换到从服务2下运行脚本文件

  3.2.10 在主服务器上编辑配置文件并重新启动

  3.2.11 在从服务器1上编辑配置文件并重新启动

  3.2.12 在从服务器2上编辑配置文件并重新启动

  3.2.13 在主服务上查看日志

  3.2.14 在主服务器上显示redis信息

  3.2.15 完成主从复制操作

四、 redis哨兵模式

  4.1 核心功能

    在主从复制的基础上,引入了主节点的自动故障转移

  4.2 哨兵模式的定义

    哨兵模式是一个分布式系统,用于主从结构中的每台服务器进行监测

  4.3 哨兵的组成

  • 哨兵节点:哨兵系统由一个或多个哨兵节点组成,哨兵节点是特殊的redis节点,不存储数据
  • 数据节点:主节点和从节点都是数据节点

  4.4 哨兵模式的原理

  1. 哨兵对主从复制集群进行监控,监控对象“所有redis的数据节点”
  2. 哨兵与哨兵之间相互监控,监控的对象是哨兵彼此

    它的监测目的是:

  1. 检测彼此的存活状态
  2. 实现自动故障切换

  4.5 故障切换原理

  1. 当master挂掉,哨兵会及时发现,发现之后进行投票机制选举出一个新的master服务器(一定是基数)
  2. 完成slave向master的主从切换
  3. 完成其他的从服务器对新的master配置

  4.6 哨兵的实验部署

  4.6.1 为主从服务器进行操作(一)

    进入redis下,编辑sentinel配置文件,并且在后台运行

  4.6.2 为主从服务器进行操作(二)

    显示信息内容

  4.6.3 在主服务器上显示内容

  4.6.4 同时在主服务器和从服务器1上操作内容,完成哨兵操作

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/790258.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VMware虚拟机三种网络模式

VMware虚拟机提供了三种主要的网络连接模式&#xff0c;它们分别是&#xff1a; 桥接模式&#xff08;Bridged Mode&#xff09;网络地址转换模式&#xff08;NAT Mode&#xff09;仅主机模式&#xff08;Host-Only Mode&#xff09; 1. 桥接模式&#xff08;Bridged Mode&am…

创建vue3项目及基本常用配置

1、创建vue3项目 1.1 创建vue3项目 确保电脑中安装了nodejs&#xff0c;新建文件夹&#xff0c;输入以下命令&#xff1a; npm create vuelatest 看是否为自己需要的vue版本&#xff0c;选择Y 各配置具体如下&#xff0c;根据自己的需求选择是或者否 npm create vuelatest …

阿里云数据库服务器价格表查询,一键查询报价

阿里云数据库服务器价格表&#xff0c;优惠99元一年起&#xff0c;ECS云服务器2核2G、3M固定带宽、40G ESSD Entry云盘&#xff0c;优惠价格99元一年&#xff1b;阿里云数据库MySQL版2核2G基础系列经济版99元1年、2核4GB 227.99元1年&#xff0c;云数据库PostgreSQL、SQL Serve…

redis哨兵搭建_主从复制高可用解决方案

redis哨兵搭建_主从复制高可用解决方案 redis集群搭建_亲自操作 Redis哨兵-实现Redis高可用 Redis Sentinel为Redis提供了高可用解决方案。实际上这意味着使用Sentinel可以部署一套Redis&#xff0c;在没有人为干预的情况下去应付各种各样的失败事件。 Redis Sentinel同时提…

Vivado sdk 20:41:22 ERROR : Error occurred while creating hardware platform错误

20:41:22 ERROR : Error occurred while creating hardware platform adrv9009_hw_platform_0 from sysdef java.io.FileNotFoundException: D:\workspace\project2024\project\adrvxxxx (拒绝访问。) at java.io.FileInputStream.open0(Native Method) at java.io.FileInputSt…

OpenHarmony实战:标准系统移植指南

本文描述了移植一块开发板的通用步骤&#xff0c;和具体芯片相关的详细移植过程无法在此一一列举。后续社区还会陆续发布开发板移植的实例供开发者参考。 定义开发板 本文以移植名为MyProduct的开发板为例讲解移植过程&#xff0c;假定MyProduct是MyProductVendor公司的开发板…

RC滤波电路

RC滤波电路 综述&#xff1a;本文简单讲述了RC低通滤波电路和RC高通滤波电路。 滤波电路是指过滤输入信号中不需要的信号&#xff0c;保留需要的信号。 一、RC低通滤波电路 1.定义&#xff1a;RC低通滤波电路&#xff1a;保留低频信号&#xff0c;衰减高频信号。 2.截止频率…

突破校园网限速:使用 iKuai 多拨分流负载均衡 + Clash 代理(内网带宽限制通用)

文章目录 1. 简介2. iKuai 部署2.1 安装 VMware2.2 安装 iKuai(1) 下载固件(2) 安装 iKuai 虚拟机(3) 配置 iKuai 虚拟机(4) 配置 iKuai(5) 配置多拨分流 2.3 测试速度 3. Clash 部署3.1 准备工作(1) 配置磁盘分区(2) 安装 Docker(3) 安装 Clash(4) 设置代理 1. 简介 由于博主…

014——超声波模块驱动开发Plus(基于I.MX6uLL、SR04和poll机制)

目录 一、基础知识 二、分析为什么打印会影响中断 三、驱动程序 四、应用程序 五、验证及其它 一、基础知识 013——超声波模块驱动开发&#xff08;基于I.MX6uLL与SR04&#xff09;-CSDN博客 二、分析为什么打印会影响中断 asmlinkage __visible int printk(const ch…

Vue的双向绑定v-model详细介绍

使用&#xff1a; 比如用户在登录注册时需要提交账号密码&#xff1b; 比如用户创建&#xff0c;更新时&#xff0c;需要提交一些数据&#xff1b; v-model指令可以在表单 input、textarea以及select元素上创建双向绑定&#xff1b; 它会根据控件类型自动选取正确的方法来更…

一条SQL查询语句是如何执行的

这是专栏的第一篇文章&#xff0c;我想来跟你聊聊 MySQL 的基础架构。我们经常说&#xff0c;看一个事儿千万不要直接陷入细节里&#xff0c;你应该先鸟瞰其全貌&#xff0c;这样能够帮助你从高维度理解问题。同样&#xff0c;对于 MySQL 的学习也是这样。平时我们使用数据库&a…

Windows11安装MySql-8.0.36安装详细教程(保姆级教程)

之前一直用的mysql5.7&#xff0c;最近导入一个项目一直报错&#xff0c;经查阅发现数据库mysql版本太老&#xff0c;今天特地重头下载安装配置一下&#xff0c;做个记录供大家参考。 下载安装包&#xff1a; 下载地址&#xff1a;https://dev.mysql.com/downloads/ 进入后选…

【linux】公共服务器如何清理过多的.cache缓存

【linux】公共服务器如何清理过多的.cache缓存. 【先赞后看养成习惯】求关注+点赞+收藏😀 问题叙述:用的公共服务器,管理员反映.cache缓存过大,让我清理一下 .cache介绍:在Linux系统中,.cache目录通常用于存储应用程序运行时生成的缓存文件。这些文件包括临时文件、预览…

C++STL--排序算法

sort 使用快速排序,平均性能好O(nlogn),但最差情况可能很差O(n^2)。不稳定。 sort(v.begin(),v.end());//对v容器进行排序,默认升序 sort(v.begin(),v.end(),greater<int>());//降序排序对于支持随机访问的迭代器的容器&#xff0c; 都可以利用sort算法直接对其进行排序…

滑动窗口算法 - LC76 最小覆盖子串

接上文滑窗基础题&#xff1a;滑动窗口算法 - LC3 无重复字符的最长子串-CSDN博客&#xff0c;介绍了滑窗的基础题目和滑窗解法模板&#xff0c;这次带来滑窗进阶题解。 76. 最小覆盖子串 困难 给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果…

基于SSM的师生交流平台

目录 背景 技术简介 系统简介 界面预览 背景 传统的师生互动平台主要依赖于面对面的线下交流&#xff0c;用户必须亲自到场以获取和交流相关信息。然而&#xff0c;随着信息技术的广泛传播&#xff0c;众多教育机构开始转向线上发展&#xff0c;寻求更多样化的发展途径。线…

day17-二叉树part04

110.平衡二叉树 &#xff08;优先掌握递归&#xff09;后序遍历 左右中 class Solution {public boolean isBalanced(TreeNode root) {return getHeight(root) ! -1;}//递归三部曲 确定方法的参数与返回值private int getHeight(TreeNode root){//明确终止条件if(root null){r…

数据库管理-第168期 惯性(20240402)

数据库管理168期 2024-04-02 数据库管理-第168期 惯性&#xff08;20240402&#xff09;1 加法的惯性2 创新的惯性3 长期的责任总结 数据库管理-第168期 惯性&#xff08;20240402&#xff09; 作者&#xff1a;胖头鱼的鱼缸&#xff08;尹海文&#xff09; Oracle ACE Associa…

JS-优先级相关出现的一个小问题

console.log("嵌套函数中调用fn this值被赋给self" self o);这个输出会是 false。 在 JavaScript 中&#xff0c;比较两个对象是否相等时&#xff0c;实际上比较的是它们在内存中的引用地址&#xff0c;而不是它们的属性值。即使两个对象有相同的属性值&#xff…

C++11:声明 初始化

C11&#xff1a;声明 & 初始化 初始化{ }初始化initializer_list 声明autodecltypenullptr 初始化 { }初始化 在C98中&#xff0c;允许使用花括号{ }对数组或者结构体元素进行统一的列表初始化。 用{ }初始化数组&#xff1a; int arr[] { 1, 2, 3, 4, 5 };用{ }初始化…