加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

为什么linux命令(iostat)中的每秒读取数(r / s)始终为零?

发布时间:2020-12-13 23:03:46 所属栏目:Linux 来源:网络整理
导读:我运行一个 java代码,它会从文本文件中生成大量的读写内容.程序源非常简单,在循环中我在测试文件中写入2000行,然后我再次读取它们只是为了生成大量的磁盘读写.但是当程序运行时,我通过“iostat -d -x 1”监视磁盘我发现第二个“r / s”中的读取没有变化但是
我运行一个 java代码,它会从文本文件中生成大量的读写内容.程序源非常简单,在循环中我在测试文件中写入2000行,然后我再次读取它们只是为了生成大量的磁盘读写.但是当程序运行时,我通过“iostat -d -x 1”监视磁盘我发现第二个“r / s”中的读取没有变化但是“w / s”增加了我的预期!
这是iostat命令的示例输出:

Device: rrqm/s wrqm/s  r/s   w/s    rsec/s wsec/s   avgrq-sz avgqu-sz await svctm  %util
sda     0.00   913.00  0.00  82.00  0.00   7872.00   96.00    0.58    7.09   7.11  58.30

Device: rrqm/s wrqm/s  r/s   w/s   rsec/s  wsec/s  avgrq-sz  avgqu-sz  await  svctm  %util
sda     0.00   869.00  0.00  79.00  0.00   7584.00    96.00   0.57    7.11   7.18  56.70

Device: rrqm/s wrqm/s  r/s   w/s   rsec/s  wsec/s  avgrq-sz avgqu-sz   await  svctm  %util
sda     0.00   847.00  0.00  77.00  0.00   7392.00   96.00   0.57      7.42   7.43  57.20

Device: rrqm/s wrqm/s  r/s   w/s   rsec/s  wsec/s   avgrq-sz avgqu-sz  await  svctm  %util
sda     0.00  1221.00  0.00  113.00  0.00  10760.00  95.22    0.84     7.47   7.32  82.70

如图所示,所有“r / s”都为零!但在Java程序中,我读到的文件和我在文件中写的一样多吗?!当我运行Java代码时,每秒写入次数增加,但“r / s”没有变化!!
这是我在监视磁盘时运行的java代码:

import java.io.*;

public class Test {

    public static void main(String [] args) throws IOException{

    String fileName = "/scratch/dump_file.txt";
    File f = new File(fileName);
    // Attempt to delete it
    boolean success = f.delete();
    int j=0;
    while(j<20000)
    {
        ++j;
        Writer output = null;
        String text = "A test content";
        File file = new File(fileName);
        output = new BufferedWriter(new FileWriter(file));

        int i=1;
        while(i<2000)
        {
            //Here we start writing 2000 lines into file line by line
            output.write("j==="+Integer.toString(j)+text+Integer.toString(i)+"n");
            ++i;
        }
        output.close();
        System.out.println("Your file has been written");  

        String line = null;
        try {
            // FileReader reads text files in the default encoding.
            FileReader fileReader = new FileReader(fileName);
            BufferedReader bufferedReader = 
            new BufferedReader(fileReader);
            i=1;
            while((line = bufferedReader.readLine()) != null) {
                //Here we start reading from file line by line and show the result on screen
                ++i;
                System.out.println(line);
            }   
            // Always close file
            bufferedReader.close();         
        }
        catch(FileNotFoundException ex) {
            System.out.println(
                "Unable to open file '" + 
                fileName + "'");                
        }
        catch(IOException ex) {
            System.out.println(
                "Error reading file '" 
                + fileName + "'");                  
            // Or we could just do this: 
            // ex.printStackTrace();
        }
    }
}
}

解决方法

最有可能的是,操作系统将文件缓存在RAM中.因为它已经缓存在内存中,所以当你用Java读取时,操作系统不需要实际从磁盘读取 – 它只是为你提供了已经存在的缓存副本.这比实际从磁盘读取要快得多;但请注意,由于iostat仅报告实际的磁盘读写,因此您的缓存读取不会显示在那里.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读