質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Red Hat Enterprise

Red Hat Enterpriseは、レッドハット社により開発・サポートが行われている業務向けLinuxディストリビューションです。オープンソースで無償で利用することができ、バイナリ版の入手・サポートは有償です。商用ディストリビューションとして人気が高く、代表的なLinuxの選択肢の一つです。

Q&A

解決済

1回答

1000閲覧

apacheのAH00804: Cannot create socache DBM fileエラーについて

Shoko

総合スコア9

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Red Hat Enterprise

Red Hat Enterpriseは、レッドハット社により開発・サポートが行われている業務向けLinuxディストリビューションです。オープンソースで無償で利用することができ、バイナリ版の入手・サポートは有償です。商用ディストリビューションとして人気が高く、代表的なLinuxの選択肢の一つです。

0グッド

0クリップ

投稿2022/04/19 05:49

編集2022/04/19 13:38

いつもお世話になっています。
apacheをSRPMファイルを元にビルドし、test-httpdという別名のサービスとして実行させようとしているのですが、標題のエラーに引っかかり、ここ数日どうにもできず、どう対処すればよいか途方に暮れています。
どなたかお知恵を拝借できれば有難いです。

エラーログ内容
ブラウザからサイトにアクセスしてもエラーで何も表示されず、エラーメッセージを確認したところ下記のエラーが出力されていました。
httpd-error.logの内容

[Tue Apr 19 12:16:23.862092 2022] [socache_dbm:error] [pid 963309:tid 139844270008640] (120021)APR does not understand this error code: AH00804: Cannot create socache DBM file `/var/cache/test-httpd/ssl'
[Tue Apr 19 12:16:23.862214 2022] [ssl:emerg] [pid 963309:tid 139844270008640] AH01874: Could not initialize session cache. Exiting.
[Tue Apr 19 12:16:23.862223 2022] [ssl:emerg] [pid 963309:tid 139844270008640] AH02312: Fatal error initialising mod_ssl, exiting.
[Tue Apr 19 12:16:23.862227 2022] [:emerg] [pid 963309:tid 139844270008640] AH00020: Configuration Failed, exiting

journalctl -xe -u test-httpd実行結果

-- The unit test-httpd.service has entered the 'failed' state with result 'exit>
Apr 19 12:28:09 rhel85 systemd[1]: Starting Customize Web Server>
-- Subject: Unit test-httpd.service has begun start-up
-- Defined-By: systemd
-- Support: https://access.redhat.com/support
-- Unit test-httpd.service has begun starting up.
Apr 19 12:28:09 rhel85 systemd[1]: Started Customize Web Server
-- Subject: Unit test-httpd.service has finished start-up
-- Defined-By: systemd
-- Support: https://access.redhat.com/support
-- Unit test-httpd.service has finished starting up.
-- The start-up result is done.
Apr 19 12:28:09 rhel85 systemd[1]: test-httpd.service: Main process exited, cod>
Apr 19 12:29:39 rhel85 systemd[1]: test-httpd.service: Reload operation timed o>
Apr 19 12:29:39 rhel85 systemd[1]: test-httpd.service: Failed with result 'exit>
-- Subject: Unit failed
-- Defined-By: systemd
-- Support: https://access.redhat.com/support
-- The unit test-httpd.service has entered the 'failed' state with result 'exit>

環境
OS:Red Hat Enterprise Linux 8.5
apache2.4.37-41
seLinux:オフ

詳細
apache2.4.37-41のSRPMを元に、別名のサービスとして起動できるよう、SPECファイル、その他ファイルを修正し、rpmファイルを作成しました。

rpmファイルをインストールし、想定通りのディレクトリに各種ファイルが存在していることを確認。systemctlコマンドで起動、起動時にエラーは特に表示されません。

systemctl status test-httpd.serviceを実行すると画面上は下記の様に緑色になっているため、起動したかに見えますが、最後の行には「httpd.service: Main process exited, code=exited, status=1/FAILURE」とあります。
数分後再度statusを確認すると緑色から赤色のエラー表示に変わっていました。
イメージ説明

[socache_dbm:error] [pid 963309:tid 139844270008640] (120021)APR does not understand this error code: AH00804: Cannot create socache DBM file `/var/cache/test-httpd/ssl'

このログを元に、該当のディレクトリを確認しましたが、ディレクトリは存在し、SPECファイルで指定したuser、groupが設定されていました。
属性はdrwx------でしたが、念のためにdrwxrwxrwxに変更しても結果は同じでした。
/usr/lib64/test-httpd/module下に mod_socache_dbm.soが存在することも確認しています。

英語が苦手なため、Google翻訳機能を使って情報を探していますが、なかなかヒントを見つけることができず、ここでお力を拝借できれば助かります。
またLinuxの知識も浅いため、質問内容に不足情報等ありましたらご指摘頂けると有難いです。

どうぞよろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nukasa

2022/04/19 08:03

SELinuxはオンですか。
Shoko

2022/04/19 08:42

ありがとうございます。無効にしています。 /etc/selinux/configファイルで SELINUX=disabled と設定しています。
guest

回答1

0

ベストアンサー

.spec ファイルも設定もわかりませんが、SSLSessionCache dbm:/var/cache/test-httpd/ssl としているのであれば、/var/cache/test-httpd/ssl はディレクトリではなくファイルです。
すでにディレクトリとして存在しているためエラーとなっていると思います。
SSLSessionCache dbm:/var/cache/test-httpd/ssl/sslcache などとするとどうなるでしょうか。

投稿2022/04/19 13:35

TaichiYanagiya

総合スコア12146

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Shoko

2022/04/19 13:42

ありがとうございます。早速ビルドしなおしてみます。
TaichiYanagiya

2022/04/19 13:46

いや、ビルドじゃなく、設定の問題では?
Shoko

2022/04/19 13:59

ご指摘の通りでした。ビルドせず、まずはssl.confの該当箇所をアドバイス通り修正してsystemctlでサービスを再起動したら無事Webサーバとして機能し、ブラウザからのアクセスも確認できました。SSLも問題なさそうです。 心から感謝します。手を差し伸べてくださってありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問