ホームページ >バックエンド開発 >PHPチュートリアル >クラウド用のLaravelアプリを準備します

クラウド用のLaravelアプリを準備します

Emily Anne Brown
Emily Anne Brownオリジナル
2025-03-07 01:02:09641ブラウズ

ララコヌスでの最近の発表は、ララヴェルコミュニティ内のクラウドベースの展開に新たな関心を呼び起こしました。アプリの展開方法について議論が続くにつれて、1つのことが明らかです。クラウドはLaravelユーザーにとってより実行可能なオプションになりつつあります。 この記事では、frankenphp、caddy、dockerfilesを使用してクラウド環境で展開するためにLaravelアプリを準備する方法を紹介します。

では、どこから始めますか?もちろん、地元の環境で! ?

#local開発環境

簡単にするために、ローカルマシンに新鮮なLaravelアプリがインストールされていると仮定します。これは、PostgreSQLデータベースに接続してデータを読み取り/書き込みます。

先に進む前に、次のコンテンツを使用してプロジェクトルートに

ファイルを持っていることを確認してください。

.envそれが確認されたら、構築を開始できます。 ? ☕️

生産環境によく似たローカル開発環境を持つことをお勧めします。このようにして、早期に問題をキャッチし、プロダクションにアプリを展開するときに驚きを避けることができます。 .env dockerとdocker Composeを使用する生産セットアップを模倣するために。 Dockerがマシンにインストールされていない場合は、公式Webサイトからダウンロードできます。 データベースなしでlaravelを実行します

最初に、Laravelプロジェクトのrootに
<!-- Syntax highlighted by torchlight.dev -->...
DB_CONNECTION=pgsql
...
と呼ばれる新しいファイルを作成し、次のコンテンツを追加します。

この構成ファイルは、Laravelアプリを実行するために必要な拡張機能を含むfrankenPhp画像である

画像を使用する

と呼ばれるサービスを定義します。

環境変数は、ポートで聴くようにCaddyを構成します。 また、ホストマシンからアプリにアクセスするためにポート

を公開します。

構成をテストするには、端末で次のコマンドを実行してみてください。 compose.yml ブラウザでドライバーが欠落しているため、接続がデータベースに確立されていないことを説明するLaravelエラーページが表示されます。 Laravelアプリをまだデータベースに接続していないため、これは予想されます。

素晴らしい、これまでのところ、LaravelアプリをFrankenPhpサーバーで提供するように構成しました。

次に、ローカルアプリをpostgreSQLデータベースに接続しましょう!compose.yml データベースでlaravelを実行します

#running
<!-- Syntax highlighted by torchlight.dev -->services:
  php:
    image: dunglas/frankenphp:php8.3-bookworm
    environment:
      SERVER_NAME: ":8080"
    ports:
      - 8080:8080
    volumes:
      - .:/app
LaravelアプリをPostgreSQLデータベースに接続するには、いくつかのことをする必要があります。

最初に、phpファイルに次の環境変数を設定する必要があります:dunglas/frankenphp:php8.3-bookworm SERVER_NAME80808080

<!-- 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

は、ローカル/開発環境でのみ使用されることを目的としており、Dockerfile.dev拡張機能を含めるようにdunglas/frankenphp:php8.3-bookworm画像を拡張します。 pdo_pgsql

compose.yml

ここではたくさんのことが起こっています。何が変わったのか、そしてその理由を見てみましょう。
<!-- Syntax highlighted by torchlight.dev -->docker compose up [-d]

サービスを更新して、
    というカスタムDockerFileを使用して、PostgreSQLデータベースに接続するために必要な拡張機能を含む新しい画像を作成しました。
  1. php画像を使用するDockerfile.devという新しいサービスを追加しました。また、データベースユーザー、パスワード、およびデータベース名を設定するためのいくつかの環境変数を定義しました。
  2. マシンのデータベースにデータを保持するために
  3. という新しいボリュームを作成しました。Dockerは、サービスを再起動すると再利用できます。 db postgres:16.4-alpineと呼ばれる新しいサービスも、
  4. を再利用することを追加しました。この画像は、データベースの移行を実行するために
  5. コマンドを実行するために使用されます。 db_dataキーは、移行が実行される前に
  6. サービスが稼働していることを保証します。
  7. initサービスは、Laravelアプリが開始される前にデータベースの移行が実行されるようにDockerfile.devサービスに依存しています。 php artisan migrate depends_onサービスに追加しました。 db
  8. 構成をテストするには、端末で次のコマンドを実行します。
  9. phpアプリケーションはPostgreSQLデータベースに接続する必要があり、データベースの移行は常に実行されます。 ?init
  10. あなたの地元のEnvnirmentは、あなたの生産環境を模倣する準備ができています。これで、アプリをローカルに開発し、生産で使用する非常によく似たセットアップをテストできます。
  11. ##preparing for productiondb init生産環境に必要な変更を加える時が来ました。
最初のステップは、生産画像を構築するときにどのディレクトリが安全に無視できるかをDockerに伝えることです。 laravelプロジェクトのルートで

という新しいファイルを作成し、次のコンテンツを追加します。

<!-- 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
...
これは、以前に作成したに似ていますが、いくつかの追加手順が含まれています。

Dockerfilefrankenphp画像はデフォルトのWebサーバーとしてCaddyを使用するため、Dockerfile.dev環境変数を

に設定して、キャディにポート
  1. 画像にコンポーザーをインストールするためにSERVER_NAMEPHP拡張機能をインストールします。 :80808080コマンドは、laravelアプリの依存関係をインストールするために実行されます。
  2. ワーキングディレクトリを
  3. に設定し、Laravelアプリの内容を画像にコピーしました。 @composer
  4. ローカル環境で変更をテストするには、アプリの生産ビルドを作成する必要があります。ターミナルで次のコマンドを実行します:
  5. composer install このコマンドは、現在のディレクトリの
  6. に基づいて、
  7. に基づいて呼ばれる新しい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アプリを作成できます。
  1. create app modalに移動します
  2. 希望のGitプロバイダーからアプリのリポジトリを選択します
  3. データベースが
  4. にあるのと同じデータセンターを選択してください
laravel

で必要な環境変数を設定します

as build type

残りの設定を確認し、「後で展開」ボタンを押します
  1. アプリの準備ができたら、PostgreSQLデータベースに接続できるようになりました。
    1. アプリのページに移動します
    2. 「ネットワーク」タブ
    3. に移動します
    4. [接続の追加]ボタンをクリックして、postgreSQLデータベースを選択
    5. 設定を確認し、「connect」
    6. を押します

    次に、データベースの接続の詳細を使用して、「環境変数」タブに次の環境変数を設定します。

  • DB_CONNECTION
  • DB_HOST
  • DB_PORT
  • DB_DATABASE
  • DB_USERNAME
  • DB_PASSWORD

データベースの内部ネットワークアドレスを

値として使用することを推奨しました。これにより、アプリはプライベートネットワークを介してデータベースに接続できます。 DB_HOST最後のステップは、アプリを開始する前に、アプリケーションがデータベースのmirgationを実行するためのジョブプロセスを設定することです。

「プロセス」タブ

に移動します
    [プロセスの作成]ボタンをクリックし、[ジョブ]
  1. を選択します コマンドを
  2. に設定します
  3. 開始ポリシーを「展開前」に設定します
  4. php artisan migrate --force設定を確認し、「作成」
  5. を押します

これも完了した場合、[展開]タブでアプリの手動展開を開始できるようになりました。 ? すべてがうまくいったら、おめでとうございます!クラウド用のLaravelアプリを正常に準備しました。 ?

#conclusion

この記事では、以下を調査しました

dockerと

Docker、Frankenphp、およびCaddyを使用してクラウド環境で展開するためにLaravelアプリを準備する方法。

また、Sevallaのようなクラウドプロバイダーにアプリを展開する方法についても説明しました。

    これらの手順に従うことにより、Laravelアプリを新たな高みに引き上げて、クラウドベースの展開の利点を享受できます。 ?
  • docker compose#update:2024年9月8日
  • Xについての議論を通じて、コミュニティから貴重なフィードバックを受け取りました。
  • 最初のポイントは、
  • ファイルに
  • コマンドを含めることは不要であることを強調しました。
ファイルの関連セクションを更新することにより、これを修正しました。ケビン・ダングラス(Frankenphpの作成者)が共有する2番目のポイントは、DebianがPHPとのより良い互換性とFrankenPhpとのより良いパフォーマンスを提供するため、Alpine(

)の代わりにDebianベースの画像(bookworm)を使用して推奨されています。その結果、ファイルとalpineの両方を更新しました。 Dockerfile.devコミュニティのサポートとフィードバックに感謝しています。 ? ❤️Dockerfile

以上がクラウド用のLaravelアプリを準備しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。