【Laravel】artisanのdownコマンドを解説

チートシート

Laravel 10.xのartisanの「down」コマンドを解説します。

Description

アプリケーションをメンテナンス/デモモードにします。
メンテナンス中は通常のアクセスが503エラーとなり、指定したビューが表示されます。

Usage

php artisan down [--redirect [REDIRECT]] [--render [RENDER]] [--retry [RETRY]] [--refresh [REFRESH]] [--secret [SECRET]] [--status [STATUS]]

Options

オプション省略形必須説明
redirectユーザーがリダイレクトされるべきパス
renderメンテナンスモード時に表示するためにプリレンダリングすべきビュー
retryリクエストの再試行が可能な秒数
refreshブラウザが更新されるまでの秒数
secretメンテナンスモードを回避するために使用される秘密のフレーズ
statusメンテナンスモードレスポンスを返すときに使用するステータスコード

Example

no options

php artisan down
   INFO  Application is now in maintenance mode.  

ブラウザアクセス時は以下のような503 SERVICE UNAVAILABLEが表示されます。

render

php artisan down --render="errors::503"

表示するビューを指定できます。
様々な機能やプラグインなどをロードする前にレンダリングするので、ユーザーがメンテナンス中にアクセスすることによりエラーが発生することを防いだりできます。

retry

php artisan down --retry=3600

HTTPヘッダのRetry-Afterを設定します。
このヘッダは見た目などに変化はありませんが、Googleのクローラーなどが再クロールまでの時間を調整してくれます。

refresh

php artisan down --refresh=30

HTTPヘッダのRefreshが設定されます。指定した秒数毎にブラウザがリロードされます。

secret

php artisan down --secret=abcdefg

通常のアクセスはメンテナンスモードの503となりますが、以下のようにsecretで指定した文字列のURLからアクセスすると、/へリダイレクトされ通常通りアクセスできるようになります。

http://your.domain/abcdefg

status

php artisan down --status=404

Source

著者

Webエンジニア歴30年、フリーランスバックエンドエンジニア。

PHP歴約30年(Laravel 7年・FuelPHP 5年・CakePHP・自作FW)、
JavaScript歴約20年(React・Vue各4年)。
AWS(EC2 / CloudFront / RDS / API Gateway など)・
GCP(BigQuery)を使ったバックエンド開発を中心に、
複数の事業会社・受託案件でシステム設計から実装・運用まで担当しています。

PHPがバージョン4の時代から書いており、
Laravelが普及する前のフレームワーク乱立期も経験しています。
「昔はこう書いていたが今はこう」という変遷を肌で知っているエンジニアとして、
単なるコマンドの使い方だけでなく、なぜそうするのかの背景まで伝えることを意識して書いています。

このブログでは、実務で実際に詰まった箇所・調べたこと・気づいたことを
そのまま記事にしています。誰かの「詰まり」が解決するきっかけになれば幸いです。

千原 耕司をフォローする

役にたったと思ったら応援をお願いします m(._.)m

チートシート
スポンサーリンク
シェアする
千原 耕司をフォローする
タイトルとURLをコピーしました