0

0

【Laravel vx Docker】利用 Laravel Sail 高效搭建 Laravel 应用开发环境

碧海醫心

碧海醫心

发布时间:2024-10-23 13:56:25

|

1132人浏览过

|

来源于dev.to

转载

关于 laravel sail

laravel sail 是 laravel 框架的官方开发环境。 sail 提供了一个轻量级的命令行界面 (cli),可以使用 docker 轻松设置和管理 laravel 应用程序开发环境。下面,我们讲解一下 laravel sail 的主要特性和使用方法。

使用 laravel sail 的好处

  1. 构建独立于操作系统的开发环境
    • sail 使用 docker 来容器化 laravel 应用程序的开发环境。这使您可以构建独立于操作系统的开发环境。
  2. 轻松设置开发环境
    • 使用 sail,只需几条命令即可搭建 laravel 开发环境。即使使用 mysqlredis、mailhog 等复杂的开发环境,也可以轻松构建。
  3. 轻松管理不同版本的项目
    • 例如,laravel 的版本取决于 php 的版本,但通过在 docker-compose.yml 文件中设置每个项目的环境,可以轻松切换版本。

【Laravel vx Docker】利用 Laravel Sail 高效搭建 Laravel 应用开发环境
当您使用 docker 和 laravel sail 创建项目时,结构将如上图所示。

用法

开发环境

  • mac
  • php v8.3
  • laravel v11
  • docker

先决条件

在创建 laravel 项目之前,请下载并启动 docker desktop。
https://www.docker.com/products/docker-desktop/

1. 创建 laravel 项目

运行以下命令创建一个新的 laravel 项目并设置 laravel sail。

curl -s "https://laravel.build/example-app" | bash
cd example-app

这将创建 laravel 项目文件。生成的 docker-compose.yml 文件中描述了开发环境。

使用 with 查询指定服务

如果要指定php版本或者使用postgresql而不是mysql,可以在生成项目时的命令中指定with=,,...

curl -s "https://laravel.build/example-app?php=81&with=pgsql,redis" | bash

2. 起航

移动到项目目录并启动 sail。

./vendor/bin/sail up -d

此命令启动 docker 容器并运行 laravel 应用程序。

※注册别名

输入 ./vendor/bin/sail 很麻烦,因此请将其保存为 shell 配置文件中的别名 sail。

使用以下命令检查您正在使用的 shell 的路径

echo $shell

示例:/bin/zsh

编辑 shell 配置文件

  • 对于 zsh

shell 配置文件是 ~/.zshrc。
要添加别名,请运行以下命令

echo "alias sail='sh $([ -f sail ] && echo sail || echo vendor/bin/sail)'" >> ~/.zshrc
source ~/.zshrc
  • 对于 bash

shell 配置文件是 ~/.bash_profile 或 ~/.bashrc。
要添加别名,请运行以下命令:

echo "alias sail='sh $([ -f sail ] && echo sail || echo vendor/bin/sail)'" >> ~/.bash_profile
source ~/.bash_profile

通过上述设置,您可以以缩写形式运行 sail 命令。

sail up -d

3. 使用 sail 命令

您可以使用sail执行各种开发任务。以下是一些示例。

  • 启动应用程序
sail up -d
  • 停止应用程序
sail down
  • 运行 artisan 命令
sail artisan migrate
sail composer install
  • 运行 npm 命令
sail npm install

4. 改变服务

即使在创建项目后,您也可以通过修改 docker-compose.yml 文件(即 docker 配置文件)来更改服务。在这里,我们将更改 php 版本和使用的数据库。

更改 php 版本

首先检查当前php版本

sail php -v
php 8.3.12 (cli) (built: sep 27 2024 03:53:05) (nts)

接下来修改docker-compose.yml文件中描述的开发环境信息。

services:
    laravel.test:
        build:
            context: "./vendor/laravel/sail/runtimes/8.3"
            dockerfile: dockerfile
            args:
                wwwgroup: "${wwwgroup}"
        image: "sail-8.3/app"

将构建上下文和镜像更改为 8.1 .

services:
    laravel.test:
        build:
            context: "./vendor/laravel/sail/runtimes/8.1"
            dockerfile: dockerfile
            args:
                wwwgroup: "${wwwgroup}"
        image: "sail-8.1/app"

修改 docker-compose.yml 后,停止应用。

sail down

接下来,重建 docker 容器以反映更改。

sail build --no-cache

重新启动应用程序。

Q.AI视频生成工具
Q.AI视频生成工具

支持一分钟生成专业级短视频,多种生成方式,AI视频脚本,在线云编辑,画面自由替换,热门配音媲美真人音色,更多强大功能尽在QAI

下载
sail up -d

检查php版本是否有变化。

sail php -v
php 8.1.30 (cli) (built: sep 27 2024 04:07:29) (nts)

php 版本已从 php 8.3 更改为 php 8.1。

更改使用的数据库

将使用 mysql 创建的项目更改为 postgresql。

运行 sail 安装命令

sail php artisan sail:install

选择 pgsql

 ┌ which services would you like to install? ───────────────────┐
 │   ◼ mysql                                                  ┃ │
 │ › ◻ pgsql                                                  │ │
 │   ◻ mariadb                                                │ │
 │   ◻ redis                                                  │ │
 │   ◻ memcached                                              │ │
 └────────────────────────────────────────────────── 1 selected ┘
  use the space bar to select options.

检查 docker-compose.yml 文件并确认 pgsql 条目已添加。

services:
    laravel.test:
...
        depends_on:
            - mysql
            - redis
            - meilisearch
            - mailpit
            - selenium
            - pgsql
...
        pgsql:
            image: 'postgres:17'
            ports:
                - '${forward_db_port:-5432}:5432'
            environment:
                pgpassword: '${db_password:-secret}'
                postgres_db: '${db_database}'
                postgres_user: '${db_username}'
                postgres_password: '${db_password:-secret}'
            volumes:
                - 'sail-pgsql:/var/lib/postgresql/data'
                - './vendor/laravel/sail/database/pgsql/create-testing-database.sql:/docker-entrypoint-initdb.d/10-create-testing-database.sql'
            networks:
                - sail
            healthcheck:
                test:
                    - cmd
                    - pg_isready
                    - '-q'
                    - '-d'
                    - '${db_database}'
                    - '-u'
                    - '${db_username}'
                retries: 3
                timeout: 5s

ext,打开项目目录下的.env文件,确认设置了db_connection=pgsql和db_host=pgsql。
如果没有,请手动更改它们。

db_connection=pgsql
db_host=pgsql
db_port=5432
db_database=laravel
db_username=sail
db_password=******

确认 docker-compose.yml 和 .env 中的更改后,停止应用程序。

sail down

接下来,重建 docker 容器以反映更改。

sail build --no-cache

重新启动应用程序。

sail up -d

运行迁移文件。

sail artisan migrate

info  preparing database.

creating migration table ................................ 6.00ms done

info  running migrations.

0001_01_01_000000_create_users_table .................... 5.74ms done
0001_01_01_000001_create_cache_table .................... 1.45ms done
0001_01_01_000002_create_jobs_table ..................... 3.44ms done

在 docker 中启动 shell 并检查 pgsql

显示当前正在运行的 docker 容器的列表。

sail ps
name                                image                          command                  service
laravel-sail-setup-laravel.test-1   sail-8.3/app                   "start-container"        laravel.test
laravel-sail-setup-mailpit-1        axllent/mailpit:latest         "/mailpit"               mailpit

检查应用程序的容器名称并在 docker 内启动应用程序的 bash。

docker exec -it laravel-sail-setup-laravel.test-1 bash

连接到 pgsql。

psql -u sail -h pgsql laravel

系统将提示您输入密码,因此请输入 .env 文件中指定的 db_password。

password for user sail:******

检查pgsql中的表

laravel=# \dt
               List of relations
 Schema |         Name          | Type  | Owner
--------+-----------------------+-------+-------
 public | cache                 | table | sail
 public | cache_locks           | table | sail
 public | failed_jobs           | table | sail
 public | job_batches           | table | sail
 public | jobs                  | table | sail
 public | migrations            | table | sail
 public | password_reset_tokens | table | sail
 public | sessions              | table | sail
 public | users                 | table | sail
(9 rows)

这样,即使创建了项目,也可以从 mysql 更改为 postgresql。

结论

通过本文,您将了解如何使用 laravel sail 高效地设置和管理开发环境。通过根据项目的需求选择合适的服务并自定义设置,您可以实现更灵活、更强大的开发环境。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2643

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1634

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1513

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1418

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

65

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 800人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号