将 Nytro WarpDrive 加速卡配置为文件系统
本节说明的操作使您可调整 Nytro WarpDrive 加速卡,增强使用 Oracle Linux with
Unbreakable Enterprise Kernel (UEK) 操作系统的性能。这些配置步骤在 UEK 和 Oracle Linux
操作系统中均有效。以下步骤将 Nytro WarpDrive 卡为 MySQL 数据库的每个主服务器和从
服务器配置为一个文件系统。其他选项可用于加倍 Nytro WarpDrive 加速,并使用 RAID 提
供容错能力,实现额外的数据保护。
1. 在 Linux 操作系统中将 Nytro WarpDrive 卡与 1MB 边界对齐。以下示例介绍如何将
Nytro WarpDrive 卡分区作为从 1MB 边界开始的单一分区。
echo “2048,,” | sfdisk -uS /dev/sda
Disk /dev/sda: 24321 cylinders, 255 heads, 63 sectors/track
Units = sectors of 512 bytes, counting from 0
Device Boot Start End #sectors Id System
/dev/sda1 2048 390721535 390719488 83 Linux
/dev/sda2 0 - 0 0 Empty
/dev/sda3 0 - 0 0 Empty
/dev/sda40 0 - 0 0 Empty
2. 创建文件系统时绕过日志记录。采用 EXT-4 文件系统并关闭日志记录,而非使用 EXT-3,
消除某些情况下对 Nytro WarpDrive 卡的双重写入。写入的减少提高了性能并延长了 Nytro
WarpDrive 卡的寿命。
3. 创建 EXT-4 文件系统并关闭日志记录时:
$ mkfs –t ext4 /dev/sda1 或 mkfs.ext4 /dev/sda1
创建 EXT-4 文件系统后,日志记录默认开启。为进行验证,执行 tune4fs 命令:
$ tune4fs –l /dev/sda1 | grep ‘Filesystem features’
注意应列出“has_journal”功能。如需关闭日志记录,执行:
$ tune4fs -O ^has_journal /dev/sda1
4. 验证已关闭日志记录,执行以下命令并确保未列出“has_journal”。
$ tune4fs –l /dev/sda1 | grep ‘Filesystem features’
5. 加载新 EXT-4 设备时(以下描述 noatime 选项):
$ mount -o noatime /dev/sda1 /mountpoint
6. 修改内核 I/O 调度程序。最新 Linux 操作系统版本中的 I/O 调度程序具备
新的 I/O 能力,包括在启动时修改这些设置的选项。在本文件所描述的测试
中, DEADLINE I/O 调度程序与 noatime 文件系统加载选项配合使用。如需调用整
个系统的 DEADLINE 调度程序,将此行添加到 /etc/grub.conf 文件并重启系统。
$ kernel /vmlinuz-2.6.39-300.28.1.el6uek.x86_64 ro root=/dev/mapper/vg_nytrolv_root elevator=deadline
调用 DEADLINE IO 调度程序的另一种方式是使用以下命令修改 /etc/rc.local 文件:
$ echo “deadline” > /sys/block/sda/queue/scheduler
7. 如需确认已启用 DEADLINE 调度程序,将以下声明作为根发布。
$ cat /sys/block/sda/queue/scheduler
noop anticipatory [deadline] cfq 8. 除了更改 I/O 调度程序, noatime 文件系统加载选项已启用,并且添加到 /etc/fstab 文
件。
此选项在仅读取对象时使系统无需创建对文件系统的写入。此选项还允许更快速地访问文
件,并减少对 Nytro WarpDrive 卡的磨损。此例介绍了 /etc/fstab 如何调用 noatime 选项:
/dev/sda1 /osfc ext4 defaults,noatime 1 2
调用 noatime 选项的另一种方式是指在执行加载命令时制定此选项:
$ mount –o noatime /dev/sda1 /osfc 9. 将行列深度( QD)从默认的 128 提高到 256 或更高(取决于数据库工作负荷),可提
高 Nytro WarpDrive 的性能。由于 Nytro WarpDrive 卡的延迟是如此之小,与硬盘驱动器相
比, Nytro WarpDrive 卡上可同时运行多项 I/O 操作/命令。为了修改行列深度,需将
nr_requests 参数修改为与新行列深度相同或更大的值。以下为修改测试中所用 /dev/sda 的
nr_requests 和 queue_depth 参数的示例:
$ echo “512” > /sys/block/sda/queue/nr_requests IO调度队列大小
$ echo “512” > /sys/block/sda/device/queue_depth 磁盘队列深度 10. 通过告诉操作系统在启动其的相同 CPU 上完成 I/O 请求还可确认更多性能优点。在一
些工作负荷中,这可提供明显的性能提高。如需在 Nytro WarpDrive 设备中启用此功能:
echo “1” > /sys/block/sda/queue/rq_affinity
11. 可提供更高性能的另一个操作设置是将旋转设置设为 0,表示设备是非旋转设备,而是
一个闪存设备:
echo 0 > /sys/block/sda/queue/rotational
注:如需在重启时保持这些设置,将所有这些命令放入 /etc/rc.local 文件。

在操作系统中,I/O Scheduler的调度模式选择deadline对于数据库应用是有利的。命令:echo deadline > /sys/block//queue/scheduler

操作系统中nr_requests参数,可以提高系统的吞吐量,似乎越大越好,但是该请求队列的也不能过大,因为这样会消耗大量的内存空间。该值的调整需要综合多处因素,

比如: 文件系统、sheduler类型、io的特点。

命令: echo xxx > /sys/block//queue/nr_requestsnr_requests的大小设置至少是/sys/block//device/queue_depth的两倍,所以,修改nr_requtests的时候要注意。

Mysql : L闪存卡linux中的内核参数设置的更多相关文章

  1. 理解 Linux backlog/somaxconn 内核参数

    https://jaminzhang.github.io/linux/understand-Linux-backlog-and-somaxconn-kernel-arguments/ 各参数的含义:h ...

  2. (转)Linux内核参数设置sysctl命令详解

    Linux内核参数设置sysctl命令详解 原文:https://www.zhukun.net/archives/8064 sysctl是一个允许您改变正在运行中的Linux系统的接口. 它包含一些 ...

  3. Linux之TCPIP内核参数

    /proc/sys/net目录 参考1.Linux之TCPIP内核参数优化 所有的TCP/IP参数都位于/proc/sys/net目录下(请注意,对/proc/sys/net目录下内容的修改都是临时的 ...

  4. TCP三次握手与Linux的TCP内核参数优化

    感谢各位技术大佬的资料分享,这里我把我理解的内容做一个整理 一:TCP的三次握手 1.TCP简述 TCP是一个面向连接的协议,在连接双方发送数据之前,首先需要建立一条连接.TCP建立连接可以简单称为: ...

  5. linux中touch命令参数修改文件的时间戳(转)

    linux中touch命令参数不常用,一般在使用make的时候可能会用到,用来修改文件时间戳,或者新建一个不存在的文件,以下是linux中touch命令参数的使用方法: touch [-acm][-r ...

  6. 在Linux上进行内核参数调整

    在Solaris上,使用工具mdb就可以直接修改内核内存里的内容.而在Linux上,则通常使用命令sysctl(8)做类似的事情. 本文以Fedora为例,介绍如何在Linux上进行内核参数调整. 常 ...

  7. linux中touch命令参数修改文件的时间戳(转载)

    转自:http://os.51cto.com/art/200908/144237.htm linux中touch命令参数不常用,一般在使用make的时候可能会用到,用来修改文件时间戳,或者新建一个不存 ...

  8. Linux中mpstat命令参数详解

    Linux中mpstat命令参数详解 mpstat 是 Multiprocessor Statistics的缩写,是实时系统监控工具.其报告与CPU的一些统计信息,这些信息存放在 /proc/stat ...

  9. Swift语言中为外部参数设置默认值可变参数常量参数变量参数输入输出参数

    Swift语言中为外部参数设置默认值可变参数常量参数变量参数输入输出参数 7.4.4  为外部参数设置默认值 开发者也可以对外部参数设置默认值.这时,调用的时候,也可以省略参数传递本文选自Swift1 ...

随机推荐

  1. EF4 Code First和EF6 Code First链接mysql的方法

    1.首先需要下载安装.Net的Mysql驱动 下载地址如下:http://dev.mysql.com/downloads/connector/net/ 2.配置Web.Config EF6: 配置链接 ...

  2. 破解之关键CALL与关键跳查找方法

    找关键CALL和关键跳 方法一: 输入假码注册程序,记录下错误提示信息. OD载入程序--> 右键-->查找-->所有参考文本字串-->(右键-->查找文本,注:不要区分 ...

  3. Android LogCat 日志记录

    日志级别列表如下(从低到高): V — Verbose (lowest priority) D — Debug I — Info W — Warning E — Error F — Fatal S — ...

  4. 使用reuseport和recvmmsg优化UDP服务器

    http://skoo.me/system/2014/03/18/udp-server-performance/ http://www.helplib.net/s/linux.die/65_3223/ ...

  5. IP处理函数inet_aton()和inet_ntoa(),inet_pton,inet_ntop

    inet_ntoa: 功能: 将一个IP转换成一个互联网标准点分格式的字符串. 原型: char FAR * inet_ntoa( struct in_addr in); 返回值: 如果正确,返回一个 ...

  6. 【CF】135 Div2 Choosing Capital for Treeland

    树形结构,挺有意思的题目.不难. /* 219D */ #include <iostream> #include <string> #include <map> # ...

  7. Apache Struts 远程代码执行漏洞(CVE-2013-4316)

    漏洞版本: Apache Group Struts < 2.3.15.2 漏洞描述: BUGTRAQ ID: 62587 CVE(CAN) ID: CVE-2013-4316 Struts2 是 ...

  8. 基于开源软件在Azure平台建立大规模系统的最佳实践

    作者 王枫 发布于2014年5月28日 前言 Microsoft Azure 是微软公有云的唯一解决方案.借助这一平台,用户可以以多种方式部署和发布自己的应用. 这是一个开放的平台,除了对于Windo ...

  9. Javascript 母羊生小羊问题,递归

    农场买了一只小羊,这种羊在第一年是小羊,第二年的年底会生一只小羊,第三年不生小羊,第四年的年底还会再生下一只小羊,第五年就死掉了. 要计算N年时农场里有几只羊. [凡是碰到“一生二.二生三.三生万物” ...

  10. bzoj 1513 [POI2006]Tet-Tetris 3D(二维线段树)

    1513: [POI2006]Tet-Tetris 3D Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 540  Solved: 175[Submit ...