Laravel Homestead
简介
Laravel 致力于使整个 PHP 开发体验令人愉快,包括你的本地开发环境。Laravel Homestead 是一个官方的预打包 Vagrant 虚拟机,它为你提供了一个绝佳的开发环境,无需在本地机器上安装 PHP、Web 服务器或任何其他服务器软件。
Vagrant 提供了一种简单优雅的方式来管理和配置虚拟机。Vagrant 虚拟机是完全可丢弃的。如果出现问题,你可以几分钟内销毁并重新创建虚拟机!
Homestead 可以在任何 Windows、macOS 或 Linux 系统上运行,并包含 Nginx、PHP、MySQL、PostgreSQL、Redis、Memcached、Node 以及开发出色的 Laravel 应用程序所需的所有其他软件。
如果你使用的是 Windows,你可能需要启用硬件虚拟化 (VT-x)。通常可以通过你的 BIOS 启用它。如果你在 UEFI 系统上使用 Hyper-V,你可能还需要禁用 Hyper-V 才能访问 VT-x。
包含的软件
- Ubuntu 22.04
- Git
- PHP 8.3
- PHP 8.2
- PHP 8.1
- PHP 8.0
- PHP 7.4
- PHP 7.3
- PHP 7.2
- PHP 7.1
- PHP 7.0
- PHP 5.6
- Nginx
- MySQL 8.0
- lmm
- Sqlite3
- PostgreSQL 15
- Composer
- Docker
- Node (包含 Yarn、Bower、Grunt 和 Gulp)
- Redis
- Memcached
- Beanstalkd
- Mailpit
- avahi
- ngrok
- Xdebug
- XHProf / Tideways / XHGui
- wp-cli
可选软件
- Apache
- Blackfire
- Cassandra
- Chronograf
- CouchDB
- Crystal & Lucky Framework
- Elasticsearch
- EventStoreDB
- Flyway
- Gearman
- Go
- Grafana
- InfluxDB
- Logstash
- MariaDB
- Meilisearch
- MinIO
- MongoDB
- Neo4j
- Oh My Zsh
- OpenResty
- PM2
- Python
- R
- RabbitMQ
- Rust
- RVM (Ruby 版本管理器)
- Solr
- TimescaleDB
- Trader (PHP 扩展)
- Webdriver & Laravel Dusk 工具
安装和设置
第一步
在启动 Homestead 环境之前,你必须安装 Vagrant 以及以下受支持的提供程序之一
所有这些软件包都为所有流行的操作系统提供了易于使用的可视化安装程序。
要使用 Parallels 提供程序,你需要安装 Parallels Vagrant 插件。它是免费的。
安装 Homestead
你可以通过将 Homestead 代码库克隆到你的主机机器上来安装 Homestead。考虑将代码库克隆到你的“home”目录中的 `Homestead` 文件夹中,因为 Homestead 虚拟机将作为所有 Laravel 应用程序的主机。在本文档中,我们将此目录称为你的“Homestead 目录”。
git clone https://github.com/laravel/homestead.git ~/Homestead
克隆 Laravel Homestead 代码库后,你应该检出 `release` 分支。此分支始终包含 Homestead 的最新稳定版本。
cd ~/Homestead git checkout release
接下来,从 Homestead 目录执行 `bash init.sh` 命令以创建 `Homestead.yaml` 配置文件。在 `Homestead.yaml` 文件中,你将配置 Homestead 安装的所有设置。此文件将放置在 Homestead 目录中。
# macOS / Linux...bash init.sh # Windows...init.bat
配置 Homestead
设置你的提供程序
你 `Homestead.yaml` 文件中的 `provider` 键指示应使用哪个 Vagrant 提供程序:`virtualbox` 或 `parallels`。
provider: virtualbox
如果你使用的是 Apple Silicon,则需要 Parallels 提供程序。
配置共享文件夹
`Homestead.yaml` 文件的 `folders` 属性列出了你希望与 Homestead 环境共享的所有文件夹。随着这些文件夹中文件的更改,它们将保持在你的本地机器和 Homestead 虚拟环境之间的同步。你可以根据需要配置多个共享文件夹。
folders: - map: ~/code/project1 to: /home/vagrant/project1
Windows 用户不应使用 `~/` 路径语法,而应使用项目的完整路径,例如 `C:\Users\user\Code\project1`。
你应该始终将单个应用程序映射到它们自己的文件夹映射,而不是映射包含所有应用程序的单个大型目录。当你映射文件夹时,虚拟机必须跟踪文件夹中*每个*文件的全部磁盘 I/O。如果文件夹中有很多文件,你可能会遇到性能下降。
folders: - map: ~/code/project1 to: /home/vagrant/project1 - map: ~/code/project2 to: /home/vagrant/project2
使用 Homestead 时,你永远不应该挂载 `.`(当前目录)。这会导致 Vagrant 不将当前文件夹映射到 `/vagrant`,并且会破坏可选功能,并在配置过程中导致意外结果。
要启用 NFS,你可以在文件夹映射中添加 `type` 选项。
folders: - map: ~/code/project1 to: /home/vagrant/project1 type: "nfs"
在 Windows 上使用 NFS 时,你应该考虑安装 vagrant-winnfsd 插件。此插件将维护 Homestead 虚拟机中文件和目录的正确用户/组权限。
你还可以通过在 `options` 键下列出它们来传递 Vagrant 的 共享文件夹 支持的任何选项。
folders: - map: ~/code/project1 to: /home/vagrant/project1 type: "rsync" options: rsync__args: ["--verbose", "--archive", "--delete", "-zz"] rsync__exclude: ["node_modules"]
配置 Nginx 站点
不熟悉 Nginx?没问题。你的 `Homestead.yaml` 文件中的 `sites` 属性允许你轻松地将一个“域名”映射到 Homestead 环境中的一个文件夹。一个示例站点配置包含在 `Homestead.yaml` 文件中。同样,你可以根据需要向 Homestead 环境添加任意数量的站点。Homestead 可以作为你正在处理的每个 Laravel 应用程序的便捷虚拟化环境。
sites: - map: homestead.test to: /home/vagrant/project1/public
如果你在配置 Homestead 虚拟机后更改了 `sites` 属性,则应在终端中执行 `vagrant reload --provision` 命令来更新虚拟机上的 Nginx 配置。
Homestead 脚本尽可能地构建为幂等的。但是,如果在配置过程中遇到问题,则应通过执行 `vagrant destroy && vagrant up` 命令来销毁并重建机器。
主机名解析
Homestead 使用 `mDNS` 发布主机名以实现自动主机解析。如果在你的 `Homestead.yaml` 文件中设置 `hostname: homestead`,则主机可在 `homestead.local` 访问。macOS、iOS 和 Linux 桌面发行版默认包含 `mDNS` 支持。如果你使用的是 Windows,则必须安装 Bonjour Print Services for Windows。
自动主机名最适合用于 每个项目安装 Homestead。如果在一个 Homestead 实例上托管多个站点,则可以将网站的“域名”添加到机器的 `hosts` 文件中。`hosts` 文件将把对 Homestead 站点的请求重定向到你的 Homestead 虚拟机。在 macOS 和 Linux 上,此文件位于 `/etc/hosts`。在 Windows 上,它位于 `C:\Windows\System32\drivers\etc\hosts`。添加到此文件中的行如下所示:
192.168.56.56 homestead.test
确保列出的 IP 地址是你 `Homestead.yaml` 文件中设置的 IP 地址。将域名添加到 `hosts` 文件并启动 Vagrant 虚拟机后,你将能够通过 Web 浏览器访问该站点。
http://homestead.test
配置服务
Homestead 默认启动多个服务;但是,你可以在配置过程中自定义启用或禁用的服务。例如,你可以通过修改 `Homestead.yaml` 文件中的 `services` 选项来启用 PostgreSQL 并禁用 MySQL。
services: - enabled: - "postgresql" - disabled: - "mysql"
指定的服务将根据其在 `enabled` 和 `disabled` 指令中的顺序启动或停止。
启动 Vagrant 虚拟机
编辑完 `Homestead.yaml` 后,从你的 Homestead 目录运行 `vagrant up` 命令。Vagrant 将启动虚拟机并自动配置你的共享文件夹和 Nginx 站点。
要销毁机器,可以使用 `vagrant destroy` 命令。
每个项目的安装
与其全局安装 Homestead 并跨所有项目共享同一个 Homestead 虚拟机,不如为管理的每个项目配置一个 Homestead 实例。如果你希望将 `Vagrantfile` 与你的项目一起交付,则每个项目安装 Homestead 可能更有益,这允许其他人克隆项目的存储库后立即 `vagrant up`。
你可以使用 Composer 包管理器将 Homestead 安装到你的项目中。
composer require laravel/homestead --dev
安装 Homestead 后,调用 Homestead 的 `make` 命令来为你的项目生成 `Vagrantfile` 和 `Homestead.yaml` 文件。这些文件将放在项目的根目录中。`make` 命令将自动配置 `Homestead.yaml` 文件中的 `sites` 和 `folders` 指令。
# macOS / Linux...php vendor/bin/homestead make # Windows...vendor\\bin\\homestead make
接下来,在终端中运行 `vagrant up` 命令,并在浏览器中访问 `http://homestead.test` 中的项目。请记住,如果你不使用自动 主机名解析,则仍然需要为 `homestead.test` 或你选择的域名添加 `/etc/hosts` 文件条目。
安装可选功能
可选软件使用 `Homestead.yaml` 文件中的 `features` 选项安装。大多数功能可以使用布尔值启用或禁用,而某些功能允许多个配置选项。
features: - blackfire: server_id: "server_id" server_token: "server_value" client_id: "client_id" client_token: "client_value" - cassandra: true - chronograf: true - couchdb: true - crystal: true - dragonflydb: true - elasticsearch: version: 7.9.0 - eventstore: true version: 21.2.0 - flyway: true - gearman: true - golang: true - grafana: true - influxdb: true - logstash: true - mariadb: true - meilisearch: true - minio: true - mongodb: true - neo4j: true - ohmyzsh: true - openresty: true - pm2: true - python: true - r-base: true - rabbitmq: true - rustc: true - rvm: true - solr: true - timescaledb: true - trader: true - webdriver: true
Elasticsearch
你可以指定受支持的 Elasticsearch 版本,该版本必须是精确的版本号(主版本.次版本.修订版本)。默认安装将创建一个名为“homestead”的集群。你不应为 Elasticsearch 提供超过操作系统内存一半的内存,因此请确保你的 Homestead 虚拟机至少拥有 Elasticsearch 分配的两倍内存。
查看 Elasticsearch 文档,了解如何自定义你的配置。
MariaDB
启用 MariaDB 将删除 MySQL 并安装 MariaDB。MariaDB 通常充当 MySQL 的直接替换,因此你仍应在应用程序的数据库配置中使用 `mysql` 数据库驱动程序。
MongoDB
默认 MongoDB 安装将数据库用户名设置为 `homestead`,相应密码设置为 `secret`。
Neo4j
默认 Neo4j 安装将数据库用户名设置为 `homestead`,相应密码设置为 `secret`。要访问 Neo4j 浏览器,请通过 Web 浏览器访问 `http://homestead.test:7474`。端口 `7687` (Bolt)、`7474` (HTTP) 和 `7473` (HTTPS) 已准备好为来自 Neo4j 客户端的请求提供服务。
别名
你可以通过修改 Homestead 目录中的 `aliases` 文件来向 Homestead 虚拟机添加 Bash 别名。
alias c='clear'alias ..='cd ..'
更新 `aliases` 文件后,应使用 `vagrant reload --provision` 命令重新配置 Homestead 虚拟机。这将确保你的新别名在机器上可用。
更新 Homestead
在开始更新 Homestead 之前,应确保已通过在 Homestead 目录中运行以下命令删除当前虚拟机:
vagrant destroy
接下来,你需要更新 Homestead 源代码。如果你克隆了存储库,则可以在最初克隆存储库的位置执行以下命令:
git fetch git pull origin release
这些命令从 GitHub 存储库中提取最新的 Homestead 代码,获取最新的标签,然后检出最新的标记版本。你可以在 Homestead 的 GitHub 版本页面 上找到最新的稳定版本。
如果你通过项目的 `composer.json` 文件安装了 Homestead,则应确保你的 `composer.json` 文件包含 `"laravel/homestead": "^12"` 并更新你的依赖项。
composer update
接下来,应使用 `vagrant box update` 命令更新 Vagrant 虚拟机。
vagrant box update
更新 Vagrant 虚拟机后,应从 Homestead 目录运行 `bash init.sh` 命令以更新 Homestead 的附加配置文件。系统将询问你是否要覆盖现有的 `Homestead.yaml`、`after.sh` 和 `aliases` 文件。
# macOS / Linux...bash init.sh # Windows...init.bat
最后,你需要重新生成 Homestead 虚拟机以利用最新的 Vagrant 安装。
vagrant up
日常使用
通过 SSH 连接
你可以通过从 Homestead 目录执行 `vagrant ssh` 终端命令来 SSH 进入你的虚拟机。
添加其他站点
配置并运行 Homestead 环境后,你可能希望为其他 Laravel 项目添加其他 Nginx 站点。你可以在单个 Homestead 环境中运行任意数量的 Laravel 项目。要添加其他站点,请将站点添加到 `Homestead.yaml` 文件中。
sites: - map: homestead.test to: /home/vagrant/project1/public - map: another.test to: /home/vagrant/project2/public
在添加站点之前,应确保已为项目的目录配置了 文件夹映射。
如果 Vagrant 没有自动管理你的“hosts”文件,则可能需要将新站点添加到该文件中。在 macOS 和 Linux 上,此文件位于 `/etc/hosts`。在 Windows 上,它位于 `C:\Windows\System32\drivers\etc\hosts`
192.168.56.56 homestead.test192.168.56.56 another.test
添加站点后,从 Homestead 目录执行 `vagrant reload --provision` 终端命令。
站点类型
Homestead 支持多种“类型”的站点,这允许你轻松运行并非基于 Laravel 的项目。例如,我们可以使用 `statamic` 站点类型轻松地将 Statamic 应用程序添加到 Homestead。
sites: - map: statamic.test to: /home/vagrant/my-symfony-project/web type: "statamic"
可用的站点类型有:`apache`、`apache-proxy`、`apigility`、`expressive`、`laravel`(默认)、`proxy`(用于 nginx)、`silverstripe`、`statamic`、`symfony2`、`symfony4` 和 `zf`。
站点参数
你可以通过 `params` 站点指令向你的站点添加其他 Nginx `fastcgi_param` 值。
sites: - map: homestead.test to: /home/vagrant/project1/public params: - key: FOO value: BAR
环境变量
你可以通过将它们添加到 `Homestead.yaml` 文件来定义全局环境变量。
variables: - key: APP_ENV value: local - key: FOO value: bar
更新 `Homestead.yaml` 文件后,请务必通过执行 `vagrant reload --provision` 命令来重新配置机器。这将更新所有已安装 PHP 版本的 PHP-FPM 配置,并更新 `vagrant` 用户的环境。
端口
默认情况下,以下端口转发到你的 Homestead 环境:
- **HTTP:** 8000 → 转发到 80
- **HTTPS:** 44300 → 转发到 443
转发其他端口
如果需要,可以通过在 `Homestead.yaml` 文件中定义 `ports` 配置条目来将其他端口转发到 Vagrant 虚拟机。更新 `Homestead.yaml` 文件后,请务必通过执行 `vagrant reload --provision` 命令来重新配置机器。
ports: - send: 50000 to: 5000 - send: 7777 to: 777 protocol: udp
以下是可能希望从主机映射到 Vagrant 虚拟机的其他 Homestead 服务端口列表:
- **SSH:** 2222 → 到 22
- **ngrok UI:** 4040 → 到 4040
- **MySQL:** 33060 → 到 3306
- **PostgreSQL:** 54320 → 到 5432
- **MongoDB:** 27017 → 到 27017
- **Mailpit:** 8025 → 到 8025
- **Minio:** 9600 → 到 9600
PHP 版本
Homestead 支持在同一虚拟机上运行多个版本的 PHP。你可以在 `Homestead.yaml` 文件中为给定站点指定要使用的 PHP 版本。可用的 PHP 版本为:“5.6”、“7.0”、“7.1”、“7.2”、“7.3”、“7.4”、“8.0”、“8.1”、“8.2”和“8.3”(默认)。
sites: - map: homestead.test to: /home/vagrant/project1/public php: "7.1"
在你的 Homestead 虚拟机中,你可以通过 CLI 使用任何受支持的 PHP 版本。
php5.6 artisan listphp7.0 artisan listphp7.1 artisan listphp7.2 artisan listphp7.3 artisan listphp7.4 artisan listphp8.0 artisan listphp8.1 artisan listphp8.2 artisan listphp8.3 artisan list
你可以通过在 Homestead 虚拟机内发出以下命令来更改 CLI 使用的默认 PHP 版本:
php56php70php71php72php73php74php80php81php82php83
连接到数据库
开箱即用地为 MySQL 和 PostgreSQL 配置了 `homestead` 数据库。要从主机数据库客户端连接到 MySQL 或 PostgreSQL 数据库,应连接到端口 `33060` (MySQL) 或 `54320` (PostgreSQL) 上的 `127.0.0.1`。两个数据库的用户名和密码都是 `homestead` / `secret`。
只有在从主机连接到数据库时才应使用这些非标准端口。你将在 Laravel 应用程序的 `database` 配置文件中使用默认的 3306 和 5432 端口,因为 Laravel 运行在虚拟机 *内部*。
数据库备份
Homestead 可以在销毁 Homestead 虚拟机时自动备份你的数据库。要使用此功能,你必须使用 Vagrant 2.1.0 或更高版本。或者,如果你使用的是旧版本的 Vagrant,则必须安装 `vagrant-triggers` 插件。要启用自动数据库备份,请将以下行添加到 `Homestead.yaml` 文件中:
backup: true
配置后,执行 `vagrant destroy` 命令时,Homestead 将把你的数据库导出到 `.backup/mysql_backup` 和 `.backup/postgres_backup` 目录。这些目录可以在安装 Homestead 的文件夹中找到,或者如果你使用的是 每个项目安装 方法,则可以在项目的根目录中找到。
配置 Cron 计划任务
Laravel 通过调度每分钟运行一次的单个 `schedule:run` Artisan 命令提供了一种方便的方式来 安排 cron 作业。`schedule:run` 命令将检查在 `routes/console.php` 文件中定义的作业调度,以确定要运行哪些计划任务。
如果你希望为 Homestead 站点运行 `schedule:run` 命令,则可以在定义站点时将 `schedule` 选项设置为 `true`。
sites: - map: homestead.test to: /home/vagrant/project1/public schedule: true
站点的 cron 作业将定义在 Homestead 虚拟机的 `/etc/cron.d` 目录中。
配置 Mailpit
Mailpit 允许你拦截传出的电子邮件并检查它,而无需实际将其发送给收件人。要开始使用,请更新应用程序的 `.env` 文件以使用以下邮件设置:
MAIL_MAILER=smtpMAIL_HOST=localhostMAIL_PORT=1025MAIL_USERNAME=nullMAIL_PASSWORD=nullMAIL_ENCRYPTION=null
配置 Mailpit 后,你可以在 `https://127.0.0.1:8025` 访问 Mailpit 仪表板。
配置 Minio
Minio 是一个开源对象存储服务器,具有与 Amazon S3 兼容的 API。要安装 Minio,请在 功能 部分使用以下配置选项更新您的 Homestead.yaml
文件
minio: true
默认情况下,Minio 在 9600 端口可用。您可以通过访问 https://127.0.0.1:9600
来访问 Minio 控制面板。默认访问密钥是 homestead
,默认密钥是 secretkey
。访问 Minio 时,应始终使用 us-east-1
区域。
为了使用 Minio,请确保您的 .env
文件包含以下选项
AWS_USE_PATH_STYLE_ENDPOINT=trueAWS_ENDPOINT=https://127.0.0.1:9600AWS_ACCESS_KEY_ID=homesteadAWS_SECRET_ACCESS_KEY=secretkeyAWS_DEFAULT_REGION=us-east-1
要配置 Minio 支持的“S3”存储桶,请在您的 Homestead.yaml
文件中添加 buckets
指令。定义存储桶后,您应在终端中执行 vagrant reload --provision
命令
buckets: - name: your-bucket policy: public - name: your-private-bucket policy: none
支持的 policy
值包括:none
、download
、upload
和 public
。
Laravel Dusk
为了在 Homestead 中运行 Laravel Dusk 测试,您应该在 Homestead 配置中启用 webdriver
功能
features: - webdriver: true
启用 webdriver
功能后,您应在终端中执行 vagrant reload --provision
命令。
共享你的环境
有时您可能希望与同事或客户共享您当前正在处理的内容。Vagrant 通过 vagrant share
命令内置支持此功能;但是,如果您在 Homestead.yaml
文件中配置了多个站点,则此功能将不起作用。
为了解决这个问题,Homestead 包含它自己的 share
命令。要开始,请通过 vagrant ssh
SSH 连接到您的 Homestead 虚拟机 并执行 share homestead.test
命令。此命令将共享 Homestead.yaml
配置文件中的 homestead.test
站点。您可以将任何其他配置的站点替换为 homestead.test
share homestead.test
运行命令后,您将看到一个 Ngrok 屏幕出现,其中包含活动日志和共享站点的公共可访问 URL。如果您想指定自定义区域、子域名或其他 Ngrok 运行时选项,您可以将它们添加到 share
命令中
share homestead.test -region=eu -subdomain=laravel
如果您需要通过 HTTPS 而不是 HTTP 共享内容,则使用 sshare
命令代替 share
命令可以实现此目的。
请记住,Vagrant 本身是不安全的,运行 share
命令时,您会将虚拟机暴露在互联网上。
调试和性能分析
使用 Xdebug 调试 Web 请求
Homestead 支持使用 Xdebug 进行逐步调试。例如,您可以访问浏览器中的页面,PHP 将连接到您的 IDE,允许检查和修改正在运行的代码。
默认情况下,Xdebug 已经运行并准备接受连接。如果您需要在 CLI 上启用 Xdebug,请在您的 Homestead 虚拟机中执行 sudo phpenmod xdebug
命令。接下来,按照 IDE 的说明启用调试。最后,配置您的浏览器以使用扩展程序或 书签 触发 Xdebug。
Xdebug 会导致 PHP 运行速度明显变慢。要禁用 Xdebug,请在 Homestead 虚拟机中运行 sudo phpdismod xdebug
并重新启动 FPM 服务。
自动启动 Xdebug
调试向 Web 服务器发出请求的功能测试时,自动启动调试比修改测试以传递自定义标头或 Cookie 来触发调试更容易。要强制 Xdebug 自动启动,请修改 Homestead 虚拟机内的 /etc/php/7.x/fpm/conf.d/20-xdebug.ini
文件并添加以下配置
; If Homestead.yaml contains a different subnet for the IP address, this address may be different...xdebug.client_host = 192.168.10.1xdebug.mode = debugxdebug.start_with_request = yes
调试 CLI 应用
要调试 PHP CLI 应用程序,请在您的 Homestead 虚拟机中使用 xphp
shell 别名
xphp /path/to/script
使用 Blackfire 分析应用程序性能
Blackfire 是一款用于分析 Web 请求和 CLI 应用程序的服务。它提供了一个交互式用户界面,可在调用图和时间线中显示配置文件数据。它专为开发、暂存和生产环境而构建,对最终用户没有开销。此外,Blackfire 还提供代码和 php.ini
配置设置的性能、质量和安全检查。
Blackfire Player 是一款开源 Web 爬虫、Web 测试和 Web 抓取应用程序,可以与 Blackfire 协同工作以编写分析场景。
要启用 Blackfire,请在 Homestead 配置文件中使用“功能”设置
features: - blackfire: server_id: "server_id" server_token: "server_value" client_id: "client_id" client_token: "client_value"
Blackfire 服务器凭据和客户端凭据 需要 Blackfire 帐户。Blackfire 提供各种选项来分析应用程序,包括 CLI 工具和浏览器扩展。请 查看 Blackfire 文档以了解更多详细信息。
网络接口
Homestead.yaml
文件的 networks
属性配置 Homestead 虚拟机的网络接口。您可以根据需要配置多个接口
networks: - type: "private_network" ip: "192.168.10.20"
要启用 桥接 接口,请为网络配置 bridge
设置并将网络类型更改为 public_network
networks: - type: "public_network" ip: "192.168.10.20" bridge: "en1: Wi-Fi (AirPort)"
要启用 DHCP,只需从配置中删除 ip
选项
networks: - type: "public_network" bridge: "en1: Wi-Fi (AirPort)"
要更新网络使用的设备,您可以向网络的配置中添加 dev
选项。默认 dev
值为 eth0
networks: - type: "public_network" ip: "192.168.10.20" bridge: "en1: Wi-Fi (AirPort)" dev: "enp2s0"
扩展 Homestead
您可以使用 Homestead 目录根目录中的 after.sh
脚本扩展 Homestead。在此文件中,您可以添加任何必要的 shell 命令来正确配置和自定义您的虚拟机。
自定义 Homestead 时,Ubuntu 可能会询问您是否要保留软件包的原始配置或将其覆盖为新的配置文件。为避免这种情况,您应该在安装软件包时使用以下命令,以避免覆盖 Homestead 之前编写的任何配置
sudo apt-get -y \ -o Dpkg::Options::="--force-confdef" \ -o Dpkg::Options::="--force-confold" \ install package-name
用户自定义
在与您的团队一起使用 Homestead 时,您可能希望调整 Homestead 以更好地适应您的个人开发风格。为此,您可以在 Homestead 目录的根目录(包含 Homestead.yaml
文件的同一目录)中创建一个 user-customizations.sh
文件。在此文件中,您可以进行任何您想要的自定义;但是,user-customizations.sh
不应进行版本控制。
提供商特定设置
VirtualBox
natdnshostresolver
默认情况下,Homestead 将 natdnshostresolver
设置配置为 on
。这允许 Homestead 使用主机操作系统的 DNS 设置。如果您想覆盖此行为,请将以下配置选项添加到您的 Homestead.yaml
文件中
provider: virtualboxnatdnshostresolver: 'off'