Не удалось перезапустить nginx

Я использую nginx с Django на Ubunto 10:04. Проблема в том, что когда я перезапускаю nginx, я получаю эту ошибку.

sudo /etc/init.d/nginx restart
Restarting nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
configuration file /etc/nginx/nginx.conf test is successful
[emerg]: bind() to 0.0.0.0:80 failed (98: Address already in use)
[emerg]: bind() to 0.0.0.0:80 failed (98: Address already in use)
[emerg]: bind() to 0.0.0.0:80 failed (98: Address already in use)
[emerg]: bind() to 0.0.0.0:80 failed (98: Address already in use)

Кроме того, я попытался остановить, а затем начать, но все равно получить ошибку.

Здесь вывод из lsof:

sudo lsof -i tcp:80
COMMAND   PID   USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
nginx   27141   root    6u  IPv4 245906      0t0  TCP *:www (LISTEN)
nginx   27142 nobody    6u  IPv4 245906      0t0  TCP *:www (LISTEN)

Если я убью процесс с помощью PID 27141, он будет работать. Тем не менее, я хотел бы дойти до сути почему я не могу просто перезапустить.

Здесь nginx.conf:

worker_processes 1;

user nobody nogroup;
pid /tmp/nginx.pid;
error_log /tmp/nginx.error.log;

events {
    worker_connections 1024;
    accept_mutex off;
}

http {
    include mime.types;
    default_type application/octet-stream;
    access_log /tmp/nginx.access.log combined;
    sendfile on;

    upstream app_server {
        # server unix:/tmp/gunicorn.sock fail_timeout=0;
        # For a TCP configuration:
        server 127.0.0.1:8000 fail_timeout=0;
    }

    server {
        listen 80 default;
        client_max_body_size 4G;
        server_name _;

        keepalive_timeout 5;

        # path for static files
        root /home/apps/venvs/app1/app1;

        location / {
            # checks for static file, if not found proxy to app
            try_files $uri @proxy_to_app;
        }

        location @proxy_to_app {
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host $http_host;
            proxy_redirect off;

            proxy_pass   http://app_server;
        }

        error_page 500 502 503 504 /500.html;
        location = /500.html {
            root /path/to/app/current/public;
        }
    }
}

Любые идеи?

Ответы

Ответ 1

Try:

$ sudo fuser -k 80/tcp ; sudo /etc/init.d/nginx restart 

Ответ 3

Daemontools запускает nginx успешно, затем nginx demonizes, а затем daemontools пытается снова запустить nginx, безуспешно, регистрируя ошибку в журнале.

Решение этой проблемы - отключить режим демона в главном разделе nginx.conf:

daemon off;

Сайт: http://wiki.nginx.org/CoreModule

Ответ 4

Устали от проблем с перезагрузкой nginx и ошибок "адрес в использовании". Решил сделать его работу раз и навсегда.

Добавлена ​​только одна строка в конце остановки и перезапустите действие в файле /etc/init.d/nginx

nginx -s quit

поэтому теперь он выглядит (и убедитесь, что папка nginx находится в переменной PATH, иначе укажите полный путь)

stop)
    echo -n "Stopping $DESC: "
    start-stop-daemon --stop --quiet --pidfile /var/run/$NAME.pid \
        --exec $DAEMON || true
    echo "$NAME."
    nginx -s quit
    ;;

restart|force-reload)
    echo -n "Restarting $DESC: "
    start-stop-daemon --stop --quiet --pidfile \
        /var/run/$NAME.pid --exec $DAEMON || true
    nginx -s quit
    sleep 1
    test_nginx_config
    start-stop-daemon --start --quiet --pidfile \
        /var/run/$NAME.pid --exec $DAEMON -- $DAEMON_OPTS || true
    echo "$NAME."
    ;;

Надеемся, что это решение будет работать для других.

Ответ 5

Всегда сначала проверяйте свой конфиг, он будет отображать синтаксические ошибки и дублировать строки и указывать на них.

nginx -t

Вы увидите журналы, в которых показано, что вызывает отказ.

Ответ 6

Это потому, что вы не перезапускаете как root.

Изменить на root:

sudo -i

Restart:

service nginx restart

Или:

/etc/init.d/nginx restart