_soldat_ |
04-08-2008 02:06 867247 |
Apache22 не запускается при старте системы
У меня в файле /etc/rc.conf прописана строка но при старте системы апаче не запускается как быть?
А при запуске (# /usr/local/sbin/apachectl start ) запускается, но пишет:
Код:
[warn] (2)No sach file or directory: Failed to enable the `httppready` Accept Filter
|
_soldat_ |
04-08-2008 09:20 867351 |
|
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”
|
|
Столкнулся с такой же проблемой: Apache 2.2.11 не хочет запускаться при старте системы.
В /etc/rc.conf прописал apache22_enable="YES" - все равно не хочет.
Директория, в которую установлен сервер - /usr/local/apache22/. Вручную, при введении команды /usr/local/apache22/bin/apachectl start, все прекрасно работает.
В чем же здесь причина?
|
LevshinO, тогда в /usr/local/etc/rc.d запихай скриптик типа :
#!/bin/sh
/usr/local/apache22/bin/apachectl start
|
bozordzh, этот путь кажется немного через Ж.
LevshinO, логи смотрел? может конечно ошибаюсь, но в директории /usr/local/etc/rc.d/ должен лежать стартовый скрипт апача.
|
leonty, почему через жопу? какие минусы?
|
leonty, эм, если вы про apache22 в пути - то это мой косяк: там просто apache2. Что касается логов... Смотреть логи загрузки системы? Или Apach? Я в Unix вообще не разбираюсь... :dont-know Да, стартового скрипта Апача в /usr/local/etc/rc.d/ нету. Я его даже туда копировал (apachectl), но что-то не помогало.
bozordzh, хорошо, попробуем.
|
Цитата:
Цитата LevshinO
даже туда копировал (apachectl) »
|
дык копировать надо apache22 :)
|
dmitryst, кхм, а где мне его взять?
|
вообще-то, можно в мс поиском воспользоваться :). Если не найдете, то выложу (кажется, он дефолтом пишется в /usr/etc/rc.d)
|
dmitryst, к сожалению, ничего с именем apache22 я не нашел...
|
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"
|
leonty, премного благодарен. А как его исполняемым-то сделать? Извиняюсь за тупой вопрос... И как он, собсно, называться-то должен скрипт этот.
|
leonty, большое вам спасибо. Скрипт сделал - все заработало. Единственное, что пришлось сделать - подправить пути к httpd и httpd.conf. Как-то не в тех они у меня местах лежали.)))
|
Время: 12:55.
© OSzone.net 2001-