MySQL与RAID
RAID在mysq中适用场景
raid0:由于性能高和成本低,以及基本没有数据恢复的能力,而且它比单片磁盘损坏的概率要高。建议只在不担心数据丢失的情况下使用,如备库(slave)或者某些原因"一次性使用"的时候。
raid1:在很多情况下提供很好的读性能(比raid0要快),并且提供冗余。它非常适合存放日志这样顺序写操作的东西
raid5:由于raid5级有性能上的提示,而且提供冗余,磁盘利用率也和高,所以在某些应用方面是个不错的选择。raid5在读方面还很好(随机读和顺序读),因为不需要考虑校验机制的问题。但是在写方面raid5需要两次读写的操作,所以随机写代价很大,但是顺序写还可以接受。Raid5一般用于以读为主的业务中,如果像日志这样的顺序写也可以。
另外,raid5在生产环境中使用(MySQL),一旦出现一块盘的损坏,那么它将立即根据校验机制来恢复数据,而此时的I/O就会很高,性能将慢到2-5倍,如果业务上对MySQL服务器压力也很大,那么MySQL或者系统有可能有崩溃的危险。
硬件的raid5性能上也很强大了,基本上可达到raid10的性能水准
raid10:读写性能都很好,相对于RAID来说,它重建起来很简单,速度也很快。但是当有一块磁盘损坏的使用,整体读的性能将会有所下降.软件RAID对raid10也有很好的支持
raid50:如果有很多盘的话,这可能是raid5的经济和raid10高性能的折中。主要用于存放庞大的数据集,例如数据仓库或者非常庞大的OLTP系统
Raid的缓存和配置:
raid条带化,理论上来讲,对随机读写来说,更大的块更好,这样数据就不用跨块读取,也就说可以在单个磁盘上读取。但在实践中,控制器可能把块大小,缓存大小,读取单元的大小匹配起来。最好情况是把Innodb的块,文件系统的块,LVM,分区偏移,RAID条带,磁盘扇区多有的块都对齐,这样性能会有15%-23%的提升
RAID缓存:
raid缓存读对MySQL来说,并不好。因为MySQL有自己缓存机制。一般在操作系统层面和MySQL自身的缓存层级可以读到的数据就不会读取raid中的缓存的数据,但是没有命中数据,raid中的缓存也基本不可能存在
Raid预读:如果数据库服务器设定了有自己的预读机制(如Innodb),此时的预读可能对MySQL有反作用
raid的缓存写入:raid控制器可以在高速缓存例缓冲写操作,并且一段时间在写到磁盘中,这样一来磁盘反馈给内核写"成功"信号将快得多。其次,通过累计的写,可以将随机写变成顺序写。
写入缓存对同步写入用处很大,例如事务日志和二进制日志,但是raid控制器一定要有独立的电池,这样能在断电的时候,不至于损坏数据库和事务性文件系统。一般生产环境最好先做断电测试。
通常情况下,对于raid0,raid1,raid10应该把控制器缓存100%分配给写入用;对于raid5来说,应该保留一些内存给内部操作。
raid监控:
硬件raid:一般使用厂商提供的或者使用开源软件监控:MegaCli或者lsiutil
软件raid:cat /proc/mdstat
这里我只是做个了解:
http://imysql.com/2014/09/11/pc-server-raid-controller-disk-health-monitoring.shtml
http://blog.chinaunix.net/uid-25135004-id-3139293.html
MySQL与RAID的更多相关文章
- MySQL数据库Raid存储方案
作为一名DBA,选择自己的数据存储在什么上面,应该是最基本的事情了.但是很多DBA却容易忽略了这一点,我就是其中一个.之前对raid了解的并不多,本文就记录下学习的raid相关知识. 一.RAID的基 ...
- 【Linux】系统 之 RAID
本人从事DBA相关的工作,最近遇到了IO抖动伴随shread running抖动的情况,主机宕机重启后备库及下游解析binlog出现损坏的案例,向一些有经验的同事咨询学习,其中最大的嫌疑是:raid卡 ...
- MYSQL SHOW VARIABLES简介
原文地址:http://www.2cto.com/database/201108/100546.html mysqld服务器维护两种变量.全局变量影响服务器的全局操作.会话变量影响具体客户端连接相关操 ...
- MySql配置参数很全的Mysql配置参数说明
MySql配置参数 很全的Mysql配置参数说明 1. back_log 指定MySQL可能的连接数量.当MySQL主线程在很短的时间内得到非常多的连接请求,该参数就起作用,之后主线程花些时间(尽管很 ...
- 查找mysql数据文件存放路径
show variables like 'datadir%'; show variables当前的会话,是系统参数 是静态 show global variables全局 show status是系统 ...
- mysql show variables
1. back_log 指定MySQL可能的连接数量.当MySQL主线程在很短的时间内得到非常多的连接请求,该参数就起作用,之后主线程花些时间(尽管很短)检查连接并且启动一个新线程. back_log ...
- mysql 开发进阶篇系列 21 磁盘I/O问题(RAID)
一.概述 作为应用系统的持久化层,不管数据库采取了什么样的Cache机制,数据库最终总是要将数据储存到可以长久保存的I/O设备磁盘上.但磁盘的存取速度显然要比cpu,ram的速度慢很多.因此,对于比较 ...
- MySQL Disk--SSD与RAID
===================================================SSD与RAID 51.在RAID 5这类Parity-RAID上存在partial-stripe ...
- MySQL优化聊两句
原文地址:http://www.cnblogs.com/verrion/p/mysql_optimised.html MySQL优化聊两句 MySQL不多介绍,今天聊两句该如何优化以及从哪些方面入手, ...
随机推荐
- POJ3080 Blue Jeans —— 暴力枚举 + KMP / strstr()
题目链接:https://vjudge.net/problem/POJ-3080 Blue Jeans Time Limit: 1000MS Memory Limit: 65536K Total ...
- CSS animation-timing-function 属性中的 steps() 与 step-start,step-end
steps() 设置间隔参数,可以实现分步过渡 第一个参数指定了时间函数中的间隔数量(必须是正整数)第二个参数可选,接受 start 和 end 两个值,指定在每个间隔的起点或是终点发生阶跃变化,默认 ...
- 后缀自动机SAM BZOJ 2806
终于遇到了一道后缀数组不能过 一定要学SAM的题... (看了半个下午+半个上午) 现在总结一下(是给我自己总结..所以只总结了我觉得重要的 .. 看不太懂的话可以To http://blog.c ...
- ng 表单提交验证
http://www.runoob.com/try/try.php?filename=try_ng_validate
- http监听工具Fildder
空间管理您的位置: 51Testing软件测试网 » 雨洒泪 » 日志 中国龙,中国风,中国会变得更加强大! 力量越大,责任越大! 人的一生,会面临很多选择,但决定一个人一生的,往往就是最关键那么的一 ...
- Linux下安装oracle数据库提示DISPLAY not set. Please set the DISPLAY and try again。
错误如下: Ignoring required pre-requisite failures. Continuing... Preparing to launch Oracle Universal I ...
- 构建Docker平台【第一篇】环境准备
主机信息 操作系统版本 CentOS-7-x86_64-Everything-1511 主机A 192.168.6.128 主节点 主机B 192.168.6.129 主节点 主机C 192.16 ...
- kafka之四:Kafka集群搭建
1.软件环境 1.linux一台或多台,大于等于2 2.已经搭建好的zookeeper集群 3.软件版本kafka_2.11-0.9.0.1.tgz 2.创建目录并下载安装软件 #创建目录 cd /o ...
- html语义化 -------<fieldset>和<legend>
为什么HTML代码要语义化,除了代码可读性好以外,SEO有帮助外,最主要的还是对一些屏幕阅读设备或者其他辅助阅读设备友好, 可以让用户在条件受限的条件下依然可以正常使用我们的产品,比方说鼠标坏了,又或 ...
- 【旧文章搬运】修改PEB,断链隐藏模块成功
原文发表于百度空间,2008-7-26========================================================================== 继续实践之前 ...