Linux 避免IO hang

简介:

 对于DB Server 来说,删除大表来说是很棘手的。

   删除大表的话,可以对原有表的.ibd文件建立硬链接。当多个文件名指向同一个Node时,删除任何一个文件名都很快,因为直连的物理文件没有删除只是删除了一个指针而已。当Node引用数为1的时候,删除文件需要把文件相关的所有数据块都删除。

具体参考:http://www.mysqlops.com/2011/05/18/mysql%E5%88%A0%E9%99%A4%E5%A4%A7%E8%A1%A8%E6%9B%B4%E5%BF%AB%E7%9A%84drop-table%E5%8A%9E%E6%B3%95.html

   今天我们只讨论,如果我们利用了以上方法建立了硬链接文件,那么删除该大文件的时候,如何避免IO hang呢?

   答案是 coreutils 工具集中的 truncate 工具

   wget http://ftp.gnu.org/gnu/coreutils/coreutils-8.9.tar.gz

     tar -zxvf coreutils-8.9.tar.gz
     cd coreutils-8.9
     ./configure
     make
     sudo cp src/truncate /usr/bin/ 
   truncate 收缩或扩展文件至指定大小
   语法: truncate option ... file ...
   如果文件不存在的话会被创建。
   如果一个文件的size比指定的size大,则该文件会被截断丢是一部分数据,如果size比指定的小,那么他会0字节填充。
   option:
   -c
   --no-create 如果没有该文件的话也不会创建

   -o
   --io-blocks 对于文件的size大小以I/O block来对待

   -r rfile 
   --reference=file Base the size of each file on the size of rfile

   -s size
   --size=size 根据下面的选项,调整文件的大小
      ‘KB’ => 1000 (KiloBytes)
      ‘K’ => 1024 (KibiBytes)
      ‘MB’ => 1000*1000 (MegaBytes)
      ‘M’ => 1024*1024 (MebiBytes)
      ‘GB’ => 1000*1000*1000 (GigaBytes)
      ‘G’ => 1024*1024*1024 (GibiBytes)
       或者是 T P E Z这样的单位
       根据下面的符号,根据他们本身的size来调整大小
       + 扩展
       - 缩小
       < 至多
       > 至少
       / 向下舍入的倍数
       % 向上的倍数

   简单举例:

   touch  abc

   truncate -s +1KB abc

   truncate -s +1KB abc

   ll abc

   -rwxrwxrwx 1 root root 2000 11月 28 05:31 abc

   欢迎各位讨论!  






本文转自 位鹏飞 51CTO博客,原文链接:http://blog.51cto.com/weipengfei/1072597,如需转载请自行联系原作者

目录
相关文章
|
27天前
|
网络协议 安全 Linux
Linux C/C++之IO多路复用(select)
这篇文章主要介绍了TCP的三次握手和四次挥手过程,TCP与UDP的区别,以及如何使用select函数实现IO多路复用,包括服务器监听多个客户端连接和简单聊天室场景的应用示例。
86 0
|
27天前
|
存储 Linux C语言
Linux C/C++之IO多路复用(aio)
这篇文章介绍了Linux中IO多路复用技术epoll和异步IO技术aio的区别、执行过程、编程模型以及具体的编程实现方式。
66 1
Linux C/C++之IO多路复用(aio)
|
3月前
|
缓存 安全 Linux
Linux 五种IO模型
Linux 五种IO模型
|
27天前
|
Linux C++
Linux C/C++之IO多路复用(poll,epoll)
这篇文章详细介绍了Linux下C/C++编程中IO多路复用的两种机制:poll和epoll,包括它们的比较、编程模型、函数原型以及如何使用这些机制实现服务器端和客户端之间的多个连接。
20 0
Linux C/C++之IO多路复用(poll,epoll)
|
3月前
|
小程序 Linux 开发者
Linux之缓冲区与C库IO函数简单模拟
通过上述编程实例,可以对Linux系统中缓冲区和C库IO函数如何提高文件读写效率有了一个基本的了解。开发者需要根据应用程序的具体需求来选择合适的IO策略。
29 0
|
3月前
|
存储 IDE Linux
Linux源码阅读笔记14-IO体系结构与访问设备
Linux源码阅读笔记14-IO体系结构与访问设备
|
4月前
|
Linux 数据处理 C语言
【Linux】基础IO----系统文件IO & 文件描述符fd & 重定向(下)
【Linux】基础IO----系统文件IO & 文件描述符fd & 重定向(下)
72 0
|
4月前
|
Linux 编译器 C语言
【Linux】基础IO----理解缓冲区
【Linux】基础IO----理解缓冲区
60 0
【Linux】基础IO----理解缓冲区
|
4月前
|
缓存 网络协议 算法
【Linux系统编程】深入剖析:四大IO模型机制与应用(阻塞、非阻塞、多路复用、信号驱动IO 全解读)
在Linux环境下,主要存在四种IO模型,它们分别是阻塞IO(Blocking IO)、非阻塞IO(Non-blocking IO)、IO多路复用(I/O Multiplexing)和异步IO(Asynchronous IO)。下面我将逐一介绍这些模型的定义:
179 1
|
5月前
|
Linux 编译器 C语言
【Linux】基础IO_4
【Linux】基础IO_4
26 3