ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
このエラーの概要
PHP は暴走スクリプトでサーバを止めないため、デフォルトで 30 秒以内にスクリプトが完了しないと処理を中断し、次のエラーを吐きます:
Fatal error: Maximum execution time of 30 seconds exceeded in /var/www/html/app.php on line 42
PHP Fatal error: Maximum execution time of 30 seconds exceeded ...
このタイムアウトは CPU 時間 のみ計測されます(PHP < 7.1 では)。sleep() や外部リソース待ちは含まれないため、本当の wall-clock 時間とは異なる場合があります(PHP 7.1+ では wall-clock を計測)。
原因の切り分け
| 原因 | 典型例 | 対処方針 |
|---|---|---|
| 重い DB クエリ | JOIN 連発、INDEX 無し | EXPLAIN で確認 → INDEX 追加 |
| 無限ループ | while (true) の脱出条件バグ | ロジック修正 |
| 大量データの一括処理 | 10 万件を foreach で処理 | 分割 / バッチ化 / Queue 化 |
| 外部 API の応答遅延 | 連続して API 呼出 | 並列化 / 非同期 / タイムアウト短縮 |
| 大容量ファイル読込 | file_get_contents で巨大ファイル | ストリーム読込(fgets) |
| 正規表現の暴走 | Catastrophic Backtracking | 正規表現修正 / 別手段 |
対処1: スクリプト内で時間延長
最も早い応急対処は、スクリプト先頭で次のいずれかを呼ぶことです:
<?php
// 制限を無くす(無制限)
set_time_limit(0);
// 60 秒に延長
set_time_limit(60);
// ini_set でも同等
ini_set('max_execution_time', '60');
// ループ内で都度リセット(処理が前に進んでいる証)
foreach ($items as $item) {
set_time_limit(60); // ここを通る度に時間制限がリセット
processItem($item);
}
注意: safe_mode 有効時 / 一部のレンタルサーバ / PHP-FPM ではこの方法が効かないことがあります。
対処2: php.ini で全体設定
; /etc/php/8.2/fpm/php.ini または /etc/php/8.2/cli/php.ini
max_execution_time = 60
; Web からのアップロード時間
max_input_time = 60
; メモリも合わせて
memory_limit = 256M
変更後は systemctl reload php8.2-fpm または Apache 再起動が必要です。CLI と FPM で php.ini が別なので両方確認:
# CLI で使われている php.ini
php --ini
# Web (FPM) で使われている php.ini
php -i | grep "Loaded Configuration File"
# または <?php phpinfo(); ?> を実行
対処3: .htaccess で個別設定(Apache + mod_php)
# .htaccess(プロジェクトルートに配置)
<IfModule mod_php.c>
php_value max_execution_time 120
php_value max_input_time 120
php_value memory_limit 256M
</IfModule>
PHP-FPM 環境では .htaccess の php_value は効きません。FPM のプール設定または .user.ini を使います:
; .user.ini(公開ディレクトリに配置、5 分キャッシュ)
max_execution_time = 120
memory_limit = 256M
対処4: CLI での実行時間
バッチ処理を CLI で動かすとき、php.ini の CLI 用設定または引数で個別指定できます:
# 1 回の実行のみ無制限化
php -d max_execution_time=0 batch.php
# CLI 用 php.ini を確認
php --ini
# /etc/php/8.2/cli/php.ini に対して
# max_execution_time = 0 と書くのが定石(CLI は基本無制限)
対処5: PHP-FPM の request_terminate_timeout
PHP-FPM には独自のタイムアウト request_terminate_timeout もあり、こちらは php.ini の max_execution_time より優先 されます:
; /etc/php/8.2/fpm/pool.d/www.conf
request_terminate_timeout = 120s
; 0 にすると php.ini の max_execution_time を尊重
request_terminate_timeout = 0
FPM のさらに上流(Nginx / Apache mod_proxy_fcgi)のタイムアウト(fastcgi_read_timeout / ProxyTimeout)も延ばす必要があります。
対処6: Laravel / Symfony で Queue に逃がす(根本対処)
そもそも Web リクエスト中に長時間処理を走らせるのは UX 的にもサーバ的にも悪手です。非同期ジョブに逃がすのが現代的な解です:
<?php
// Laravel: Job クラス
class GenerateReport implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
public $timeout = 600; // ジョブのタイムアウト
public $tries = 3; // 失敗時リトライ
public function handle()
{
// 重い処理をここに
Report::generateForAllUsers();
}
}
// 呼び出し側はすぐ返る
GenerateReport::dispatch();
// 起動: php artisan queue:work --timeout=600
クエリ最適化の例(最も多い原因)
<?php
// 悪い例: N+1 で 10000 回クエリ
$users = User::all();
foreach ($users as $user) {
$orders = Order::where('user_id', $user->id)->get(); // 10000 回
}
// 良い例: eager loading で 2 回
$users = User::with('orders')->get();
foreach ($users as $user) {
$orders = $user->orders; // 追加クエリなし
}
// チャンク処理で大量レコード
User::chunk(1000, function ($users) {
foreach ($users as $user) {
processUser($user);
}
});
FAQ
Q: set_time_limit(0) しても効かない
A: safe_mode が有効、または PHP-FPM の request_terminate_timeout が短い、または上流(Nginx 等)でタイムアウトしている可能性。phpinfo() で実効値を確認してください。
Q: Web 画面が「504 Gateway Timeout」になる
A: PHP は動いていても Nginx 側で切断。fastcgi_read_timeout 300; を location ~ \.php$ に追加。
Q: ブラウザだけ切れて PHP は動き続けている?
A: 可能性あり。ignore_user_abort(true) を入れていると、ブラウザを閉じても PHP は最後まで実行されます。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- Fatal error: Maximum execution time of 30 seconds exceeded in...
- Fatal error: Uncaught Error: Cannot use object of type stdClass as array in ...
- Warning: Use of undefined constant ... - assumed '...' (this will throw an Error)
- ERROR: Call to undefined method Maatwebsite\Excel\Excel::load()
- Maximum execution time of 30 seconds exceeded
- Your requirements could not be resolved to an installable set of packages. ... To enable extensions, verify that they are enabled in your .ini files:
- could not find driver
- the requested PHP extension mbstring is missing from your system.
- the requested PHP extension dom is missing from your system.
- A non well formed numeric value encountered
- Warning: Cannot modify header information - headers already sent by ...
- php_network_getaddresses: getaddrinfo failed: Name or service not known
- XMLWriter::openUri(): Unable to resolve file path
- Object of class stdClass could not be converted to string
- Class 'Google_Service_Youtube' not found
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?