1.Apache2のインストールとバーチャルホスト設定
1.1 Apache2インストール
①httpdをインストール
# dnf -y install httpd
バージョン確認
# httpd -v
Server version: Apache/2.4.62 (Rocky Linux)
Server built: May 11 2026 00:00:00
1.2 Apache の設定
①httpd.conf ファイルを編集
# cp /etc/httpd/conf/httpd.conf /etc/httpd/conf/httpd.conf_org
# vi /etc/httpd/conf/httpd.conf
91行目 : 管理者アドレス指定
ServerAdmin [Email Address]
101行目 : ServerName の追加
#ServerName www.example.com:80
ServerName [ドメイン名]
149行目 : 変更 (Indexes は削除)
Options FollowSymLinks
156行目 : 変更
AllowOverride All
169行目 : ディレクトリ名のみでアクセスできるファイル名追加
DirectoryIndex index.html index.php index.cgi
最終行に追記
ServerTokens Prod
②Firewalld を有効にしている場合は HTTP サービスの許可が必要。HTTP は [80/TCP] を使用します
# firewall-cmd --add-service=http --permanent
# firewall-cmd --reload
③Apache の自動起動設定
# systemctl start httpd
# systemctl enable httpd
# systemctl status httpd
● httpd.service - The Apache HTTP Server
Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled; preset: disabled)
Active: active (running) since Mon 2026-06-08 09:39:45 JST; 12s ago
Docs: man:httpd.service(8)
Main PID: 9564 (httpd)
Status: "Total requests: 0; Idle/Busy workers 100/0;Requests/sec: 0; Bytes served/sec:>
Tasks: 177 (limit: 22900)
Memory: 14.1M (peak: 14.5M)
CPU: 56ms
CGroup: /system.slice/httpd.service
├─9564 /usr/sbin/httpd -DFOREGROUND
├─9565 /usr/sbin/httpd -DFOREGROUND
├─9566 /usr/sbin/httpd -DFOREGROUND
├─9567 /usr/sbin/httpd -DFOREGROUND
└─9568 /usr/sbin/httpd -DFOREGROUND
Jun 08 09:39:45 Lepard systemd[1]: Starting The Apache HTTP Server...
Jun 08 09:39:45 Lepard httpd[9564]: Server configured, listening on: port 80
Jun 08 09:39:45 Lepard systemd[1]: Started The Apache HTTP Server.
④動作確認
http://[サーバーIPアドレス] にアクセスすると下記のようにHTTP Server Test Page が表示されればOK

⑤Welcomeページを非表示にし、Test Pageとして新規にindex.htmlファイルを作成し、apacheの動作確認
ウェルカムページをリネームする
# mv /etc/httpd/conf.d/welcome.conf /etc/httpd/conf.d/welcome.conf.org
HTML テストページを作成
# vi /var/www/html/index.html
下記を記述
<html>
<body>
<div style="width: 100%; font-size: 40px; font-weight: bold; text-align: center;">
Apache Test Page
</div>
</body>
</html>
http://[サーバーIPアドレス] にアクセスすると下記のようにTest Page が表示されればOK

1.3 バーチャルホストの設定
バーチャルホストで運用するドメイン名 [FQDN] を、ドキュメントルート[/var/www/html/FQDN] ディレクトリに割り当てて設定します
# vi /etc/httpd/conf.d/vhost.conf
下記を記述(バーチャルホストのドメインの設定)
<VirtualHost *:80>
DocumentRoot /var/www/html/[FQDN]
ServerName [FQDN]
ServerAdmin <Email Address> ←管理者メールアドレス
ErrorLog logs/[FQDN].error_log
CustomLog logs/[FQDN].access_log combined
</VirtualHost>
<Directory "/var/www/html/[FQDN]">
Options FollowSymLinks
AllowOverride All
</Directory>
ドキュメントディレクトリーの作成
# mkdir /var/www/html/[FQDN]
Apacheの再起動
# systemctl restart httpd
2. CGIスクリプトの利用確認
①CGIの利用可確認
# grep -n "^ *ScriptAlias" /etc/httpd/conf/httpd.conf
252: ScriptAlias /cgi-bin/ "/var/www/cgi-bin/"
上記が表示され、「/var/www/cgi-bin/」配下で利用可能
②テストスクリプトを作成し、作動確認
# vi /var/www/cgi-bin/index.cgi
下記を記述
#!/usr/libexec/platform-python
print("Content-type: text/html\n")
print("CGI Script Test Page")
# chmod 755 /var/www/cgi-bin/index.cgi
# curl localhost/cgi-bin/index.cgi
CGI Script Test Page
3. PHPのインストールと設定
3.1.PHP8インストール
最新のWordPressをインストールするには標準リポジトリーのPHPバージョン(php8.0)は古いため、RemiリポジトリよりPHP8.4をインストールします
Remiリポジトリーは初期設定で導入済です
①PHP 8.4モジュールの有効化
RemiリポジトリからPHP 8.4を選択できるように、モジュールの情報を更新し、リセットと有効化を行います。
# dnf module reset php -y
# dnf module enable php:remi-8.4 -y
①PHP8.4及び拡張機能インストール
# dnf install -y php php-cli php-fpm php-mysqlnd php-mbstring php-xml php-gd php-json php-curl
②バージョン確認
# php -v
PHP 8.4.22 (cli) (built: Jun 3 2026 01:12:32) (NTS gcc x86_64)
Copyright (c) The PHP Group
Built by Remi's RPM repository <https://rpms.remirepo.net/> #StandWithUkraine
Zend Engine v4.4.22, Copyright (c) Zend Technologies
with Zend OPcache v8.4.22, Copyright (c), by Zend Technologies
php-fpm の有効化、起動
# systemctl enable php-fpm
Created symlink '/etc/systemd/system/multi-user.target.wants/php-fpm.service' → '/usr/lib/systemd/system/php-fpm.service'.
# systemctl start php-fpm
③Apache の再起動
PHP インストール後は、Apache を再起動すればデフォルトで PHP-FPM (FPM : FastCGI Process Manager) が呼び出され、httpd の起動と連動して php-fpm サービスも起動されます
# systemctl restart httpd
# systemctl status php-fpm
● php-fpm.service - The PHP FastCGI Process Manager
Loaded: loaded (/usr/lib/systemd/system/php-fpm.service; enabled; preset: disabled)
Active: active (running) since Mon 2026-06-08 09:52:09 JST; 14s ago
Main PID: 10690 (php-fpm)
Status: "Processes active: 0, idle: 5, Requests: 0, slow: 0, Traffic: 0req/sec"
Tasks: 6 (limit: 22900)
Memory: 11.4M (peak: 11.8M)
CPU: 35ms
CGroup: /system.slice/php-fpm.service
├─10690 "php-fpm: master process (/etc/php-fpm.conf)"
├─10691 "php-fpm: pool www"
├─10692 "php-fpm: pool www"
├─10693 "php-fpm: pool www"
├─10694 "php-fpm: pool www"
└─10695 "php-fpm: pool www"
Jun 08 09:52:09 Lepard systemd[1]: Starting The PHP FastCGI Process Manager...
Jun 08 09:52:09 Lepard systemd[1]: Started The PHP FastCGI Process Manager.
④PHP の動作確認
下記のファイルを作成
# vi /var/www/html/[FQDN]/info.php
下記を記述
<?php phpinfo(); ?>
ブラウザでhttp://[FQDN]/info.phpにアクセスすると下記のような画面が表示されればOK

4. Apache2でDigest認証を行う
http の認証認定方式として有名なBasic 認証は認証情報を平文で送信するので、パケット盗聴されるとID とパスワードが漏洩する危険があります。
一方、Digest 認証は認証情報を暗号化して送信するので、情報漏えいの心配がほとんどありません。Digest 認証はBasic 認証を強化した認証認定方式と言えます。
4.1 Digest認証のパスワードファイルを作成
realmと呼ばれる認証領域を指定する。このrealmが同じディレクトリは認証済みとしてアクセスできるようにするためのものです。
今回は例として、realmは"DigestAuth"で、"secretuser"と言うユーザー及びパスワードファイル".digestauth"を作成する。下記のコマンドを実行すると"secretuser"のパスワードを求められるので入力する。
# /usr/bin/htdigest -c /etc/httpd/.digestauth "DigestAuth" secretuser
New password:
Re-type new password:
確認する
# cat /etc/httpd/.digestauth
secretuser:DigestAuth:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
上記の通り、secretuserと暗号化されたパスワードが作成されています
4.2 Apacheの設定ファイル編集
Digest認証をかけるディレクトリを指定する。(今回はsecretディレクトリーを指定する)
# vi /etc/httpd/conf/httpd.conf
最後尾に下記追加
<Directory "/var/www/html/[FQDN]/secret">
AuthType Digest
AuthName "DigestAuth"
AuthDigestDomain /[FQDN]/secret/
AuthUserFile "/etc/httpd/.digestauth"
Require valid-user
</Directory>
Digest認証をかけるディレクトリを作成する
# mkdir /var/www/html/[FQDN]/secret
Digest認証を有効にして再起動する
# systemctl restart httpd.service
ブラウザでhttp://[FQDN]/secret にアクセスすると「ユーザー名」「パスワード」求める画面が出る

