Nginx все еще пытается открыть файл журнала ошибок по умолчанию, хотя я установил файл конфигурации nginx при перезагрузке

ниже приведен мой файл конфигурации nginx, расположенный в /etc/nginx/nginx.conf

user Foo;
worker_processes 1;

error_log /home/Foo/log/nginx/error.log;
pid /home/Foo/run/nginx.pid;

events {
    worker_connections 1024;
    use epoll;
}

http {
    access_log /home/Foo/log/nginx/access.log;

    server {
        listen 80;

        location = / {
            proxy_pass http://192.168.0.16:9999;
        }
    }
}

как вы можете видеть, я меняю журнал, местоположение pid-файлов в домашний каталог.

когда я снова начну Linux это, кажется, работает, Nginx ошибка записи логов в файл я и PID файл.

однако, когда он пытается nginx -s reload или другую пытается открыть другой файл журнала ошибок.

nginx: [alert] could not open error log file: open() "/var/log/nginx/error.log" failed (13: Permission denied)
2015/12/14 11:23:54 [warn] 3356#0: the "user" directive makes sense only if the master process runs with super-user privileges, ignored in /etc/nginx/nginx.conf:1
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
2015/12/14 11:23:54 [emerg] 3356#0: open() "/home/Foo/run/nginx.pid" failed (13: Permission denied)
nginx: configuration file /etc/nginx/nginx.conf test failed

Я знаю, я могу решить ошибку разрешения с sudo но главный вопрос в вот файл журнала ошибок(/var/log/nginx/error.log) Nginx пытается открыть.

почему он пытается получить доступ к другому файлу журнала ошибок?

4 ответов


Проверьте разрешения на каталог / home/Foo/log/nginx/. Он должен быть доступен для записи nginx. Установить разрешения, как так:

sudo chmod 766 /home/Foo/log/nginx

Это старый... но я прошел через ту же боль, и вот мое решение.

как вы можете видеть, журнал является предупреждением, а не блокирующей ошибкой:

nginx: [alert] could not open error log file: open() "/var/log/nginx/error.log" failed (13: Permission denied)

это не должно быть проблемой :) Nginx просто любит проверять этот файл при запуске...

просто использовать . Что-то вроде этого для запуска nginx локально работает для меня:

nginx -c /etc/nginx/nginx.conf -g 'daemon off;' -p /home/Foo/log/nginx

да, Nginx просто любит проверять этот файл при запуске. Я копирую установленный каталог nginx в другое место, я запускаю его, и pid нового Nginx все еще на старом месте. Поэтому я предлагаю вам удалить старый каталог.


альтернативно перезагрузите nginx с помощью sudo

sudo nginx -s reload