ПРОЕКТЫ 


  АРХИВ 


Apache-Talk @lexa.ru 

Inet-Admins @info.east.ru 

Filmscanners @halftone.co.uk 

Security-alerts @yandex-team.ru 

nginx-ru @sysoev.ru 


  СТАТЬИ 


  ПЕРСОНАЛЬНОЕ 


  ПРОГРАММЫ 



ПИШИТЕ
ПИСЬМА












     АРХИВ :: nginx-ru
Nginx-ru mailing list archive (nginx-ru@sysoev.ru)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: restart nginx



On 03.08.2011 12:27, Алексей Масленников wrote:

на системе CentOS release 5.3 (Final)

где Вы взяли такой древний и глючный инит-скрипт?

Запускается раза с 5-го

т.е. нормально не работает service nginx start ?

> restart пишет что все ОК, но не работает .

или проблемы только с service nginx restart ?

что при этом пишется на stderr и в error.log ?

make_dirs() {
    # make required directories
    user=`nginx -V 2>&1 | grep "configure arguments:" | sed
's/[^*]*--user=\([^ ]*\).*/\1/g' -`
    options=`$nginx -V 2>&1 | grep 'configure arguments:'`
    for opt in $options; do
        if [ `echo $opt | grep '.*-temp-path'` ]; then
            value=`echo $opt | cut -d "=" -f 2`
            if [ ! -d "$value" ]; then
                # echo "creating" $value
                mkdir -p $value && chown -R $user $value
            fi
        fi
    done
}

возможно имеет смысл эту функциональность перенести
внутрь /usr/sbin/nginx, чтобы он сам создавал каталоги.
потому что через shell-скрипт получается не очень красиво...

stop() {
     echo -n $"Stopping $prog: "
     killproc $prog -QUIT
     retval=$?
     echo
     [ $retval -eq 0 ] && rm -f $lockfile
     return $retval
}

причина глюков с restart - именно в этом,
старому экземпляру nginx посылают сигнал -QUIT
- это команда на "плавное завершение" и после
этого - сразу же запускают новый экземпляр.

если убрать -QUIT - то service nginx stop будет завершать
его работу гораздо быстрее, сразу обрывая все соединения.

restart() {
     configtest || return $?
     stop
     sleep 1
     start
}

sleep 1 - это не очень хороший workaround для вручную созданного
глюка, старый экземпляр nginx может и не успеть выйти за 1 секунду.

кроме того - нет никакого смысла использовать restart, когда
в nginx есть http://sysoev.ru/nginx/docs/control.html#upgrade
да и большинство изменений в конфигурации применяются
с помощью команды service nginx reload

force_reload() {
     restart
}

очень старый инит-скрипт, эти ошибки были исправлены
в нем еще несколько лет тому назад. по крайней мере,
в init-скрипте из EPEL этих ошибок уже давно нет.

Как это отдебажить ? Спасибо.

см. в аттаче мой вариант инит-скрипта.

после изменения настроек лучше делать service nginx reload
а после обновления бинарника или чтобы на 100 % быть уверенным,
что все изменения применились - service nginx force-reload

service nginx restart не имеет смысла вообще использовать.
разве что только в том случае когда nginx так зависнет,
что никак нельзя будет завершить, а только через kill -9
( но лучше будет причину этой ошибки найти и устранить )

там я еще сделал некоторую часть работы для того, чтобы
можно было запускать одновременно несколько независимых
экземпляров nginx на одном сервере, просто копируя
инит-скрипт, например, в nginx-frontend, nginx-static, и т.п.
меняя переменную pidfile и значение переменной instance -
но пока что полностью это сделать не удалось - в nginx
жестко вкомпилировано имя error.log файла и поэтому
разные экземпляры nginx будут писать ошибки в один
и тот же лог-файл, что не очень удобно и трудно
потом будет понять, что к чему относится.

на FreeBSD насколько я знаю, nginx "из коробки"
поддерживает такой режим работы, что можно запускать
несколько полностью независимых друг от друга экземпляров,
но на Linux - такую функциональность сейчас сделать нельзя,
не компилируя его много раз с различными параметрами configure.

--
Best regards,
 Gena
#!/bin/sh
# chkconfig: - 85 15
# description: nginx [engine x] is a HTTP server written by Igor Sysoev

. /etc/rc.d/init.d/functions
. /etc/sysconfig/network

[ "$NETWORKING" = "no" ] && exit 0

binary=/usr/sbin/nginx
instance=nginx

pidfile="/var/run/nginx.pid"
config="/etc/nginx/$instance.conf"

lockfile="/var/lock/subsys/$instance"
sysconfig="/etc/sysconfig/$instance"

[ -f $sysconfig ] && . $sysconfig

start() {
    [ -x $binary ] || exit 5
    [ -f $config ] || exit 6
    echo -n $"Starting $instance: "
    daemon $binary -c $config 
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}

stop() {
    echo -n $"Stopping $instance: "
    killproc -p $pidfile $instance
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}

restart() {
    configtest_q || return 6
    stop
    start
}

online_upgrade() { 
    configtest_q || return 6
    echo -n $"Upgrading $instance: "
    kill -USR2 `cat /var/run/$instance.pid`
    sleep 1
    if test -f /var/run/$instance.pid.oldbin
    then
        kill -QUIT `cat /var/run/$instance.pid.oldbin`
        success $"$instance online upgrade"
        echo
    else
        failure $"$instance online upgrade"
        echo
        exit 1
    fi
}

reload() {
    configtest_q || return 6
    echo -n $"Reloading $instance: "
    killproc -p $pidfile $instance -HUP
    retval=$?
    echo
    return $retval
}

rotate(){
    configtest_q || return 6
    echo -n $"Rotating $instance logs: "
    killproc -p $pidfile $instance -USR1
    retval=$?
    echo
    return $retval
}

configtest() {
  $binary -t -c $config 
}

configtest_q() {
  $binary -t -q -c $config 
}

rh_status() {
    status -p $pidfile $instance
}

rh_status_q() {
    rh_status >/dev/null 2>&1
}

case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload|online-upgrade|upgrade)
        rh_status_q || exit 7
        online_upgrade
        ;;
    condrestart|try-restart)
        rh_status_q || exit 7
        restart
        ;;
    restart|configtest|rotate)
        $1
        ;;
    status|status_q)
        rh_$1
        ;;
    *)
        echo $"Usage: $0 
{start|stop|reload|force-reload|restart|try-restart|status|rotate|configtest}"
        exit 2
esac

/var/log/nginx/*log {
    daily
    rotate 9
    missingok
    notifempty
    compress
    sharedscripts
    postrotate
        [ ! -f /var/run/nginx.pid ] || kill -USR1 `cat /var/run/nginx.pid`
    endscript
}

# Configuration file for the nginx service

ulimit -n 16384

# set this to the location of the nginx configuration file

config=/etc/nginx/nginx.conf

_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://mailman.nginx.org/mailman/listinfo/nginx-ru

  • References:

 




Copyright © Lexa Software, 1996-2009.