ララコヌスでの最近の発表は、ララヴェルコミュニティ内のクラウドベースの展開に新たな関心を呼び起こしました。アプリの展開方法について議論が続くにつれて、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: - .:/appLaravelアプリをPostgreSQLデータベースに接続するには、いくつかのことをする必要があります。
最初に、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></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 サイトの他の関連記事を参照してください。

Sessionlockingisatechniqueusedtoensureauser'ssessionremainsexclusivetooneuseratatime.Itiscrucialforpreventingdatacorruptionandsecuritybreachesinmulti-userapplications.Sessionlockingisimplementedusingserver-sidelockingmechanisms,suchasReentrantLockinJ

PHPセッションの代替品には、Cookie、トークンベースの認証、データベースベースのセッション、Redis/Memcachedが含まれます。 1.Cookiesは、クライアントにデータを保存することによりセッションを管理します。 2.トークンベースの認証はトークンを使用してユーザーを検証します。これは非常に安全ですが、追加のロジックが必要です。 3.Databaseベースのセッションは、データベースにデータを保存します。これは、スケーラビリティが良好ですが、パフォーマンスに影響を与える可能性があります。 4. Redis/Memcachedは分散キャッシュを使用してパフォーマンスとスケーラビリティを向上させますが、追加のマッチングが必要です

SessionHijackingとは、ユーザーのSessionIDを取得してユーザーになりすましている攻撃者を指します。予防方法には、次のものが含まれます。1)HTTPSを使用した通信の暗号化。 2)SessionIDのソースの検証。 3)安全なSessionID生成アルゴリズムの使用。 4)SessionIDを定期的に更新します。

この記事では、PHPについて説明し、その完全なフォーム、Web開発での主要な使用、PythonとJavaとの比較、および初心者の学習のしやすさについて説明します。

PHPは、$ \ _ postおよび$ \ _を使用してフォームデータを処理し、検証、消毒、安全なデータベースインタラクションを通じてセキュリティを確保します。

この記事では、PHPとASP.NETを比較して、大規模なWebアプリケーション、パフォーマンスの違い、セキュリティ機能への適合性に焦点を当てています。どちらも大規模なプロジェクトでは実行可能ですが、PHPはオープンソースであり、プラットフォームに依存しませんが、ASP.NET、

PHPの症例感度は変化します:関数は鈍感であり、変数とクラスは感度があります。ベストプラクティスには、一貫した命名と、比較のためにケース非感受性関数を使用することが含まれます。

この記事では、PHPのページリダイレクトのさまざまな方法について説明し、ヘッダー()関数に焦点を当て、「すでに送信されているヘッダー」エラーなどの一般的な問題に対処します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

WebStorm Mac版
便利なJavaScript開発ツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ホットトピック









