【问题标题】:Java NIO FileLock allows other process to write to a locked fileJava NIO FileLock 允许其他进程写入锁定的文件
【发布时间】:2019-10-20 19:59:24
【问题描述】:

我正在使用以下代码在一个 Java 应用程序中获取对文件的锁定:

...

File file = new File("/some/file/at/some/path.txt");
FileChannel channel = new RandomAccessFile(file, "rw").getChannel();

FileLock lock = channel.tryLock();

if (lock != null) {
    Thread.sleep(60000); // Hold lock for 60 seconds 
    lock.release();
}

...

如果在上述 60 秒内,我使用以下代码运行另一个 java 应用程序,它无法获取锁(如预期的那样),但它仍然可以写入。

...

File file = new File("/some/file/at/some/path.txt");
System.out.println(file.canWrite());  // returns true (not expected)

FileChannel channel = new RandomAccessFile(file, "rw").getChannel();
FileLock lock = channel.tryLock();  
System.out.println(lock.toString());  // throws NullPointerException (expected)

...

同一个文件(当第一个应用程序持有锁时)也可由非 Java 应用程序(例如 vi、bash 等)写入。 Oracle docs 表示锁定映射到底层操作系统的本机锁定,因此对所有程序可见。因此,我希望锁定能够阻止任何其他进程在其上写入。

我的代码或理解中是否遗漏了什么?

我在 MacOS Mojave (10.14) 上运行上述代码。

【问题讨论】:

    标签: java nio file-locking filelock


    【解决方案1】:

    它还在您链接到“锁是否实际上阻止另一个程序访问锁定区域的内容是系统相关的,因此未指定”的文档中说。

    所以这取决于操作系统是否能够进行写锁定。

    【讨论】:

    • 对。是否有任何关于 FileLock 在各种操作系统上的行为的官方/非官方文档?
    • 我不知道。您需要检查操作系统的特定版本和您正在运行的 JVM 版本。
    • 是否至少可以保证在一个 JVM 上运行的应用程序在检查时可以看到另一个 JVM 中的应用程序获取的锁?就像我的问题中的一个例子。或者这也是特定于操作系统的?
    • 我不相信这是指定的,并且将再次取决于操作系统的锁定方法。文档指出,这些锁应被视为建议性的。
    • 我的猜测是文件锁在任何地方都是建议性的,除了在 Windows 上,但不要引用我的话。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-03-17
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-03-26
    • 2013-08-11
    相关资源
    最近更新 更多