17

私の次のセットアップは Xampp 1.7.7 で、そのパッケージのすべての情報は次のとおりです。 v5.10.1

Windows XP SP3 32 ビット OS、4 ギガの RAM、クアッド コアでサーバーを実行しています。

私のApacheエラーログファイルにある問題は次のとおりです。

[Tue Apr 24 15:55:55 2012] [notice] Parent: child process exited with status 3221225477 -- Restarting.
[Tue Apr 24 15:55:57 2012] [notice] Digest: generating secret for digest authentication ...
[Tue Apr 24 15:55:57 2012] [notice] Digest: done
[Tue Apr 24 15:55:59 2012] [notice] Apache/2.2.21 (Win32) mod_ssl/2.2.21 OpenSSL/1.0.0e PHP/5.3.8 mod_perl/2.0.4 Perl/v5.10.1 configured -- resuming normal operations
[Tue Apr 24 15:55:59 2012] [notice] Server built: Sep 10 2011 11:34:11
[Tue Apr 24 15:55:59 2012] [notice] Parent: Created child process 776
[Tue Apr 24 15:56:00 2012] [notice] Disabled use of AcceptEx() WinSock2 API
[Tue Apr 24 15:56:01 2012] [notice] Digest: generating secret for digest authentication ...
[Tue Apr 24 15:56:01 2012] [notice] Digest: done
[Tue Apr 24 15:56:02 2012] [notice] Child 776: Child process is running
[Tue Apr 24 15:56:02 2012] [notice] Child 776: Acquired the start mutex.
[Tue Apr 24 15:56:02 2012] [notice] Child 776: Starting 350 worker threads.
[Tue Apr 24 15:56:02 2012] [notice] Child 776: Listening on port 443.
[Tue Apr 24 15:56:02 2012] [notice] Child 776: Listening on port 80.

これは 1 日を通して散発的に発生するようで、Apache conf ファイルで Win32DisableEx、EnableIMAP Off、および EnableSendFile Off を使用してみました。また、libmysql.dll ファイルを system32 および apache/bin フォルダーにコピーしようとしましたが、役に立ちませんでした。

子プロセスが終了してApacheがクラッシュする原因となるこのエラーの他の理由を誰かが知っている場合は、情報をいただければ幸いです。追加のログ ファイルが必要な場合はお知らせください。

わかりました、シェーン。

4

1 に答える 1

22

エラー コード32212254770xC000000516 進数で、Windows では次のようになります。

#define STATUS_ACCESS_VIOLATION  ((NTSTATUS)0xC0000005L)

アクセス違反は、プログラムが割り当てられていないメモリにアクセスしようとしたことを意味する「セグメンテーション違反」の Windows バージョンです。これはさまざまな理由で発生する可能性がありますが、ほとんどの場合 (常にではないにしても) プログラムのバグです。

さて、あなたの状況についての私の推測では、PHP または PHP の拡張機能の 1 つ、または Perl または一部の Perl アプリケーションにバグがあるということです。通常、Apache 自体は非常に安定していますが、通常とは異なる拡張機能を使用している場合は、それが原因である可能性もあります。

すべての構成を最新バージョンに更新することをお勧めします。問題の原因を確実に見つけたい場合は、Visual Studio や OllyDbg などのデバッガー内で Apache を実行します。例外 (アクセス違反) が発生すると、(再起動ではなく) 実行が停止され、どのモジュールにあるかがわかります。

エラーと同じタイムスタンプを持つ不審なリクエストがある場合は、アクセス ログも確認してください。ただし、リクエストがログファイルに保存される前にクラッシュが発生する場合があります。

于 2012-04-24T22:33:24.430 に答える