Java“设备上没有剩余空间”但磁盘上有足够的空间?

问题描述 投票:0回答:2

我试图在 Java 程序中将文件写入文件系统,但它失败了,当 df -h(和 df -i)另有说明时抛出“设备上没有剩余空间”的异常。

这是 df -h 的输出:

Filesystem      Size  Used Avail Use% Mounted on
udev            5.9G  4.0K  5.9G   1% /dev
tmpfs           1.2G  1.4M  1.2G   1% /run
/dev/sda5       156G  139G  9.1G  94% /
none            4.0K     0  4.0K   0% /sys/fs/cgroup
none            5.0M     0  5.0M   0% /run/lock
none            5.9G  105M  5.8G   2% /run/shm
none            100M   28K  100M   1% /run/user
/dev/sda2       105G  102G  2.7G  98% /media/sam/System 
/dev/sda3       176G  163G   14G  93% /media/sam/Sam //where I'm trying to write

这是 df -i 的输出:

Filesystem       Inodes    IUsed    IFree IUse% Mounted on
udev            1523763      552  1523211    1% /dev
tmpfs           1526458      584  1525874    1% /run
/dev/sda5      10362880  4750381  5612499   46% /
none            1526458        2  1526456    1% /sys/fs/cgroup
none            1526458        3  1526455    1% /run/lock
none            1526458      191  1526267    1% /run/shm
none            1526458       26  1526432    1% /run/user
/dev/sda2       3832820  1045155  2787665   28% /media/sam/System 
/dev/sda3      35769712 22090147 13679565   62% /media/sam/Sam //where I'm trying to write

我正在尝试将文件写入 /media/sam/Sam/。我试过重新启动我的机器,卸载并再次安装但没有运气。同样在 Java 中,如果我在 /media/sam/Sam 中创建一个新文件对象并打印使用信息,它会打印 0,如下所示:

File tweetFile = new File( "/media/sam/Sam/" + "test"  + ".txt" );
System.out.println( tweetFile.getTotalSpace()  ); // prints 0
System.out.println( tweetFile.getFreeSpace()/1000000000 ); // prints 0
System.out.println( tweetFile.getUsableSpace()/1000000000 ); // prints 0

非常感谢您的帮助,因为我一整天都在尝试解决此问题并感到非常沮丧。

编辑 这是抛出的确切消息:

Exception: java.io.IOException: No space left on device
java.io.IOException: No space left on device
    at java.io.UnixFileSystem.createFileExclusively(Native Method)
    at java.io.File.createNewFile(File.java:1006)
    at utils.FileUtil.writeToFile(FileUtil.java:64)
    at experiments.usinglists.tagbasedeval.ToindexTweetsForAUser.main(ToindexTweetsForAUser.java:36)
java file-io ubuntu-14.04
2个回答
0
投票

在我的例子中,Java 进程使用临时目录运行,使用默认的 java.io.tmpdir(在我的例子中是 /tmp)。

我期待它在另一个分区中工作。所以也许改变默认的作品:

-Djava.io.tmpdir=/media/sam/Sam/tmp

0
投票

看起来问题可能与 inode 使用有关。文件系统正在使用其 62% 的 inode,而您尝试写入的目录也有很高比例的 inode 在使用 - 35769712 中的 22090147。您可能需要释放一些 inode 空间才能写入文件。您可以通过删除一些现有文件,将它们移动到另一个目录或使用诸如“tune2fs”之类的工具来手动增加文件系统上可用的 inode 数量来实现此目的。

© www.soinside.com 2019 - 2024. All rights reserved.