上周末晚上运营做直播,业务代码不规范,访问1个redis竟然把1台服务器的网卡打满了,这台服务器上的其他redis服务都受到了影响。之前没有做这方面的预案,当时又没有空闲的机器可以迁移,在当时一点办法都没有,尴尬啊,就这样拖到了直播结束。结束后做复盘,leader对数据库这边要求必须对数据库使用服务器资源有限制方案。结合我们的数据库部署情况,mysql都是单实例部署,问题不大;redis是直接在服务器上做多实例部署,因此主要就是限制redis的cpu和网卡流量。

1. linux如何限制网卡流量

流量控制的基本概念是队列(Qdisc),每个网卡都与一个队列(Qdisc)相联系, 每当内核需要将报文分组从网卡发送出去, 都会首先将该报文分组添加到该网卡所配置的队列中, 由该队列决定报文分组的发送顺序。在队列中将不同的报文使用不同的过滤器(Filter)来分组分成不同的类别(Class),并根据不同的原则, 以不同的顺序发送队列中的报文分组。

2. 带宽互斥

2.1 针对网卡建立根htb队列:

需要限流的端口为 9001, 网卡为 eth0

v_port=9001

veth=eth0

tc qdisc add dev ${veth} root handle 1:0 htb default 11

#add dev ${veth} 表示针对 veth 网卡创建队列

#root 表示添加的是1个根队列

#handle 1:0 标识该队列

#htb 表示要添加的队列为HTB队列

#default 11 是htb队列特有的参数,表示所有未分类的流量都分配给 1:11

2.2 为根队列创建两个类别:

tc class add dev ${veth} parent 1:0 classid 1:11 htb rate 64mbps ceil 64mbps burst 640k

tc class add dev ${veth} parent 1:0 classid 1:12 htb rate 64mbps ceil 64mbps burst 640k

#parent 1:0 表示类别的父亲为根队列 1:0

#classid 1:11 标识该类别;其中 1:11 为1.1中指定的未分类的流量分配类别

#rate 64Mbit 表示系统为该类别确保带宽为 64M

#ceil 64Mbit表示该类别最高可占用带宽为 64M

#burst 640k 令牌桶大小,应对突发流量,官方建议1M/s数据流对应 10k的令牌桶大小

2.3 为各个类别设置过滤器

对出口流量进行限制

tc filter add dev ${veth} protocol ip parent 1:0 prio 1 u32 match ip sport ${v_port} 0xffff flowid 1:12

#protocol ip 表示过滤器检查tcp报文分组的协议字段

#prio 1 表示这些过滤器对报文处理的优先级是相同的,对于不同优先级的过滤器,系统将按照从小到大的优先级

#u32 match ip sport ${v_port} 0xffff  表示采用 u32 选择器来匹配不同的数据流,sport表示匹配的是sport字段, 如果该字段与 0xffff的与操作结果是 ${v_port}

#flowid 1:12 表示将该数据流分配给类别 1:12

这种方式共创建了两个类别,1:11 和 1:12, 1:11给为未分类的流量使用,1:12给分类的流量使用;这两个类别的数据流之间是互斥的,即当 1:11 的数据流没有达到最大流量配额时,剩余的带宽不能被 1:12 数据流使用,造成了带宽浪费。

3. 多个数据流共享一定的带宽

3.1 针对网卡建立根htb队列:

v_port=9001

veth=eth0

tc qdisc add dev ${veth} root handle 1:0 htb default 11

3.2 为根队列创建根类别

tc class add dev ${veth} parent 1:0 classid 1:1 htb rate 128mbps ceil 128mbps burst 1280k

tc class add dev ${veth} parent 1:1 classid 1:11 htb rate 64mbps ceil 128mbps burst 640k

tc class add dev ${veth} parent 1:1 classid 1:12 htb rate 64mbps ceil 128mbps burst 640k

# 类别 1:11 和 1:12 是 1:1 的子类别,因此他们可以共享分配的 128M带宽,同时,又确保当需要时,自身的带宽至少有 64M。

3.3 为类别设置过滤器

tc filter add dev ${veth} protocol ip parent 1:0 prio 1 u32 match ip sport ${v_port} 0xffff flowid 1:12

这种方式下带宽在各个类别之间进行共享,同时又确保各进程有一定的基础带宽。

4. desc

4.1 显示队列状况

tc -s qdisc ls dev ${veth}

4.2 显示分类状况

tc -s class ls dev ${veth}

4.3 显示过滤器的状况

tc -s filter ls dev ${veth}

5. 维护操作

5.1 过滤器删除

tc filter del dev ${veth} parent 1:0 prio 1 u32 match ip sport ${v_port} 0xffff

5.2 类别删除

5.3 队列删除

tc qdisc del dev ${veth} root

## 队列删除之后,该队列上的类别、过滤器都会被删除

6. 对CPU进行限制

isolcpus 是将指定的CPU从内核调度算法中删除,使得操作系统不会向指定的CPU上调度任务,将指定的CPU孤立出来。同时,通过taskset亲和性设置将指定的进程指定到特定的CPU上运行;通过这种方式,确保redis进程和系统进程 、监控进程等互相隔离,同时确保各redis进程之间互相隔离。

6.1 设置方式:
a.  centos6: 在 /boot/grub/grub.conf 文件中定位到 kernel /vmlinuz-2.6.32-431.el6.x86_64 ro root=UUID=08143ae2-e0ba-4181-a1f7-02ec210cded6 rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun16 crashkernel=auto  KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM rhgb quiet   这一行,在这一行后面添加启动参数 isolcpus=2,3,4 来设置需要孤立的CPU;而后重启系统,通过 cat /proc/cmdline 命令来进行验证。

b. 在进程启动后通过 taskset -pc ${cpunum} ${pid} 来设置CPU亲和。

redis在物理机部署模式下如何进行资源[cpu、网卡]隔离的更多相关文章

  1. Nginx+Docker部署模式下 asp.net core 获取真实的客户端ip

    目录 Nginx+Docker部署模式下 asp.net core 获取真实的客户端ip 场景 过程还原 结论 参考资料 Nginx+Docker部署模式下 asp.net core 获取真实的客户端 ...

  2. Apache Spark技术实战之8:Standalone部署模式下的临时文件清理

    未经本人同意严禁转载,徽沪一郎. 概要 在Standalone部署模式下,Spark运行过程中会创建哪些临时性目录及文件,这些临时目录和文件又是在什么时候被清理,本文将就这些问题做深入细致的解答. 从 ...

  3. Apache Spark技术实战之6 --Standalone部署模式下的临时文件清理

    问题导读 1.在Standalone部署模式下,Spark运行过程中会创建哪些临时性目录及文件? 2.在Standalone部署模式下分为几种模式? 3.在client模式和cluster模式下有什么 ...

  4. Apache Spark源码走读之15 -- Standalone部署模式下的容错性分析

    欢迎转载,转载请注明出处,徽沪一郎. 概要 本文就standalone部署方式下的容错性问题做比较细致的分析,主要回答standalone部署方式下的包含哪些主要节点,当某一类节点出现问题时,系统是如 ...

  5. vmware桥接模式下主机有多个网卡导致虚拟机网络不通

    桥接模式下,vmware会绑定一个物理网卡,因此有多个物理网卡时就要注意当前绑定的物理网卡.打开如下vmware菜单 可以看到VMnet0是桥接模式用的,然后他可以选择绑定一个物理网卡,注意要正确选择 ...

  6. IIS8集成模式下打开静态资源被aspx处理程序处理,StaticFileModule失效问题分析

    问题描述: 打开js,css,jpg之类的静态资源文件触发了asp.net mvc的权限认证,并不是直接返回静态内容 问题分析: StaticFileModule 失效 ,可能是文件权限问题 问题解决 ...

  7. win10的VMware虚机host-only模式下,虚拟机无法ping通物理机,而物理机能ping通虚机

    1.打开控制面板—->Windows防火墙(win10操作系统) 2.点击最上面的”允许应用或功能通过xxxxx” 3.勾上上图的“文件和打印机共享” 然后点确定.

  8. redis 学习笔记3(哨兵模式下分布式锁的实现以及全局唯一id的生成)

    redis实现分布式锁和全局唯一id应该是较为常见的应用. 实现基于redis的setNX,以及incr命令.还是比较简单的! 搭建环境以及配置好sping整合,做了下测试,有兴趣的载下来看看,自己做 ...

  9. redis几种模式的部署(Windows下实现)

    <参考>http://www.cnblogs.com/ruiati/p/6374152.html 1.   自行下载redis客户端.redis官方不支持Windows系统,所以官网上是下 ...

随机推荐

  1. Mybatis结果集ResultMap映射

    基本使用: 解决属性名和数据库字段名不一致的问题 <resultMap id="user" type="com.guan.bean.UserBean"&g ...

  2. &取地址运算符

    &可以取得一个变量在内存当中的地址 Register int a; //这种变量不在内存里面,而在CPU里面,是没有地址的, 所以寄存器变量(register)不能用&来取得变量 在计 ...

  3. UIautomatorviewer连接设备报错Unexpected error while obtaining UI hierarchy

    先来看下现象哈,点击sdk/tools下uiautomatorviever.bat,点击连接设备的图标,本以为就这么简单,那你就错了: 是不是看到这个瞬间心情就不好了,那么我们该怎么解决这个问题呢,归 ...

  4. Spring Authorization Server 0.2.3发布,放出联合身份DEMO

    很快啊Spring Authorization Server又发新版本了,现在的版本是0.2.3.本次都有什么改动呢?我们来了解一下. 0.2.3版本特性 本次更新的新特性不少. 为公开客户端提供默认 ...

  5. 如何使用docker制作开发集成环境

    1. 编写最基本的Dockerfile 内容:touch 一个Dockerfile FROM ubuntu 2. 创建基本的docker镜像 docker build  -t ubuntu:v1 . ...

  6. 羽夏看Win系统内核——调试篇

    写在前面   此系列是本人一个字一个字码出来的,包括示例和实验截图.由于系统内核的复杂性,故可能有错误或者不全面的地方,如有错误,欢迎批评指正,本教程将会长期更新. 如有好的建议,欢迎反馈.码字不易, ...

  7. 不会DRF?源码都分析透了确定不来看?

    目录 不会DRF?源码都分析透了确定不来看? 快速使用DRF写出接口 序列化和反序列化 drf快速使用 views.py serializer.py urls.py 在settings的app中注册 ...

  8. springcloud断路器作用?

    当一个服务调用另一个服务由于网络原因或自身原因出现问题,调用者就会等待被调用者的响应 当更多的服务请求到这些资源导致更多的请求等待,发生连锁效应(雪崩效应)断路器有完全打开状态:一段时间内 达到一定的 ...

  9. CentOS7防火墙开启与关闭以及开放6379,3306,80等端口

    CentOS7用firewall防火墙替代了原来的iptables,所以我们应该使用firewall的一些命令.如下:1.关闭防火墙 systemctl stop firewalld.service ...

  10. 服务注册和发现是什么意思?Spring Cloud 如何实现?

    当我们开始一个项目时,我们通常在属性文件中进行所有的配置.随着越来越多的服务开发和部署,添加和修改这些属性变得更加复杂.有些服务可能会下降,而某些位置可能会发生变化.手动更改属性可能会产生问题.Eur ...