我可以以编程方式强制更改文件以传播到所有NFS客户端吗?

时间:2011-09-27 20:20:39

标签: php file-io nfs haproxy

我有一个用PHP构建的CMS,它存储页面列表,页面导航结构和磁盘上文件的页面内容。此应用程序托管在haproxy服务器后面的Apache / php-fpm服务器群集上。这些服务器通过NFS从中央文件服务器安装Apache DocumentRoot目录,因此从CMS进行的所有更改都将写入NFS共享上的文件。

我发现,除非我使用noac选项挂载NFS共享,否则所做的更改可能需要5-10秒才能传播到群集中的所有服务器;这意味着当快速连续进行多个更改时,最终更改有时会覆盖先前的更改,因为最终更改可能会转到尚未收到先前更改的服务器。

但是,当使用noac挂载选项时,访问者访问内容会有2-5秒的延迟,这是完全不可接受的。

有没有办法以编程方式强制更改NFS共享上的文件以提升所有客户端,或者导致所有客户端刷新该文件的缓存?

2 个答案:

答案 0 :(得分:2)

我不知道任何NFS级别选项可以实现您想要的但是如果访问这些文件的应用程序在您的控制之下,那么您可以使用O_DIRECT选项打开每个文件 - 这会绕过任何本地以这种方式打开的任何文件的NFS缓存......

一句话:

你写noac导致延迟2-5秒..这似乎指向网络和/或存储级问题或“远远到一个目录中的许多文件/目录” ...

答案 1 :(得分:2)

我使用apache指令ctoEnableMMAP Off解决了NFS参数EnableSendFile Off的相同问题。 noac参数与您所写的症状相同。