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

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

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

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

SSL

SSL(Secure Sockets Layer)とは、暗号化されたプロトコルで、インターネット上での通信セキュリティを提供しています。

Q&A

解決済

2回答

1143閲覧

apache再起動後のhttpsへアクセスした際の挙動がおかしい

shivil

総合スコア22

Apache

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

SSL

SSL(Secure Sockets Layer)とは、暗号化されたプロトコルで、インターネット上での通信セキュリティを提供しています。

0グッド

1クリップ

投稿2021/12/25 08:28

編集2021/12/25 09:26

Rocky Linux 8.5にて新しくLAMP環境を構築したのですが、mod_sslをインストール後http,httpsでのVirtualHostでDocumentRootなどの設定後、
証明書はlet'sencryptを利用相手インストール、その後

dnf restart httd

などでapacheを再起動後、なぜかhttpでのアクセスはきちんとファイルが表示されるのですが、httpsで同じファイルにアクセスすると404 Not Foundが返ってきます。
DocumentRootはhttp、https共に同じディレクトリを指定しております。
証明書もlet'sencryptの証明書が反映されてないようで、sslのエラーログを確認したところ、

Cannot serve directory /var/www/html/: No matching DirectoryIndex (index.php,index.html,index.php) found, and server-generated directory index forbidden by Options directive

となっており、VirtualHostで設定したDocumentRootを見ていないようでした。
全く原因がわからず、ダメ元でサーバを再起動したところ、直後はきちんとhttpsでのアクセスが正常にできたのですが、

dnf restart httd

dnf reload httd

をするとまたhttpsでのアクセスが正常にできなくなります。

どんな原因が考えられるでしょうか?
ご教授よろしくお願い致します。

追記
状況的にわかったことは

dnf restart httpd

でapacheを再起動すると同じファイルに記述してあるhttpとhttpsの設定のうち、httpsの設定だけが反映しない状況のようです。
DocumentRoot /var/www/htmlはデフォルトでhttpd.confに記述されてるので単にそこを見にいってたようでした。
試しにhttpd.confのDocumentRootをVirtualHostの設定と同じディレクトリに設定するとやはり表示されました。

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

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

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

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

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

otn

2021/12/25 15:34

これだけの情報しかないと、「設定ファイルの記述が間違っているのでしょう」以上のことは言い様がないです。
shivil

2021/12/27 01:37

情報不足で申し訳ございません。 設定に関してはapacheの再起動をしない限り問題なくアクセスできてますので設定の間違いではないことが前提でした。
otn

2021/12/27 15:10

初心者にありがちですが、「設定が間違いないのに動作がおかしい」という思い込みです。 動作がおかしいのであれば、設定にどこか間違いあるに違いないです。
shivil

2021/12/28 01:32

otn様のおっしゃる通りだと私も思っております。 初心者と言われれば反論はできませんが、その上で言わさせていただくと少なくとも今まで複数台サーバを構築してこのようなことは一度もなく、かつVirtualHostに対しての設定ではなくhttpd.conf内(ここでの設定はVirtualHost以外に対しての設定と認識しております)のポート80に対するServerNameの設定自体を行っただけで(でたらめなドメインでも問題ありませんでした)ポート443に対するリクエストがVirtualHostの設定通りに正常に返った、という事自体は今でもなぜそうなったのかは理解できておりません。
guest

回答2

0

自己解決

apacheのステータスを確認したところ

httpd: Could not reliably determine the server’s fully qualified domain name

のメッセージが表示されていたので
httpd.conf内の
ServerNameのコメントアウトを

ServerName localhost:80

としたところ無事httpsでのアクセスも正常にされました。
今まで構築したサーバではバーチャルホストで設定した場合にはhttp.con内のServerNameはコメントアウトのままで問題なかったのですが、とりあえず自己解決しました。

投稿2021/12/27 01:30

shivil

総合スコア22

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

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

0

dnfコマンドはパッケージ管理コマンドです

サービスを制御したいならsystemctlコマンドを使用しましょう
誤)dnf restart httd
正)systemctl restart httpd

投稿2021/12/25 15:47

yukky1201

総合スコア2751

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

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

shivil

2021/12/26 08:14 編集

申し訳ございません。 完全に単語ミスでした。 systemctlの間違いです。 あくまでapacheを再始動したという意味です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問