複数のApacheをインストールしたら

php4とphp5の両方に対応するため、ひとつのサーバに複数のApacheをインストール。
ひとつは/usr/local/apache2へインストールして、もう一つは/usr/local/apache2-php4へインストール。
片方でapachectl startでapacheを開始、もう片方でapachectl startすると"alread running"などと言われる。
httpdが開始するときにはpidファイル(デフォルトだとlogs/httpd.pid)を参照して、そのファイルがあればすでにプロセスがいるものとして扱っています。どうも /usr/local/apache2-php4が/usr/local/apach2/logs/httpd.pid ファイルを参照しているみたい。
このあたりのコンフィギュレーションhttpd -V で参照できます。

# /usr/local/apache2-php4/bin/httpd -V
Server version: Apache/2.4.3 (Unix)
Server built:   Nov 20 2012 11:31:21
Server's Module Magic Number: 20120211:6
Server loaded:  APR 1.4.6, APR-UTIL 1.4.1
Compiled using: APR 1.4.6, APR-UTIL 1.4.1
Architecture:   64-bit
Server MPM:     event
  threaded:     yes (fixed thread count)
    forked:     yes (variable process count)
Server compiled with....
 -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=256
 -D HTTPD_ROOT="/usr/local/apache2"
 -D SUEXEC_BIN="/usr/local/apache2/bin/suexec"
 -D DEFAULT_PIDLOG="logs/httpd.pid"
 -D DEFAULT_SCOREBOARD="logs/apache_runtime_status"
 -D DEFAULT_ERRORLOG="logs/error_log"
 -D AP_TYPES_CONFIG_FILE="conf/mime.types"
 -D SERVER_CONFIG_FILE="conf/httpd.conf"

HTTPD_ROOTに注目。/usr/local/apach2を指しているので当然pidファイルも/usr/local/apache2/bin/httpd.pidを参照しますね。いやー "--prefix"を指定しないでconfigure,makeしてインストールしたあと、/usr/local/apache2をリネームしてしまったようです。

configure --prefix=/usr/local/apache2-php4を指定して再コンパイル。ちゃんと動作するようになりました。