クラウド用のLaravelアプリを準備します
ララコヌスでの最近の発表は、ララヴェルコミュニティ内のクラウドベースの展開に新たな関心を呼び起こしました。アプリの展開方法について議論が続くにつれて、1つのことが明らかです。クラウドはLaravelユーザーにとってより実行可能なオプションになりつつあります。 この記事では、frankenphp、caddy、dockerfilesを使用してクラウド環境で展開するためにLaravelアプリを準備する方法を紹介します。
では、どこから始めますか?もちろん、地元の環境で! ?#local開発環境
ファイルを持っていることを確認してください。
:
.env
それが確認されたら、構築を開始できます。 ? ☕️
生産環境によく似たローカル開発環境を持つことをお勧めします。このようにして、早期に問題をキャッチし、プロダクションにアプリを展開するときに驚きを避けることができます。
.env
dockerとdocker Composeを使用する生産セットアップを模倣するために。 Dockerがマシンにインストールされていない場合は、公式Webサイトからダウンロードできます。
データベースなしでlaravelを実行します
<!-- Syntax highlighted by torchlight.dev -->... DB_CONNECTION=pgsql ...
この構成ファイルは、Laravelアプリを実行するために必要な拡張機能を含むfrankenPhp画像である
画像を使用する
と呼ばれるサービスを定義します。環境変数は、ポートで聴くようにCaddyを構成します。 また、ホストマシンからアプリにアクセスするためにポート
を公開します。構成をテストするには、端末で次のコマンドを実行してみてください。
compose.yml
ブラウザでドライバーが欠落しているため、接続がデータベースに確立されていないことを説明するLaravelエラーページが表示されます。 Laravelアプリをまだデータベースに接続していないため、これは予想されます。
次に、ローカルアプリをpostgreSQLデータベースに接続しましょう!compose.yml
データベースでlaravelを実行します
<!-- Syntax highlighted by torchlight.dev -->services: php: image: dunglas/frankenphp:php8.3-bookworm environment: SERVER_NAME: ":8080" ports: - 8080:8080 volumes: - .:/app
最初に、php
ファイルに次の環境変数を設定する必要があります:dunglas/frankenphp:php8.3-bookworm
SERVER_NAME
8080
:8080
<!-- Syntax highlighted by torchlight.dev -->... DB_CONNECTION=pgsql ...
それに続いて、新しいサービスをcompose.yml
ファイルに追加し、開発環境向けにカスタムDockerfile
を作成する必要があります。次のコンテンツを使用してファイルを作成して更新します
:Dockerfile.dev
<!-- Syntax highlighted by torchlight.dev -->services: php: image: dunglas/frankenphp:php8.3-bookworm environment: SERVER_NAME: ":8080" ports: - 8080:8080 volumes: - .:/app
は、ローカル/開発環境でのみ使用されることを目的としており、dunglas/frankenphp:php8.3-bookworm
画像を拡張します。
pdo_pgsql
compose.yml
<!-- Syntax highlighted by torchlight.dev -->docker compose up [-d]
- というカスタムDockerFileを使用して、PostgreSQLデータベースに接続するために必要な拡張機能を含む新しい画像を作成しました。
-
php画像を使用する Dockerfile.dev
という新しいサービスを追加しました。また、データベースユーザー、パスワード、およびデータベース名を設定するためのいくつかの環境変数を定義しました。 マシンのデータベースにデータを保持するために - という新しいボリュームを作成しました。Dockerは、サービスを再起動すると再利用できます。
db
postgres:16.4-alpine
と呼ばれる新しいサービスも、 を再利用することを追加しました。この画像は、データベースの移行を実行するために - コマンドを実行するために使用されます。
db_data
キーは、移行が実行される前に サービスが稼働していることを保証します。
-
init
サービスは、Laravelアプリが開始される前にデータベースの移行が実行されるようにDockerfile.dev
サービスに依存しています。php artisan migrate
depends_onサービスに追加しました。 db
構成をテストするには、端末で次のコマンドを実行します。
-
php
アプリケーションはPostgreSQLデータベースに接続する必要があり、データベースの移行は常に実行されます。 ?init
あなたの地元のEnvnirmentは、あなたの生産環境を模倣する準備ができています。これで、アプリをローカルに開発し、生産で使用する非常によく似たセットアップをテストできます。
- ##preparing for production
db
init
生産環境に必要な変更を加える時が来ました。
という新しいファイルを作成し、次のコンテンツを追加します。
<!-- Syntax highlighted by torchlight.dev -->... DB_CONNECTION=pgsql DB_HOST=db DB_PORT=5432 # default PostgreSQL port DB_DATABASE=main DB_USERNAME=admin DB_PASSWORD=password
このファイルは、
、
、およびディレクトリを無視するようにDockerに指示します。
次に、制作イメージの構築に使用されるDockerfile
を作成します。
:Dockerfile
<!-- Syntax highlighted by torchlight.dev -->... DB_CONNECTION=pgsql ...
Dockerfile
frankenphp画像はデフォルトのWebサーバーとしてCaddyを使用するため、Dockerfile.dev
環境変数を
- 。
- 画像にコンポーザーをインストールするために
SERVER_NAME
PHP拡張機能をインストールします。:8080
8080
コマンドは、laravelアプリの依存関係をインストールするために実行されます。 ワーキングディレクトリを - に設定し、Laravelアプリの内容を画像にコピーしました。
@composer
ローカル環境で変更をテストするには、アプリの生産ビルドを作成する必要があります。ターミナルで次のコマンドを実行します: -
composer install
このコマンドは、現在のディレクトリの に基づいて、 - に基づいて呼ばれる新しいDocker画像を構築します。
/app
新しく構築された生産画像をテストするには、次のコマンドを使用してください。
<!-- Syntax highlighted by torchlight.dev -->services: php: image: dunglas/frankenphp:php8.3-bookworm environment: SERVER_NAME: ":8080" ports: - 8080:8080 volumes: - .:/app
ファイルの変数に置き換えるか、ここからキーをつかみます。my-laravel-app
Dockerfile
ブラウザでLocalHost:8080にアクセスすると、アプリは生産モードで開始する必要があります。データベース接続がないためにエラーが発生する可能性がありますが、それは予想されます。
制作可能なDocker画像ができたので、クラウドプロバイダーに展開できます。 ?
<!-- Syntax highlighted by torchlight.dev -->docker compose up [-d]
ベースの展開を展開する簡単な方法を提供する新しいクラウドプロバイダーであるSevallaを使用します。
<your-app-key>
アプリはPostgreSQLデータベースに依存するため、Sevallaで新しいPostgreSQLデータベースを最初にプロビジョニングする方が良いでしょう。 Sevalla Dashboardにログインしたら、APP_KEY
.env
に移動します
postgreSQLデータベースを選択します設定を確認し、データベースを作成します
Dockerfile
データベースの準備ができたら、SevallaでLaravelアプリを作成できます。
- create app modalに移動します
- 希望のGitプロバイダーからアプリのリポジトリを選択します
- データベースが にあるのと同じデータセンターを選択してください
で必要な環境変数を設定します
残りの設定を確認し、「後で展開」ボタンを押します
- アプリの準備ができたら、PostgreSQLデータベースに接続できるようになりました。
- アプリのページに移動します
- 「ネットワーク」タブ に移動します
- [接続の追加]ボタンをクリックして、postgreSQLデータベースを選択
- 設定を確認し、「connect」 を押します
次に、データベースの接続の詳細を使用して、「環境変数」タブに次の環境変数を設定します。
-
DB_CONNECTION
-
DB_HOST
-
DB_PORT
-
DB_DATABASE
-
DB_USERNAME
-
DB_PASSWORD
値として使用することを推奨しました。これにより、アプリはプライベートネットワークを介してデータベースに接続できます。
DB_HOST
最後のステップは、アプリを開始する前に、アプリケーションがデータベースのmirgationを実行するためのジョブプロセスを設定することです。
「プロセス」タブ
に移動します- [プロセスの作成]ボタンをクリックし、[ジョブ]
- を選択します コマンドを
- に設定します 開始ポリシーを「展開前」に設定します
-
php artisan migrate --force
設定を確認し、「作成」 を押します
これも完了した場合、[展開]タブでアプリの手動展開を開始できるようになりました。 ?
すべてがうまくいったら、おめでとうございます!クラウド用のLaravelアプリを正常に準備しました。 ?
#conclusion
この記事では、以下を調査しましたdockerと
。
Docker、Frankenphp、およびCaddyを使用してクラウド環境で展開するためにLaravelアプリを準備する方法。また、Sevallaのようなクラウドプロバイダーにアプリを展開する方法についても説明しました。
- これらの手順に従うことにより、Laravelアプリを新たな高みに引き上げて、クラウドベースの展開の利点を享受できます。 ?
-
docker compose
#update:2024年9月8日 - Xについての議論を通じて、コミュニティから貴重なフィードバックを受け取りました。 最初のポイントは、
- ファイルに コマンドを含めることは不要であることを強調しました。
)の代わりにDebianベースの画像(bookworm
)を使用して推奨されています。その結果、ファイルとalpine
の両方を更新しました。
Dockerfile.dev
コミュニティのサポートとフィードバックに感謝しています。 ? ❤️Dockerfile
以上がクラウド用のLaravelアプリを準備しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

セッションハイジャックは、次の手順で達成できます。1。セッションIDを取得します。2。セッションIDを使用します。3。セッションをアクティブに保ちます。 PHPでのセッションハイジャックを防ぐための方法には次のものが含まれます。1。セッション_regenerate_id()関数を使用して、セッションIDを再生します。2。データベースを介してストアセッションデータを3。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

php8.1の列挙関数は、指定された定数を定義することにより、コードの明確さとタイプの安全性を高めます。 1)列挙は、整数、文字列、またはオブジェクトであり、コードの読みやすさとタイプの安全性を向上させることができます。 2)列挙はクラスに基づいており、トラバーサルや反射などのオブジェクト指向の機能をサポートします。 3)列挙を比較と割り当てに使用して、タイプの安全性を確保できます。 4)列挙は、複雑なロジックを実装するためのメソッドの追加をサポートします。 5)厳密なタイプのチェックとエラー処理は、一般的なエラーを回避できます。 6)列挙は魔法の価値を低下させ、保守性を向上させますが、パフォーマンスの最適化に注意してください。
