介绍

Laravel Sail 是一个轻量级的命令行界面,用于与 Laravel 的默认 Docker 开发环境进行交互。Sail 为使用 PHP, MySQL, 和 Redis 构建 Laravel 应用提供了一个很好的起点,不需要事先有 Docker 经验。

Sail 的核心是 php docker-compose.yml 文件和存储在项目根目录的 php sail 脚本。php sail 脚本为 CLI 提供了便捷的方法,可用于与 php docker-compose.yml 文件定义的 Docker 容器进行交互。

Laravel Sail 支持 macOS、Linux 和 Windows (通过 WSL2)。

安装 & 设定

Laravel Sail 会随着所有全新的 Laravel 应用程序一起自动安装,因此你可以立即的开始使用它。要了解如何创建一个新的 Laravel 应用程序,请查阅适合您目前操作系统的 安装文档。在安装过程中,你将被要求选择你的应用程序将与哪些 Sail 支持的服务进行交互。

安装 Sail 到当前应用中

假如你有兴趣在你现有的 Laravel 应用程序中使用 Sail,你可以透过 Composer 套件管理简单的安装 Sail。当然,这些步骤的前提是假设你现有的本地开发环境允许你安装 Copmoser 依赖:

  1. composer require laravel/sail --dev

在 Sail 完成安装后,你可以运行 Artisan 命令 php sail:install。这个命令将会发布 Sail 的 php docker-compose.yml 文件到你应用程序的根目录:

  1. php artisan sail:install

最后,你可以启动 Sail 的服务了。想要继续学习如何使用 Sail,请接着阅读本文挡的其余部分:

  1. ./vendor/bin/sail up

增加额外服务
如果你想在你现有的 Sail 安装中添加一个额外的服务,你可以运行php sail:add Artisan 命令。

  1. php artisan sail:add

使用开发容器
如果你想在 Devcontainer 中进行开发,你可以在执行 php sail:install 命令时添加 php --devcontainer 参数。php --devcontainer 将指示 php sail:install 命令将默认的 php .devcontainer/devcontainer.json 文件发布到你的应用程序根目录:

  1. php artisan sail:install --devcontainer

配置 Shell 别名

默认情况下,Sail 命令使用 php vendor/bin/sail 脚本调用,该脚本已包含在所有新建的 Laravel 应用程序中:

  1. ./vendor/bin/sail up

但与其重复的输入 php vendor/bin/sail 来执行 Sail 命令,你可能会希望配置一个 Shell 别名方便你更容易的执行 Sail 命令:

  1. alias sail='[ -f sail ] && sh sail || sh vendor/bin/sail'

为了确保这一点始终可用,你可以把它添加到你的主目录下的 shell 配置文件中,如 php ~/.zshrcphp ~/.bashrc ,然后重新启动你的 shell。

一旦配置了 shell 别名,你可以通过简单地输入 php sail 来执行 Sail 命令。本文接下来的示例都假定你已经配置了此别名:

  1. sail up

启动 & 停止 Sail

Laravel Sail 的 php docker-compose.yml 文件定义了各种 Docker 容器,它们可以协同工作以帮助你构建 Laravel 应用程序。每一个容器都定义在 php docker-compose.yml 文件的 php services 的配置内。 php laravel.test 容器是将服务于您的应用程序的主要应用程序容器。

在开始 Sail 之前,你应该确认没有其他的网站服务器或数据库正运行在你的本地计算机上。要开始启用 php docker-compose.yml 文件中定义的所有 Docker 容器,请执行 php up 命令:

  1. sail up

要在后台启动所有的 Docker 容器,你可以以 “detached” 模式启动 Sail。

  1. sail up -d

启动应用程序的容器后,你可以通过 Web 浏览器中访问项目: http://localhost.

要停止所有的容器,你可以简单的按 Control + C 来停止容器的执行。或者,如果容器是在后台运行的,你可以使用 php stop 命令。

  1. sail stop

执行命令

使用 Laravel Sail 时,应用程序在 Docker 容器中执行,并且与本地计算机隔离。不过 Sail 提供了一种针对应用程序运行各种命令的便捷方法,例如任意的 PHP 命令,Artisan 命令,Composer 命令和 Node / NPM 命令。

当你阅读 Laravel 文档时,你可能经常看到在未使用 Sail 的状况下运行 Composer,Artisan 或是 Node / NPM 命令。 以下示例假设你已经在本地计算机上安装上述工具。如果你打算使用 Sail 建构你的本地开发环境 ,你需要改用 Sail 运行这些命令:

  1. # 在本地运行 Artisan 命令...
  2. php artisan queue:work
  3. # 在 Laravel Sail 中运行 Artisan 命令...
  4. sail artisan queue:work

执行 PHP 命令

PHP 命令可以使用 php php 命令执行。当然,这些命令将使用为你的应用程序配置的 PHP 版本执行。要了解更多关于 PHP 版本可用的 Laravel Sail 信息,请查阅 PHP 版本文档:

  1. sail php --version
  2. sail php script.php

执行 Composer 命令

Composer 命令可以使用 php composer 命令执行。Laravel Sail 的应用程序容器中已经安装 Composer 2.x:

  1. sail composer require laravel/sanctum

在已运行的应用中安装 Composer 依赖
假如你与团队一起开发应用程序,你也许不是最初创建 Laravel 应用程序的人。因此,当你克隆应用程序的仓库到本地计算机后,仓库默认不会安装的任何 Composer 依赖项,也包括 Sail。

你可以进入到应用程序目录下并执行以下命令来安装应用所需的依赖,这个命令使用一个包含 PHP 与 Composer 的小型 Docker 容器进行应用程序依赖的安装:

  1. docker run --rm \
  2. -u "$(id -u):$(id -g)" \
  3. -v "$(pwd):/var/www/html" \
  4. -w /var/www/html \
  5. laravelsail/php82-composer:latest \
  6. composer install --ignore-platform-reqs

当你使用 php laravelsail/phpXX-composer 镜像时,你应该选择和你的应用程序所用环境相同的 PHP 版本(php 74php 80php 81php 82)。

执行 Artisan 命令

Artisan 命令可以使用 php artisan 命令执行:

  1. sail artisan queue:work

执行 Node / NPM 命令

Node 命令可以使用 php node 命令执行,而 NPM 命令可以使用 php npm 命令执行:

  1. sail node --version
  2. sail npm run dev

如果你愿意,你可以使用 Yarn 代替 NPM:

  1. sail yarn

与数据库交互

MySQL

你可能已经注意到,应用程序的 php docker-compose.yml 文件包含一个 MySQL 容器的配置。该容器使用了 Docker volume,以便即使在停止和重新启动容器时依然可以持久存储数据库中存储的数据。

此外,在MySQL容器第一次启动时,它将为你创建两个数据库。第一个数据库使用你的 php DB_DATABASE 环境变量的值命名,用于你的本地开发。第二个是专门的测试数据库,名为 php testing,将确保你的测试不会干扰你的开发数据。

一旦你启动了你的容器,你可以通过在你的应用程序的 php .env 文件中设置 php DB_HOST 环境变量来连接到你的应用程序中的 MySQL 实例 php mysql

要从你的本地机器连接到你的应用程序的 MySQL 数据库,你可以使用一个图形化的数据库管理应用程序,如 TablePlus。默认情况下,MySQL 数据库可以通过 php localhost 端口 3306 访问,访问凭证与 php DB_USERNAMEphp DB_PASSWORD 环境变量的值一致。或者,你可以以 php root 用户的身份连接,它也利用 php DB_PASSWORD 环境变量的值作为密码。

Redis

应用程序的 php docker-compose.yml 文件也包含 Redis 容器的配置,此容器使用 Docker volume,以便即使在停止和重新启动容器后,Redis 数据中存储的数据也可以持久保存。启动容器后,可以通过将应用程序 php .env 文件中的环境变量 php REDIS_HOST 设置为 php redis 来连接到应用程序中的 Redis 实例。

要从本地计算机连接到应用程序的 Redis 数据库,可以使用图形数据库管理应用程序,例如 TablePlus。默认情况下,可以从 php localhost 的 6379 端口访问 Redis 数据库。

Meilisearch

如果你在安装 Sail 时选择安装 MeiliSearch 服务,你的应用程序的 php docker-compose.yml 文件将包含一个 Laravel Scout 兼容且强大的 搜索引擎服务组件配置。启动容器后,你可以通过将环境变量 php MEILISEARCH_HOST 设置为 php http://meilisearch:7700 来连接到应用程序中的 MeiliSearch 实例。

要从本地计算机访问 MeiliSearch 的 Web 管理面板,你可以通过浏览器访问 php http://localhost:7700

文件存储

如果你计划在生产环境中运行应用程序时使用 Amazon S3 存储文件,你可能希望在安装 Sail 时安装 MinIO 服务。 MinIO 提供了一个与 S3 兼容的 API,你可以使用 Laravel 的 php s3 文件存储驱动程序在本地进行开发,而无需在生产 S3 环境中创建用于测试的存储桶。如果在安装 Sail 时选择安装 MinIO,部分 MinIO 相关的配置将添加到应用程序的 php docker-compose.yml 文件中。

默认情况下,应用程序的 php filesystems 配置文件已经包含 php s3 磁盘的磁盘配置。除了使用此磁盘与 Amazon S3 交互之外,你还可以使用它与任何 S3 兼容的文件存储服务(例如 MinIO)进行交互,只需修改控制其配置的关联环境变量即可。例如,在使用 MinIO 时,你的文件系统环境变量配置应定义如下:

  1. FILESYSTEM_DISK=s3
  2. AWS_ACCESS_KEY_ID=sail
  3. AWS_SECRET_ACCESS_KEY=password
  4. AWS_DEFAULT_REGION=us-east-1
  5. AWS_BUCKET=local
  6. AWS_ENDPOINT=http://minio:9000
  7. AWS_USE_PATH_STYLE_ENDPOINT=true

为了让 Laravel 的 Flysystem 集成在使用 MinIO 时产生正确的 URL,你应该定义 php AWS_URL 环境变量,使其与你的应用程序的本地 URL 相匹配,并在 URL 路径中包含桶的名称。

  1. AWS_URL=http://localhost:9000/local

你可以通过 MinIO 控制台创建桶,该控制台可在 php http://localhost:8900 。MinIO 控制台的默认用户名是 php sail,默认密码是 php password

警告
使用 MinIO 时,不支持通过 php temporaryUrl 方法生成临时存储的 URL。

运行测试

Laravel 提供了出色的开箱即用测试,你可以使用 Sail 的 php test 命令运行应用程序的 功能和单元测试。任何 PHPUnit 可接受的命令选项都可以透过 php test 命令传递:

  1. sail test
  2. sail test --group orders

Sail php test 命令相当于运行 Artisan php test 命令:

  1. sail artisan test

默认情况下, Sail会创建一个专门的 php 测试 数据库, 这样你的测试就不会干扰到你的数据库的当前状态. 在默认的Laravel安装中, Sail也会配置你的 php phpunit.xml 文件, 在执行你的测试时使用这个数据库:

  1. <env name="DB_DATABASE" value="testing"/>

Laravel Dusk

Laravel Dusk 提供了非常优雅、易于使用的浏览器自动化测试 API。有了 Sail,进行浏览器测试更加方便了,你甚至不用在你的本地电脑上安装 Selenium 或者任何其他工具。要开启这项功能,请在 php docker-compose.yml 文件中取消 Selenium 服务相关配置的注释:

  1. selenium:
  2. image: 'selenium/standalone-chrome'
  3. volumes:
  4. - '/dev/shm:/dev/shm'
  5. networks:
  6. - sail

下一步,请确认 php docker-compose.yml 文件中的 php laravel.test 服务配置 php depends_on 是否包含了 php selenium 选项:

  1. depends_on:
  2. - mysql
  3. - redis
  4. - selenium

最后,你可以透过启动 Sail 并运行 php dusk 命令来进行 Dusk 测试:

  1. sail dusk

在 Apple Silicon 上运行 Selenium
如果你的本地机器包含 Apple Silicon 芯片,你的 php selenium 服务必须使用 php seleniarm/standalone-chromium 镜像:

  1. selenium:
  2. image: 'seleniarm/standalone-chromium'
  3. volumes:
  4. - '/dev/shm:/dev/shm'
  5. networks:
  6. - sail

预览电子邮件

Laravel Sail 默认的 php docker-compose.yml 文件中包含了一个服务项 Mailpit。Mailpit 在本地开发过程中拦截应用程序发送的邮件,并提供一个便捷的 Web 界面,这样你就可以在浏览器中预览你的邮件。当使用 Sail 时,Mailpit 的默认主机是 php mailpit ,可通过端口 1025 使用。

  1. MAIL_HOST=mailpit
  2. MAIL_PORT=1025
  3. MAIL_ENCRYPTION=null

当 Sail 运行时,你可以透过 http://localhost:8025 访问 Mailpit 的 Web 界面。

容器 CLI

有时候,你可能想要在应用容器中开启一个 Bash 会话。 可以通过执行 php shell 命令,以访问容器中的文件和已安装的服务,此外,你还可以执行其他任意 Shell 指令:

  1. sail shell
  2. sail root-shell

想打开一个新的 Laravel Tinker 会话,你可以执行 php tinker 命令:

  1. sail tinker

PHP 版本

Sail目前支持通过 PHP 8.2、8.1、PHP 8.0 或 PHP 7.4 为你的应用程序提供服务。目前 Sail 使用的默认 PHP 版本是 PHP 8.2。想更改应用程序使用的 PHP 版本,请在 php docker-compose.yml 文件定义的容器 php laravel.test 相应配置中调整 php build 定义:

  1. # PHP 8.2
  2. context: ./vendor/laravel/sail/runtimes/8.2
  3. # PHP 8.1
  4. context: ./vendor/laravel/sail/runtimes/8.1
  5. # PHP 8.0
  6. context: ./vendor/laravel/sail/runtimes/8.0
  7. # PHP 7.4
  8. context: ./vendor/laravel/sail/runtimes/7.4

此外,你如果想更新你的镜像名称来反映当前使用的 PHP 版本,你可以在 php docker-compose.yml 文件中调整 php image 字段:

  1. image: sail-8.1/app

在修改 php docker-compose.yml 文件过后,你需要重建容器镜像并重启 Sail:

  1. sail build --no-cache
  2. sail up

Node 版本

Sail 默认安装 Node 18。要更改镜像构建时所安装的 Node 版本,你可以在应用程序的 php docker-compose.yml 文件中更新 php laravel.test 服务的 php build.args 定义:

  1. build:
  2. args:
  3. WWWGROUP: '${WWWGROUP}'
  4. NODE_VERSION: '14'

在修改 php docker-compose.yml 文件过后,你需要重建容器镜像并重启 Sail:

  1. sail build --no-cache
  2. sail up

共享你的网站

有时候你可能需要公开分享你的网站给同事,或是测试应用与 Webhook 的集成。想共享你的网站时,可以使用 php share 命令。当你执行此命令后,将会获取一个随机的网址,例如 php laravel-sail.site 用来访问你的应用程序:

  1. sail share

当通过 php share 命令共享你的站点时,你应该在 php TrustProxies 中间件中配置应用程序的可信代理。否则,相关的URL 生成的助手函数,例如 php urlphp route 将无法在生成 URL 生成过程中选择正确 HTTP 主机地址:

  1. /**
  2. * 应用程序的受信任代理
  3. *
  4. * @var array|string|null
  5. */
  6. protected $proxies = '*';

如果你想为你的共享站点自定义子域名,可以在执行 php share 命令时加上 php subdomain 参数:

  1. sail share --subdomain=my-sail-site

注意
php share 命令是由 Expose 提供,这是 BeyondCode 的一个开源网络隧道服务。

使用 Xdebug 进行调试

Laravel Sail 的 Docker 配置包含对 Xdebug 的支持,这是一个流行且强大的 PHP 调试器。为了启用 Xdebug,你需要在应用程序的 php .env 文件中添加一些变量以 配置 Xdebug。要启用 Xdebug,你必须在启动 Sail 之前设置适当的应用模式:

  1. SAIL_XDEBUG_MODE=develop,debug,coverage

Linux 主机 IP 配置
在容器内部,php XDEBUG_CONFIG 环境变量被定义为 php client_host=host.docker.internal 以便为 Mac 和 Windows (WSL2) 正确配置 Xdebug。如果你的本地机器运行的是 Linux,确保你运行的是 Docker Engine 17.06.0+ 和 Compose 1.16.0+。否则,你将需要手动定义这个环境变量。

首先,你需要通过运行以下命令来确定要添加到环境变量中的正确主机 IP 地址。通常,php <container-name> 应该是为你的应用程序提供服务的容器的名称,并且通常以 php _laravel.test_1 结尾:

  1. docker inspect -f {{range.NetworkSettings.Networks}}{{.Gateway}}{{end}} <container-name>

在获得正确的主机 IP 地址后,你需要在应用程序的 php .env 文件中定义 php SAIL_XDEBUG_CONFIG 变量:

  1. SAIL_XDEBUG_CONFIG="client_host=<host-ip-address>"

通过命令行使用 Xdebug 进行调试

在运行 Artisan 命令时,可以使用 php sail debug 命令启动调试会话:

  1. # 在没有 Xdebug 的情况下运行 Artisan 命令...
  2. sail artisan migrate
  3. # 使用 Xdebug 运行 Artisan 命令...
  4. sail debug migrate

通过浏览器使用 Xdebug 进行调试

要在通过 Web 浏览器与应用程序交互时调试你的应用程序,请按照 Xdebug 提供的说明 从 Web 浏览器启动 Xdebug 会话。

如果你使用的是 PhpStorm,请查看 JetBrains 关于 零配置调试 的文档。

警告
Laravel Sail 依赖于 php artisan serve 来为你的应用程序提供服务。从 Laravel 8.53.0 版本开始,php artisan serve 命令只接受 php XDEBUG_CONFIGphp XDEBUG_MODE 变量。从 Laravel 8.53.0 版本开始,旧版本的 Laravel(8.52.0 及以下)不支持这些变量并且不接受调试连接。

定制化

因为 Sail 就是 Docker,所以你可以自由的定制任何内容,使用 php sail:publish 命令可以将 Sail 预设的 Dockerfile 发布到你的应用程序中,以便于进行定制:

  1. sail artisan sail:publish

运行这个命令后,Laravel Sail 预设好的 Dockerfile 和其他配置文件将被生成发布到项目根目录的 php docker 目录中。当你自行定制 Sail 配置之后,你可以在应用程序的 php docker-compose.yml 文件中更改应用程序容器的映像名称。在完成上述操作后,你需要使用 php build 命令重新构建容器。如果你使用 Sail 在单台机器上开发多个 Laravel 应用程序,那么为应用程序的镜像分配一个唯一的名称将尤为重要:

  1. sail build --no-cache