Назад | Перейти на главную страницу

доступ apache-пользователя к NFS от Windows 2012 до Centos 7

Я установил общий ресурс NFS с сервера Windows 2012 на имеющийся у меня веб-сервер Centos7.

Я хочу, чтобы мой веб-сервер создавал и читал файлы из общего ресурса NFS. У меня раньше было подобное решение для Windows 2008 и Centos6, но после обновления серверов у меня возникают проблемы.

UID и GID установлены в параметрах NFS W2012 и являются правильными.

[root@centos external]# ll
drwxrwxrwx  2 apache www-data 4096 Sep 17 16:15 NFSShare


[root@centos external]# df -h
windowsserver:/NFSShare 50G   19G   31G  38% /var/www/external/NFSShare

[root@centos external]# getfacl NFSShare/
# file: NFSShare/
# owner: apache
# group: www-data
user::rwx
group::rwx
other::rwx

NFS-ресурс и его разрешения работают с пользователем root.

[root@centos NFSShare]# touch test.txt
[root@centos NFSShare]# ll
total 1
-rwxrwxrwx 1 apache www-data  8 Sep 17 16:15 test2.txt
-rw-r--r-- 1 apache www-data  0 Sep 24 11:10 test.txt

Но когда я пытаюсь читать или писать со своего веб-сайта с помощью PHP, я получаю отказ в разрешении.

PHP-код (пытается создать папку и прочитать файл):

// Try create a folder    
mkdir('/var/www/external/NFSShare/123');

// Try to read from file
$file = '/var/www/external/NFSShare/test2.txt';
$homepage = file_get_contents($file);
echo $homepage;

Журнал ошибок PHP:

[root@centos external]# tail /var/log/httpd/website-error_log

[Thu Sep 24 10:21:03.632156 2015] [:error] [pid 15286] [client 172.27.xxx.xxx:56198] PHP Warning:  mkdir(): Permission denied in /var/www/website/modules/users/view/admin/test.php on line 6
[Thu Sep 24 10:21:03.645438 2015] [:error] [pid 15286] [client 172.27.xxx.xxx:56198] PHP Warning:  file_get_contents(/var/www/external/NFSShare/test2.txt): failed to open stream: Permission denied in /var/www/website/modules/users/view/admin/test.php on line 15

Та же проблема, если я попытаюсь запустить как пользователь apache из ssh:

[root@centos NFSShare]# su -s /bin/sh apache -c "touch /var/www/external/NFSShare/test.txt"
touch: cannot touch ‘/var/www/external/NFSShare/test.txt’: Permission denied

На данный момент я попытался дать NTFS-разрешения «Всем» на стороне Windows, CHMOD 0777 как можно больше на Centos-сервере и выключил SELinux - просто чтобы исключить любые проблемы с этим.

У кого-нибудь есть идея, почему пользователь Apache не может читать или писать в общий ресурс NFS?

Обновление №1:

Проверено "tail -f /var/log/audit/audit.log" при создании файлов с пользователем apache. Не вижу разницы в журнале, когда я создаю файл в ex. / external или in / external / NFSShare, где я получаю отказ в разрешении на NFSShare.

Проверено "tcpdump -i any dst windowsserver", где я получаю запрос NFS при создании файла с пользователем root, но ничего при попытке с пользователем apache. Похоже, мой Centos-сервер отклоняет запрос до того, как что-либо будет отправлено на сервер Windows.