我试图在 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 进程使用临时目录运行,使用默认的 java.io.tmpdir(在我的例子中是 /tmp)。
我期待它在另一个分区中工作。所以也许改变默认的作品:
-Djava.io.tmpdir=/media/sam/Sam/tmp
看起来问题可能与 inode 使用有关。文件系统正在使用其 62% 的 inode,而您尝试写入的目录也有很高比例的 inode 在使用 - 35769712 中的 22090147。您可能需要释放一些 inode 空间才能写入文件。您可以通过删除一些现有文件,将它们移动到另一个目录或使用诸如“tune2fs”之类的工具来手动增加文件系统上可用的 inode 数量来实现此目的。