为MySQL数据库的InnoDB引擎配置裸设备(Raw Device)

MySQL 的 InnoDB 存储引擎不仅可以缓存索引,而且还可以缓存数据,如果将其表和索引存储在裸设备(Raw Device)上,从而绕过了文件

mysql 的 innodb 存储引擎不仅可以缓存索引,而且还可以缓存数据,如果将其表和索引存储在裸设备(raw device)上,从而绕过了文件系统的高速缓存和缓冲器而直接访问磁盘,,那么将大大降低linux文件系统的负担,使系统性能获得显著改善。

另外,从裸设备在数据库应用的优化原理中,我们也可以看到优化数据库的一个基本方向,就是如何设法降低因数据库特有的 I/O 密集型访问所导致的文件系统的繁重负担。因此,即使在现有的基于文件系统的数据库存储引擎上,也可考虑使用特殊的文件系统挂载方式。
例如为存储数据库文件的分区使用 noatime 作为挂载参数,由于访问次数(access times)不再被记录 可以带来系统性能的一定程度的提升。

──────────────────────────────────────────────────────────────────────────────
本笔记最新配置之系统环境:
──────────────────────────────────────────────────────────────────────────────
OS:  CentOS6
HDD:  /dev/sdc /dev/sdd
RAW:  /dev/raw/raw1 /dev/raw/raw2
MySQL:  5.1.61
USER:  mysql:mysql

参考官方网站的配置指引:

──────────────────────────────────────────────────────────────────────────────
(1) 设置裸设备(Prepare the raw device)
──────────────────────────────────────────────────────────────────────────────
在使用裸设备之前,必须先将磁盘设备绑定到裸设备上:

# /bin/raw /dev/raw/raw1 /dev/sdc;
——————————————————————————–
/dev/raw/raw1:  bound to major 8, minor 32
——————————————————————————–

再绑定另一个裸设备,然后还要让您的MySQL数据库的运行用户有权读写裸设备:

# /bin/raw /dev/raw/raw2 /dev/sdd;
# chown root:mysql /dev/raw/raw1 /dev/raw/raw2;
# chmod 0660 /dev/raw/raw1 /dev/raw/raw2;

# /bin/raw -qa;
# /bin/raw -q /dev/raw/raw1;
# /bin/ls -l /dev/raw/raw1;
# blockdev –report /dev/raw/raw1;
# blockdev –report /dev/sdc;

vi /etc/udev/rules.d/60-raw.rules;
——————————————————————————–
ACTION==”add”, KERNEL==”sdc”, GROUP==”mysql”, MODE==”0660″, RUN+=”/bin/raw /dev/raw/raw1 %N”
ACTION==”add”, KERNEL==”sdd”, GROUP==”mysql”, MODE==”0660″, RUN+=”/bin/raw /dev/raw/raw2 %N”
——————————————————————————–
Note: this make sure device /dev/sdc and /dev/sdd will bind automatically when server reboot.

# vi /etc/udev/rules.d/41-local-permissions-rules;

──────────────────────────────────────────────────────────────────────────────
(2) 如有需要,先备份旧有的InnoDB数据表
──────────────────────────────────────────────────────────────────────────────
如果您的数据库已经运行,并且现有数据存储于旧的InnoDB引擎之中,如果您需要迁移的话,
请在关闭数据库之前预先用mysqldump命令导出您的数据, 等新引擎配置好之后再导入即可。

可参考如下SQL命令查看和导出您的InnoDB数据表:

mysql> SELECT table_schema,table_name,engine FROM INFORMATION_SCHEMA.TABLES;
mysql> SELECT table_schema, table_name FROM INFORMATION_SCHEMA.TABLES WHERE engine=’InnoDB’;

如有需要,可用mysqldump导出数据,请参考如下格式(请用相应的数据库和表名称):

mysqldump -u root -p -h localhost [database].[table] > database.table.sql

注意:您必须逐个表导出旧的数据。

──────────────────────────────────────────────────────────────────────────────
(3) 初始化阶段MySQL的配置
──────────────────────────────────────────────────────────────────────────────
When you create a new data file, put the keyword newraw
immediately after the data file size in innodb_data_file_path:

# vi /etc/my.cnf;
——————————————————————————–
[mysqld]
innodb_buffer_pool_size=128M
innodb_data_home_dir=
innodb_data_file_path=/dev/raw/raw1:64Mnewraw;/dev/raw/raw2:64Mnewraw
——————————————————————————–

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1913722.html

(0)
上一篇 2025年2月22日 17:37:13
下一篇 2025年2月22日 17:37:35

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • MySQL 5.6之innodb导入的改进

    在MySQL 5.6之前,导入单个innodb表的idb文件需要对齐tablespace id,而如果tablespace id不一致,就需要通过在新库不挺的新建表 在mysql 5.6之前,导入单个innodb表的idb文件需要对齐tab…

    数据库 2025年2月23日
    100
  • InnoDB: Error: io_setup() failed with EAGAIN after 5 attempt

    在一台服务器中以各数据库的备份文件为数据文件启动多个MySQL实例供SQL Review使用。之前运行一直没有问题(最多的时候有23个MyS 在一台服务器中以各数据库的备份文件为数据文件启动多个mysql实例供sql review使用。之前…

    数据库 2025年2月23日
    100
  • InnoDB与Oracle单行存储长度对比

    众所周知,MySQL InnoDB存储引擎与Oracle非常相似,支持事务,row-locking,经过实际测试,innodb与oracle一个比较大的差异点为,相 众所周知,MySQL InnoDB存储引擎与Oracle非常相似,支持事务…

    数据库 2025年2月23日
    100
  • MySQL中特殊的SQL用法

    作为数据库软件,mysql和oracle等都是基于标准的sql,但还是存在一些异同,这里对不同点进行列举:1、limit (注意行号从0开始) 作为数据库软件,mysql和Oracle等都是基于标准的sql,但还是存在一些异同,这里对不同点…

    数据库 2025年2月22日
    100
  • Redhat下MySQL 5.5.20安装配置

    mysql 最新的版本都需要cmake编译安装,估计以后的版本也会采用这种方式,所以特地记录一下安装步骤及过程,以供参考。注意:此安 mysql 最新的版本都需要cmake编译安装,估计以后的版本也会采用这种方式,,所以特地记录一下安装步骤…

    数据库 2025年2月22日
    100
  • MySQL 查询随机条记录的sql语句和php计算概率

    最近在网上找了下mysql查询随机的几个sql,我把最终的记录下来。 SELECT * FROM uchome_mtag AS a JOIN (SELECT MAX(tagid) AS i 最近在网上找了下mysql查询随机的几个sql,我…

    数据库 2025年2月22日
    100
  • 在MySQL中利用外键实现级联删除

    首先,目前在产品环境可用的MySQL版本(指4.0.x和4.1.x)中,只有InnoDB引擎才允许使用外键,所以,我们的数据表必须使用InnoDB引 首先,目前在产品环境可用的MySQL版本(指4.0.x和4.1.x)中,只有InnoDB引…

    数据库 2025年2月22日
    100
  • MySQL互为主从复制常见问题

    报错:1)change master导致的: Last_IO_Error: error connecting to master 报错:1)change master导致的:              Last_IO_Error: erro…

    数据库 2025年2月22日
    100
  • MySQL 创建用户自定义函数

    为了防止分号产生的中途输出,自己定义一个 分隔符,这里仿照mysql官方的例子:使用两个美元符号 $$ 作为分割符号,下面这段代码 为了防止分号产生的中途输出,自己定义一个 分隔符,这里仿照mysql官方的例子:使用两个美元符号 $$ 作为…

    数据库 2025年2月22日
    100
  • 用MySQL创建数据库和数据库表的SQL命令

    1、使用SHOW语句找出在服务器上当前存在什么数据库: mysqlgt; SHOW DATABASES; +———-+ | Database | +———-+ 1、使用…

    数据库 2025年2月22日
    100

发表回复

登录后才能评论