容器化 PHP 應用程式

先決條件

  • 您已安裝最新版本的 Docker Desktop
  • 您有一個 git 客戶端。本節中的示例使用基於命令列的 git 客戶端,但您可以使用任何客戶端。

概述

本節將引導您完成 PHP 應用程式的容器化和執行。

獲取示例應用程式

在本指南中,您將使用預構建的 PHP 應用程式。該應用程式使用 Composer 進行庫依賴管理。您將透過 Apache Web 伺服器提供該應用程式。

開啟終端,進入您想要工作的目錄,然後執行以下命令克隆儲存庫。

$ git clone https://github.com/docker/docker-php-sample

這個示例應用程式是一個基本的“Hello World”應用程式,以及一個在資料庫中增加計數器的應用程式。此外,該應用程式還使用 PHPUnit 進行測試。

初始化 Docker 資產

現在您已經擁有了一個應用程式,您可以使用 docker init 來建立必要的 Docker 資產,以容器化您的應用程式。在 docker-php-sample 目錄中,在終端中執行 docker init 命令。docker init 提供了一些預設配置,但您需要回答一些關於應用程式的問題。例如,此應用程式使用 PHP 8.2 版本。請參考以下 docker init 示例,併為您的提示使用相同的答案。

$ docker init
Welcome to the Docker Init CLI!

This utility will walk you through creating the following files with sensible defaults for your project:
  - .dockerignore
  - Dockerfile
  - compose.yaml
  - README.Docker.md

Let's get started!

? What application platform does your project use? PHP with Apache
? What version of PHP do you want to use? 8.2
? What's the relative directory (with a leading .) for your app? ./src
? What local port do you want to use to access your server? 9000

現在您的 docker-php-sample 目錄中應該有以下內容。

├── docker-php-sample/
│ ├── .git/
│ ├── src/
│ ├── tests/
│ ├── .dockerignore
│ ├── .gitignore
│ ├── compose.yaml
│ ├── composer.json
│ ├── composer.lock
│ ├── Dockerfile
│ ├── README.Docker.md
│ └── README.md

要了解有關 `docker init` 新增的檔案的更多資訊,請參閱以下內容

執行應用程式

docker-php-sample 目錄中,在終端中執行以下命令。

$ docker compose up --build

開啟瀏覽器,在 https://:9000/hello.php 檢視應用程式。您應該會看到一個簡單的“Hello World”應用程式。

在終端中,按 ctrl+c 停止應用程式。

在後臺執行應用程式

您可以透過新增 -d 選項將應用程式與終端分離執行。在 docker-php-sample 目錄中,在終端中執行以下命令。

$ docker compose up --build -d

開啟瀏覽器,在 https://:9000/hello.php 檢視應用程式。您應該會看到一個簡單的“Hello World”應用程式。

在終端中,執行以下命令以停止應用程式。

$ docker compose down

有關 Compose 命令的更多資訊,請參閱Compose CLI 參考

摘要

在本節中,您學習瞭如何使用 Docker 容器化並執行一個簡單的 PHP 應用程式。

相關資訊

後續步驟

在下一節中,您將學習如何使用 Docker 容器開發您的應用程式。