Apacheのリロードに失敗しました...詳細を確認できるログはありますか?


12

サイトの追加に取り組んでいるWebサーバーがあります。

実行した後a2ensite、私は走ってservice apache2 reload、これを得ました:

[失敗] Webサーバー設定の再読み込み:apache2が失敗しました!

詳細を確認できるログファイルはありますか?

回答:


9

スイッチhttpdを使用して、構成ファイルを探すように構成されている場所を確認できます-V

$ httpd -V
Server version: Apache/2.2.15 (Unix)
Server built:   Feb 13 2012 22:31:42
Server's Module Magic Number: 20051115:24
Server loaded:  APR 1.3.9, APR-Util 1.3.9
Compiled using: APR 1.3.9, APR-Util 1.3.9
Architecture:   64-bit
Server MPM:     Prefork
  threaded:     no
    forked:     yes (variable process count)
Server compiled with....
 -D APACHE_MPM_DIR="server/mpm/prefork"
 -D APR_HAS_SENDFILE
 -D APR_HAS_MMAP
 -D APR_HAVE_IPV6 (IPv4-mapped addresses enabled)
 -D APR_USE_SYSVSEM_SERIALIZE
 -D APR_USE_PTHREAD_SERIALIZE
 -D SINGLE_LISTEN_UNSERIALIZED_ACCEPT
 -D APR_HAS_OTHER_CHILD
 -D AP_HAVE_RELIABLE_PIPED_LOGS
 -D DYNAMIC_MODULE_LIMIT=128
 -D HTTPD_ROOT="/etc/httpd"
 -D SUEXEC_BIN="/usr/sbin/suexec"
 -D DEFAULT_PIDLOG="run/httpd.pid"
 -D DEFAULT_SCOREBOARD="logs/apache_runtime_status"
 -D DEFAULT_LOCKFILE="logs/accept.lock"
 -D DEFAULT_ERRORLOG="logs/error_log"
 -D AP_TYPES_CONFIG_FILE="conf/mime.types"
 -D SERVER_CONFIG_FILE="conf/httpd.conf"

このコマンドlsofを使用して、Unixプロセスがアクセスしているファイルを確認することもできます。私のバージョンでhttpdはストックポート80を使用しているため、80を8443に変更してください。

$ netstat -tapn|grep ::80
tcp        0      0 :::80                       :::*                        LISTEN      5338/httpd     

これlsofで、ログファイルが書き込まれている場所を見つけることができます。

$ lsof -p 5338|grep log
httpd   5338 root  mem    REG  253,0    10440   3141 /usr/lib64/httpd/modules/mod_logio.so
httpd   5338 root  mem    REG  253,0    27200   3139 /usr/lib64/httpd/modules/mod_log_config.so
httpd   5338 root    2w   REG  253,0     2014 395029 /var/log/httpd/error_log
httpd   5338 root    7w   REG  253,0     4140 394789 /var/log/httpd/access_log

access_log構成ファイルと同様にファイルの場所を特定し、それらを調べて「Directory」および「Location」ディレクティブを特定できる必要があります。これらは、提供するファイルをApacheに伝えるときに使用するローカルディレクトリを指定します。

それで?

次にaccess_log、サーバーに対するアクセスに対応するエントリがそこにあることを確認するために目を通します。これが意味することは、次のようにファイルにhttp://www.somedom.com/somefile記録されたこのアクセスを確認する必要があるときにサーバーを参照した場合access_logです。

192.168.1.110 - - [17/Jul/2013:14:39:50 -0400] "GET /somefile HTTP/1.1" 200 4303 "-" "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/5
37.36 (KHTML, like Gecko) Chrome/27.0.1453.110 Safari/537.36"

ファイルはどこにありますか?

上記の知識を取得し、次のように適用を開始できます。

これらのビットは、httpd -VApacheのルートを示しています。

-D HTTPD_ROOT="/etc/httpd"
-D SERVER_CONFIG_FILE="conf/httpd.conf"

したがって、メインの構成ファイルは次のとおり/etc/httpd/conf/httpd.confです。そのため、これらの行についてそのファイルを調べます。

$ grep -E "DocumentRoot|Directory \"|^Include" /etc/httpd/conf/httpd.conf |grep -v "^#"
Include conf.d/*.conf
DocumentRoot "/var/www/html"
<Directory "/var/www/html">
<Directory "/var/www/icons">
<Directory "/var/www/cgi-bin">
    <Directory "/var/www/error">

そのため、これらのディレクトリが、access_log。で見たファイルの潜在的なソースであることがわかりました。DocumentRootそしてDirectories私は、ファイルを一読したいですsomefile。これらの場所のいずれにもない場合は、次に出力でInclude上記のディレクトリに注目します。grep/etc/httpd/conf.d/*.conf

これらのファイルは、Apacheが使用する追加の構成であるためgrep、これらのファイルを参照するには、を使用して手順を繰り返す必要があります。


14

ログファイルが見つからない場合、またはログファイルが空の場合は、Apache構成テストを実行して、構成ファイルに関する問題を印刷できます。

apachectl configtest

2

を実行しますservice apache2 restart。エラーメッセージが表示されます(通常、サービスはapacheを停止および開始する前に構成テストを実行します)

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.