Apache服务之前是否读取锁定文件?

cdm*_*kay 9 php apache json locking

我有一个移动应用程序,它读取存储在Apache服务器上的JSON文件.如果通过GUI更改了某些内容,则会重新生成该JSON文件的内容(使用PHP脚本).

我担心尝试在Apache服务的过程中覆盖JSON文件可能会导致问题.

Apache在提供文件之前是否获得了读锁定?如果没有,如果我在服务的同时尝试写它会发生什么?

phi*_*hag 9

在POSIX兼容系统上,所有锁都是建议性的,所以即使apache获得读锁定,另一个进程也可以只写入文件.

您可以通过以下方式确定strace:

[pid  7246] open("/var/www/file.json", O_RDONLY|O_CLOEXEC) = 11
[pid  7246] fcntl(11, F_GETFD)          = 0x1 (flags FD_CLOEXEC)
[pid  7246] mmap(NULL, 20, PROT_READ, MAP_SHARED, 11, 0) = 0x7f53f93da000
[pid  7246] munmap(0x7f53f93da000, 20)  = 0
[pid  7246] writev(10, [{"HTTP/1.1 200 OK\r\nDate: Thu, 26 J"}, ...) = 365
[pid  7246] close(11)                   = 0
Run Code Online (Sandbox Code Playgroud)

因此,您的JSON文件只能部分写入.要避免此问题,请将JSON文件写入同一文件系统上的临时文件,并使用atomic rename来覆盖该文件.

这样,如果open成功,apache将继续提供旧文件.如果在rename之前完成open,apache将获得新的,已完成的文件.

如果您担心一致性(在电源故障等情况下),您可能还希望fsync在关闭之前调用写入JSON文件的应用程序.