Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Общий по FreeBSD (http://forum.oszone.net/forumdisplay.php?f=10)
-   -   [решено] Apache22 не запускается при старте системы (http://forum.oszone.net/showthread.php?t=113078)

_soldat_ 04-08-2008 02:06 867247

Apache22 не запускается при старте системы
 
У меня в файле /etc/rc.conf прописана строка
Код:

apache_enable="YES"
но при старте системы апаче не запускается как быть?

А при запуске (# /usr/local/sbin/apachectl start ) запускается, но пишет:

Код:

[warn] (2)No sach file or directory: Failed to enable the `httppready` Accept Filter

Gnix 04-08-2008 08:09 867304

apache22_enable="YES", если не ошибаюсь

и

http://www.mydigitallife.info/2006/0...-filter-error/

_soldat_ 04-08-2008 09:20 867351

Gnix,
не совсем понял из http://www.mydigitallife.info/2006/0...-filter-error/

выходит надо добавить строку в /boot/loader.conf:

Код:

accf_http_load=”YES”
но чтот не катит.
Что не так делаю?

Zergling 04-08-2008 19:55 867840

Он у тебя на запускается только при страте системы ?
Или вообще не запускается ? :)

/usr/local/etc/rc.d/apache22 start - что говорит ?
(apache22_enable="YES")

dmitryst 04-08-2008 21:58 867912

_soldat_, httpd -S что выдаёт? Конфиг нормальный?

_soldat_ 05-08-2008 01:25 868024

dmitryst,
Цитата:

Цитата dmitryst
httpd -S что выдаёт? Конфиг нормальный? »


Код:

httpd -S

Virtual Host configuration:
192.168.2.247:80      is a NameVirtualHost
                default server example.com (/usr/local/etc/apache22/httpd-vhosts.conf :27)
                port 80 namevhost example.com (/usr/local/etc/apache22/httpd-vhosts.conf :27)
Syntax OK


_soldat_ 06-08-2008 03:26 869081

С автозапуском все норма, но вот если запускать в ручную



А при запуске (# /usr/local/sbin/apachectl start ) запускается, но пишет:

Код:

[warn] (2)No sach file or directory: Failed to enable the `httppready` Accept Filter

dmitryst 06-08-2008 11:36 869270

Цитата:

Цитата _soldat_
А при запуске (# /usr/local/sbin/apachectl start ) запускается, но пишет: »

ну и фиг с ним... У меня то же самое пишет, но работает. Пока отложил разборки до лучших времен.

Так... Нашел!

Цитата:

это изза accf_http модуля..
kldload accf_http - решит проблему...
+постоянно пропиши эту ***ню в /boot/loader.conf
добавь accf_http_load=”YES”

LevshinO 29-01-2009 12:33 1023339

Столкнулся с такой же проблемой: Apache 2.2.11 не хочет запускаться при старте системы.
В /etc/rc.conf прописал apache22_enable="YES" - все равно не хочет.
Директория, в которую установлен сервер - /usr/local/apache22/. Вручную, при введении команды /usr/local/apache22/bin/apachectl start, все прекрасно работает.
В чем же здесь причина?

bozordzh 29-01-2009 15:03 1023491

LevshinO, тогда в /usr/local/etc/rc.d запихай скриптик типа :
#!/bin/sh
/usr/local/apache22/bin/apachectl start

leonty 29-01-2009 16:48 1023576

bozordzh, этот путь кажется немного через Ж.
LevshinO, логи смотрел? может конечно ошибаюсь, но в директории /usr/local/etc/rc.d/ должен лежать стартовый скрипт апача.

bozordzh 29-01-2009 16:57 1023583

leonty, почему через жопу? какие минусы?

LevshinO 29-01-2009 18:35 1023673

leonty, эм, если вы про apache22 в пути - то это мой косяк: там просто apache2. Что касается логов... Смотреть логи загрузки системы? Или Apach? Я в Unix вообще не разбираюсь... :dont-know Да, стартового скрипта Апача в /usr/local/etc/rc.d/ нету. Я его даже туда копировал (apachectl), но что-то не помогало.
bozordzh, хорошо, попробуем.

dmitryst 29-01-2009 19:04 1023723

Цитата:

Цитата LevshinO
даже туда копировал (apachectl) »

дык копировать надо apache22 :)

LevshinO 29-01-2009 19:25 1023739

dmitryst, кхм, а где мне его взять?

dmitryst 29-01-2009 20:06 1023792

Цитата:

Цитата LevshinO
а где мне его взять? »

вообще-то, можно в мс поиском воспользоваться :). Если не найдете, то выложу (кажется, он дефолтом пишется в /usr/etc/rc.d)

LevshinO 29-01-2009 20:35 1023823

dmitryst, к сожалению, ничего с именем apache22 я не нашел...

leonty 29-01-2009 21:40 1023888

LevshinO, вот такой скриптик надо создать в вышеупомянутой директории и сделать его исполняемым.
Код:

#
# $FreeBSD: ports/www/apache22/files/apache22.sh.in,v 1.5 2007/09/18 20:03:15 clement Exp $
#

# PROVIDE: apache22
# REQUIRE: LOGIN cleanvar
# KEYWORD: shutdown

#
# Add the following lines to /etc/rc.conf to enable apache22:
# apache22_enable (bool):      Set to "NO" by default.
#                            Set it to "YES" to enable apache22
# apache22_profiles (str):    Set to "" by default.
#                              Define your profiles here.
# apache22limits_enable (bool):Set to "NO" by default.
#                            Set it to yes to run `limits $limits_args`
#                            just before apache starts.
# apache22_flags (str):        Set to "" by default.
#                            Extra flags passed to start command.
# apache22limits_args (str):  Default to "-e -C daemon"
#                            Arguments of pre-start limits run.
# apache22_http_accept_enable (bool): Set to "NO" by default.
#                            Set to yes to check for accf_http kernel
#                            module on start up and load if not loaded.
. /etc/rc.subr

name="apache22"
rcvar=`set_rcvar`

start_precmd="apache22_precmd"
restart_precmd="apache22_checkconfig"
reload_precmd="apache22_checkconfig"
reload_cmd="apache22_graceful"
graceful_cmd="apache22_graceful"
gracefulstop_cmd="apache22_gracefulstop"
configtest_cmd="apache22_checkconfig"
command="/usr/local/sbin/httpd"
_pidprefix="/var/run/httpd"
pidfile="${_pidprefix}.pid"
required_files=/usr/local/etc/apache22/httpd.conf

[ -z "$apache22_enable" ]      && apache22_enable="NO"
[ -z "$apache22_profiles" ]    && apache22_profiles=""
[ -z "$apache22_flags" ]        && apache22_flags=""
[ -z "$apache22limits_enable" ] && apache22limits_enable="NO"
[ -z "$apache22limits_args" ]  && apache22limits_args="-e -C daemon"
[ -z "$apache22_http_accept_enable" ] && apache22_http_accept_enable="NO"

apache22_accf() {
        retcode=0
        if checkyesno apache22_http_accept_enable
        then
                /sbin/kldstat -v | grep accf_http 2>&1 > /dev/null
                retcode=${?}
                if [ ${retcode} -ne 0 ]
                then
                        /sbin/kldload accf_http 2> /dev/null
                        retcode=${?}
                fi
        else
                apache22_flags="${apache22_flags} -DNOHTTPACCEPT"
        fi
        [ ${retcode} -ne 0 ] && echo "Unable to load accf_http module"
        return ${retcode}
}

load_rc_config $name

if [ -n "$2" ]; then
        profile="$2"
        if [ "x${apache22_profiles}" != "x" ]; then
                pidfile="${_pidprefix}.${profile}.pid"
                eval apache22_configfile="\${apache22_${profile}_configfile:-}"
                if [ "x${apache22_configfile}" = "x" ]; then
                        echo "You must define a configuration file (apache22_${profile}_configfile)"
                        exit 1
                fi
                required_files="${apache22_configfile}"
                eval apache22_enable="\${apache22_${profile}_enable:-${apache22_enable}}"
                eval apache22_flags="\${apache22_${profile}_flags:-${apache22_flags}}"
                eval apache22_http_accept_enable="\${apache22_${profile}_http_accept_enable:-${apache22_http_accept_enable}}"
                eval apache22limits_enable="\${apache22limits_${profile}_enable:-${apache22limits_enable}}"
                eval apache22limits_args="\${apache22limits_${profile}_args:-${apache22limits_args}}"
                apache22_flags="-f ${apache22_configfile} -c \"PidFile ${pidfile}\" ${apache22_flags}"
        else
                echo "$0: extra argument ignored"
        fi
else
        if [ "x${apache22_profiles}" != "x" -a "x$1" != "x" ]; then
                for profile in ${apache22_profiles}; do
                        echo "===> apache22 profile: ${profile}"
                        /usr/local/etc/rc.d/apache22 $1 ${profile}
                        retcode="$?"
                        if [ "0${retcode}" -ne 0 ]; then
                                failed="${profile} (${retcode}) ${failed:-}"
                        else
                                success="${profile} ${success:-}"
                        fi
                done
                exit 0
        fi
fi

if [ "${1}" != "stop" ] ; then \
        apache22_accf || apache22_flags="${apache22_flags} -DNOHTTPACCEPT"
fi

apache22_requirepidfile()
{
        if [ ! "0`check_pidfile ${pidfile} ${command}`" -gt 1 ]; then
                echo "${name} not running? (check $pidfile)."
                exit 1
        fi
}

apache22_checkconfig()
{
        if test -f /usr/local/sbin/envvars
        then
                . /usr/local/sbin/envvars
        fi

        echo "Performing sanity check on apache22 configuration:"
        eval ${command} ${apache22_flags} -t
}

apache22_graceful() {
        apache22_requirepidfile

        echo "Performing a graceful restart"
        eval ${command} ${apache22_flags} -k graceful
}

apache22_gracefulstop() {
        apache22_requirepidfile

        echo "Performing a graceful stop"
        eval ${command} ${apache22_flags} -k graceful-stop
}

apache22_precmd()
{
        apache22_checkconfig

        if checkyesno apache22limits_enable
        then
                eval `/usr/bin/limits ${apache22limits_args}` 2>/dev/null
        else
                return 0
        fi

}

extra_commands="reload graceful gracefulstop configtest"
run_rc_command "$1"


LevshinO 29-01-2009 21:45 1023892

leonty, премного благодарен. А как его исполняемым-то сделать? Извиняюсь за тупой вопрос... И как он, собсно, называться-то должен скрипт этот.

LevshinO 29-01-2009 22:29 1023926

leonty, большое вам спасибо. Скрипт сделал - все заработало. Единственное, что пришлось сделать - подправить пути к httpd и httpd.conf. Как-то не в тех они у меня местах лежали.)))


Время: 12:55.

Время: 12:55.
© OSzone.net 2001-