PDA

Показать полную графическую версию : [решено] Apache22 не запускается при старте системы


_soldat_
04-08-2008, 02:06
У меня в файле /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
apache22_enable="YES", если не ошибаюсь

и

http://www.mydigitallife.info/2006/04/23/freebsd-apache-http-accept-filter-error/

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

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

accf_http_load=”YES”

но чтот не катит.
Что не так делаю?

Zergling
04-08-2008, 19:55
Он у тебя на запускается только при страте системы ?
Или вообще не запускается ? :)

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

dmitryst
04-08-2008, 21:58
_soldat_, httpd -S что выдаёт? Конфиг нормальный?

_soldat_
05-08-2008, 01:25
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
С автозапуском все норма, но вот если запускать в ручную



А при запуске (# /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
А при запуске (# /usr/local/sbin/apachectl start ) запускается, но пишет: »
ну и фиг с ним... У меня то же самое пишет, но работает. Пока отложил разборки до лучших времен.

Так... Нашел! (http://forum.anit.az/showthread.php?p=6240)

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

LevshinO
29-01-2009, 12:33
Столкнулся с такой же проблемой: 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
LevshinO, тогда в /usr/local/etc/rc.d запихай скриптик типа :
#!/bin/sh
/usr/local/apache22/bin/apachectl start

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

bozordzh
29-01-2009, 16:57
leonty, почему через жопу? какие минусы?

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

dmitryst
29-01-2009, 19:04
даже туда копировал (apachectl) »
дык копировать надо apache22 :)

LevshinO
29-01-2009, 19:25
dmitryst, кхм, а где мне его взять?

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

LevshinO
29-01-2009, 20:35
dmitryst, к сожалению, ничего с именем apache22 я не нашел...

leonty
29-01-2009, 21:40
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
leonty, премного благодарен. А как его исполняемым-то сделать? Извиняюсь за тупой вопрос... И как он, собсно, называться-то должен скрипт этот.

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




© OSzone.net 2001-2012