| git | 09555e5874bc4bc2c1cf735bf6047ff0c979bddd |
|---|
Warning
Laravel Homestead — устаревший пакет, который больше не поддерживается. Laravel Sail можно использовать в качестве современной альтернативы.
Laravel стремится сделать весь процесс разработки PHP приятным, включая вашу локальную среду разработки. Laravel Homestead - это официальный предварительно упакованный пакет Vagrant, который предоставляет вам прекрасную среду разработки, не требуя установки PHP, веб-сервера и любого другого серверного программного обеспечения на вашем локальном компьютере.
Vagrant предоставляет простой и элегантный способ управления виртуальными машинами и их подготовки. Vagrant-контейнеры полностью одноразовые. Если что-то пойдет не так, вы можете уничтожить и воссоздать контейнер за считанные минуты!
Homestead работает в любой системе Windows, macOS или Linux и включает Nginx, PHP, MySQL, PostgreSQL, Redis, Memcached, Node и все другое программное обеспечение, необходимое для разработки потрясающих приложений Laravel.
Warning
Если вы используете Windows, вам может потребоваться включить аппаратную виртуализацию (VT-x). Обычно его можно включить в BIOS. Если вы используете Hyper-V в системе UEFI, вам может дополнительно потребоваться отключить 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 (With Yarn, Bower, Grunt, and 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
- Open Resty
- PM2
- Python
- R
- RabbitMQ
- Rust
- RVM (Ruby Version Manager)
- Solr
- TimescaleDB
- Trader (PHP extension)
- Webdriver & Laravel Dusk Utilities
Перед запуском среды Homestead необходимо установить Vagrant, а также одного из следующих поддерживаемых провайдеров:
Все эти программные пакеты предоставляют простые в использовании визуальные установщики для всех популярных операционных систем.
Чтобы использовать провайдер Parallels, вам необходимо установить бесплатный плагин Parallels Vagrant.
Вы можете установить Homestead, клонировав репозиторий Homestead на свой компьютер. Рассмотрите возможность клонирования репозитория в папку Homestead в вашем домашнем каталоге, поскольку виртуальная машина Homestead будет служить хостом для всех ваших приложений Laravel. В этой документации мы будем называть этот каталог - «каталогом Homestead»:
git clone https://github.com/laravel/homestead.git ~/HomesteadПосле клонирования репозитория Laravel Homestead вы должны проверить ветку release. Эта ветка всегда содержит последний стабильный выпуск Homestead:
cd ~/Homestead
git checkout releaseЗатем выполните команду bash init.sh из каталога Homestead, чтобы создать файл конфигурации Homestead.yaml. Файл Homestead.yaml - это то место, где вы настраиваете все параметры установки Homestead. Этот файл будет помещен в каталог Homestead:
# macOS / Linux...
bash init.sh
# Windows...
init.batКлюч provider в файле Homestead.yaml указывает, какой провайдер Vagrant следует использовать: virtualbox или parallels:
provider: virtualbox
Warning
Если вы используете Apple Silicon, требуется провайдер Parallels.
Параметр folder файла Homestead.yaml перечисляет все директории, которыми вы хотите поделиться со своей виртуальной средой Homestead. При изменении файлов в этих папках они будут синхронизироваться между вашим локальным компьютером и средой Homestead. Вы можете настроить столько общих директорий, сколько необходимо:
folders:
- map: ~/code/project1
to: /home/vagrant/project1Warning
Пользователи Windows, при указании пути не должны использовать синтаксис ~/, а вместо этого должны указать полный путь к своему проекту от корня диска, например C:\Users\user\Code\project1.
Вы всегда должны сопоставлять каждое ваше приложение с его собственной отдельной директорией вместо назначения одного большого каталога, содержащего все ваши приложения. При назначении папки приложению виртуальная машина должна отслеживать все операции ввода-вывода на диске для каждого файла в папке. Поэтому у вас может снизиться производительность среды, если в папке много файлов:
folders:
- map: ~/code/project1
to: /home/vagrant/project1
- map: ~/code/project2
to: /home/vagrant/project2Warning
Вы никогда не должны монтировать . (текущий каталог) при использовании Homestead. Это приводит к тому, что Vagrant не отображает текущую папку в /vagrant, что нарушает работу дополнительных функций и приводит к неожиданным результатам при подготовке.
Чтобы включить NFS, вы можете добавить параметр type при сопоставлении папок:
folders:
- map: ~/code/project1
to: /home/vagrant/project1
type: "nfs"Warning
При использовании NFS в Windows вам следует рассмотреть возможность установки подключаемого модуля vagrant-winnfsd. Этот плагин будет поддерживать правильные разрешения пользователя / группы для файлов и каталогов на виртуальной машине Homestead.
Вы также можете передать любые параметры, поддерживаемые общими папками Vagrant, указав их под ключом options:
folders:
- map: ~/code/project1
to: /home/vagrant/project1
type: "rsync"
options:
rsync__args: ["--verbose", "--archive", "--delete", "-zz"]
rsync__exclude: ["node_modules"]Не знаком с Nginx? Нет проблем! Свойство sites файла Homestead.yaml позволяет легко сопоставить "домен" с папкой в среде Homestead. Пример конфигурации сайта включен в файл Homestead.yaml. Опять же, вы можете добавить столько сайтов в среду Homestead, сколько необходимо. Homestead может служить удобной виртуальной средой для каждого приложения Laravel, над которым вы работаете:
sites:
- map: homestead.test
to: /home/vagrant/project1/publicЕсли вы измените свойство sites после подготовки виртуальной машины Homestead, вы должны выполнить команду vagrant reload --provision в своем терминале, чтобы обновить конфигурацию Nginx на виртуальной машине.
Warning
Скрипты Homestead созданы максимально идемпотентными. Однако, если у вас возникли проблемы во время подготовки, вам следует удалить и повторно запустить виртуальную машину, выполнив команду vagrant destroy && vagrant up.
Homestead публикует имена хостов, используя mDNS для автоматического определения хостов. Если вы установите hostname: homestead в вашем файле Homestead.yaml, хост будет доступен по адресу homestead.local. Настольные дистрибутивы macOS, iOS и Linux по умолчанию включают поддержку mDNS. Если вы используете Windows, вы должны установить Bonjour Print Services для 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. После того как вы добавили домен в файл hosts и запустили Vagrant-контейнер, вы сможете получить доступ к сайту через свой веб-браузер:
http://homestead.testПо умолчанию Homestead запускает несколько сервисов; однако вы можете настроить, какие службы будут включены или отключены во время подготовки. Например, вы можете включить PostgreSQL и отключить MySQL, изменив параметр services в файле Homestead.yaml:
services:
- enabled:
- "postgresql"
- disabled:
- "mysql"Указанные службы будут запускаться или останавливаться в зависимости от их порядка в директивах enabledи disabled.
После того как вы отредактировали файл Homestead.yaml по своему вкусу, запустите команду vagrant up из каталога Homestead. Vagrant загрузит виртуальную машину и автоматически настроит ваши общие папки и сайты Nginx.
Чтобы удалить машину, вы можете использовать команду vagrant destroy.
Вместо того чтобы устанавливать Homestead глобально и использовать одну и ту же виртуальную машину Homestead для всех ваших проектов, вы можете настроить экземпляр Homestead для каждого проекта, которым вы управляете. Установка Homestead для каждого проекта может быть полезной, если вы хотите опубликовать Vagrantfile вместе с вашим проектом, позволяя другим, работающим над проектом, пользоваться проектом сразу после клонирования репозитория проекта.
Вы можете установить Homestead в свой проект с помощью диспетчера пакетов Composer:
composer require laravel/homestead --devКак только Homestead будет установлен, вызовите команду Homestead make, чтобы сгенерировать файлы Vagrantfile и Homestead.yaml для вашего проекта. Эти файлы будут помещены в корень проекта. Команда make автоматически настроит директивы sites и folder в файле Homestead.yaml:
# macOS / Linux...
php vendor/bin/homestead make
# Windows...
vendor\\bin\\homestead makeЗатем запустите команду vagrant up в вашем терминале и войдите в проект по адресу http://homestead.test в браузере. Помните, что вам все равно нужно будет добавить запись файла /etc/hosts для homestead.test или домена по вашему выбору, если вы не используете автоматическое определение имени хоста.
Дополнительное программное обеспечение устанавливается с помощью опции features в файле Homestead.yaml. Большинство функций можно включить или отключить с помощью логического значения, в то время как некоторые функции позволяют использовать несколько параметров конфигурации:
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, которая должна быть точным номером версии (major.minor.patch). При установке по умолчанию будет создан кластер с именем «homestead». Никогда не следует отдавать Elasticsearch больше половины памяти операционной системы, поэтому убедитесь, что на вашей виртуальной машине Homestead выделено как минимум вдвое больше памяти Elasticsearch.
Note
Ознакомьтесь с документацией Elasticsearch, чтобы узнать, как настроить свою конфигурацию.
Включение MariaDB удалит MySQL и установит MariaDB. MariaDB обычно служит заменой MySQL, поэтому вам все равно следует использовать драйвер базы данных mysql в конфигурации базы данных вашего приложения.
При установке MongoDB по умолчанию для имени пользователя базы данных будет установлено значение homestead, а для соответствующего пароля - secret.
При установке Neo4j по умолчанию для имени пользователя базы данных будет установлено значение homestead, а для соответствующего пароля - secret. Чтобы получить доступ к браузеру Neo4j, зайдите на сайт http://homestead.test:7474 в своем браузере. Порты 7687 (Bolt), 7474 (HTTP) и 7473 (HTTPS) готовы обслуживать запросы от клиента Neo4j.
Вы можете добавить псевдонимы Bash на свою виртуальную машину Homestead, изменив файл aliases в каталоге Homestead:
alias c='clear'
alias ..='cd ..'После обновления файла aliases вам следует повторно подготовить виртуальную машину Homestead с помощью команды vagrant reload --provision. Это обеспечит доступность ваших новых псевдонимов на машине.
Перед тем, как начать обновление Homestead, убедитесь, что вы удалили текущую виртуальную машину, выполнив следующую команду в каталоге Homestead:
vagrant destroyЗатем вам нужно обновить исходный код Homestead. Если вы клонировали репозиторий, вы можете выполнить следующие команды в том месте, где вы изначально клонировали репозиторий:
git fetch
git pull origin releaseЭти команды скачивают последний код Homestead из репозитория GitHub, извлекают теги, а затем проверяют выпуск с тегами. Вы можете найти последнюю стабильную версию выпуска Homestead на странице релизов GitHub.
Если вы установили Homestead через файл composer.json вашего проекта, вы должны убедиться, что файл composer.json содержит "laravel/homestead": "^12" и обновите ваши зависимости:
composer updateЗатем вы должны обновить поле Vagrant с помощью команды vagrant box update:
vagrant box updateПосле обновления Vagrant вы должны запустить команду bash init.sh из каталога Homestead, чтобы обновить дополнительные файлы конфигурации Homestead. Затем вас спросят, хотите ли вы перезаписать существующие файлы Homestead.yaml, after.sh и aliases:
# macOS / Linux...
bash init.sh
# Windows...
init.batНаконец, вам нужно будет обновить виртуальную машину Homestead, чтобы использовать последнюю установку Vagrant:
vagrant upВы можете подключиться к вашей виртуальной машине по SSH, выполнив команду терминала vagrant ssh из вашего каталога Homestead.
После того как ваша среда Homestead подготовлена и запущена, вы можете добавить дополнительные сайты Nginx для других ваших проектов Laravel. Вы можете запускать столько проектов Laravel, сколько хотите, в одной среде Homestead. Чтобы добавить дополнительный сайт, добавьте его в файл Homestead.yaml.
sites:
- map: homestead.test
to: /home/vagrant/project1/public
- map: another.test
to: /home/vagrant/project2/publicWarning
Перед добавлением сайта убедитесь, что вы настроили сопоставление папок для каталога проекта.
Если Vagrant не управляет вашим файлом «hosts» автоматически, вам может потребоваться также добавить новый сайт в этот файл. В macOS и Linux этот файл находится в /etc/hosts. В Windows он находится в C:\Windows\System32\drivers\etc\hosts:
192.168.56.56 homestead.test
192.168.56.56 another.test
После добавления сайта выполните команду терминала vagrant reload --provision из каталога Homestead.
Homestead поддерживает несколько «типов» сайтов, которые позволяют легко запускать проекты, не основанные на Laravel. Например, мы можем легко добавить приложение Statamic в Homestead, используя тип сайта statamic:
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, and zf.
Вы можете добавить дополнительные значения fastcgi_param Nginx на свой сайт с помощью директивы сайта params:
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-FPM для всех установленных версий PHP, а также обновит среду для пользователя vagrant.
По умолчанию в среду Homestead перенаправляются следующие порты:
- HTTP: 8000 → перенаправляется на 80
- HTTPS: 44300 → перенаправляется на 443
Вы можете перенаправить дополнительные порты в контейнер Vagrant, указав запись ports в конфигурационном файле Homestead.yaml. После обновления файла Homestead.yaml не забудьте повторно перезагрузить виртуальную машину, выполнив команду vagrant reload --provision:
ports:
- send: 50000
to: 5000
- send: 7777
to: 777
protocol: udpНиже приведен список дополнительных сервисных портов Homestead, которые вы, возможно, захотите перенаправить с вашего хост-компьютера на ваш Vagrant box:
- SSH: 2222 → To 22
- ngrok UI: 4040 → To 4040
- MySQL: 33060 → To 3306
- PostgreSQL: 54320 → To 5432
- MongoDB: 27017 → To 27017
- Mailpit: 8025 → To 8025
- Minio: 9600 → To 9600
Homestead поддерживает запуск нескольких версий PHP на одной виртуальной машине. Вы можете указать, какую версию PHP использовать для определенного сайта в файле Homestead.yaml. Доступные версии 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 вы можете использовать любую из поддерживаемых версий PHP через интерфейс командной строки:
php5.6 artisan list
php7.0 artisan list
php7.1 artisan list
php7.2 artisan list
php7.3 artisan list
php7.4 artisan list
php8.0 artisan list
php8.1 artisan list
php8.2 artisan list
php8.3 artisan listВы можете изменить версию PHP по умолчанию, используемую CLI, выполнив следующие команды на своей виртуальной машине Homestead:
php56
php70
php71
php72
php73
php74
php80
php81
php82
php83База данных homestead настраивается как для MySQL, так и для PostgreSQL из коробки. Чтобы подключиться к вашей базе данных MySQL или PostgreSQL из клиента вашего хост-компьютера, вы должны подключиться к 127.0.0.1 через порт 33060 (MySQL) или 54320 (PostgreSQL). Имя пользователя и пароль для обеих баз данных - homestead / secret.
Warning
Вы должны использовать эти нестандартные порты только при подключении к базам данных с вашего хост-компьютера. Вы будете использовать порты 3306 и 5432 по умолчанию в файле конфигурации вашего приложения Laravel database, поскольку Laravel работает внутри виртуальной машины.
Homestead может автоматически создавать резервную копию базы данных, когда ваша виртуальная машина Homestead будет удалена. Чтобы использовать эту функцию, вы должны использовать Vagrant 2.1.0 или выше. Или, если вы используете старую версию Vagrant, вы должны установить плагин vagrant-triggers. Чтобы включить автоматическое резервное копирование базы данных, добавьте следующую строку в ваш файл Homestead.yaml:
backup: trueПосле настройки Homestead будет экспортировать ваши базы данных в каталоги .backup/mysql_backup и .backup/postgres_backup при выполнении команды vagrant destroy. Эти каталоги можно найти в папке, в которую вы установили Homestead, или в корне вашего проекта, если вы использовали метод подготовка к установке.
Laravel предоставляет удобный способ запланировать задания cron, через выполнение Artisan-команды schedule: run каждую минуту. Команда schedule: run проверяет расписание заданий, записанные в файле routes/console.php, чтобы определить, какие запланированные задачи нужно выполнить.
Если вы хотите, чтобы команда schedule: run запускалась для сайта Homestead, вы можете установить для параметра schedule значение true при определении сайта:
sites:
- map: homestead.test
to: /home/vagrant/project1/public
schedule: trueЗадание cron для сайта будет записано в каталоге /etc/cron.d виртуальной машины Homestead.
Mailpit позволяет вам перехватывать исходящую электронную почту и проверять ее, не отправляя ее получателям. Для начала обновите файл .env вашего приложения, чтобы использовать следующие настройки почты:
MAIL_MAILER=smtp
MAIL_HOST=localhost
MAIL_PORT=1025
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=nullПосле настройки Mailpit вы можете получить доступ к панели управления Mailpit по адресу http://localhost:8025.
Minio - это сервер хранения объектов с открытым исходным кодом и API, совместимый с Amazon S3. Чтобы установить Minio, обновите файл Homestead.yaml, указав следующую опцию конфигурации в разделе features:
minio: true
По умолчанию Minio доступен через порт 9600. Вы можете получить доступ к панели управления Minio, посетив http://localhost:9600. Ключ доступа по умолчанию - homestead, а секретный ключ по умолчанию - secretkey. При доступе к Minio вы всегда должны использовать регион us-east-1.
Чтобы использовать Minio, убедитесь, что ваш файл .env имеет следующие параметры:
AWS_USE_PATH_STYLE_ENDPOINT=true
AWS_ENDPOINT=http://localhost:9600
AWS_ACCESS_KEY_ID=homestead
AWS_SECRET_ACCESS_KEY=secretkey
AWS_DEFAULT_REGION=us-east-1Чтобы подготовить контейнеры "S3" на базе Minio, добавьте директиву buckets в ваш файл Homestead.yaml. После определения контейнеров вы должны выполнить команду vagrant reload --provision в терминале:
buckets:
- name: your-bucket
policy: public
- name: your-private-bucket
policy: noneПоддерживаемые значения policy включают в себя: none, download, upload, and public.
Чтобы запустить тесты Laravel Dusk в Homestead, вы должны включить webdriver feature в вашей конфигурации Homestead:
features:
- webdriver: trueПосле включения функции webdriver вы должны выполнить команду vagrant reload --provision в терминале.
Иногда вы захотите поделиться тем, над чем сейчас работаете, с коллегами или клиентом. Vagrant имеет встроенную поддержку для этого с помощью команды vagrant share; однако это не сработает, если в файле Homestead.yaml настроено несколько сайтов.
Чтобы решить эту проблему, Homestead включает собственную команду share. Для начала подключитесь через SSH к вашей виртуальной машине Homestead через vagrant ssh и выполните команду share homestead.test. Эта команда предоставит общий доступ к сайту homestead.test из файла конфигурации Homestead.yaml. Вы можете заменить любой из других настроенных вами сайтов на homestead.test:
share homestead.testПосле выполнения команды вы увидите экран Ngrok, который содержит журнал активности и общедоступные URL-адреса для общего сайта. Если вы хотите указать настраиваемый регион, поддомен или другую опцию Ngrok, вы можете добавить их в команду share:
share homestead.test -region=eu -subdomain=laravelЕсли вам необходимо предоставить контент через HTTPS вместо HTTP, используйте команду sshare вместо share, и это позволит вам делать это.
Warning
Помните, что Vagrant по своей сути небезопасен, и вы открываете свою виртуальную машину для доступа из Интернета, выполняя команду share.
Homestead включает поддержку пошаговой отладки с использованием Xdebug. Например, вы можете получить доступ к странице в своем браузере, и PHP подключится к вашей среде IDE, чтобы разрешить проверку и изменение выполняемого кода.
По умолчанию Xdebug уже запущен и готов принимать подключения. Если вам нужно включить Xdebug в CLI, выполните команду sudo phpenmod xdebug на виртуальной машине Homestead. Затем следуйте инструкциям IDE, чтобы включить отладку. Наконец, настройте свой браузер для запуска Xdebug с расширением или букмарклетом.
Warning
Xdebug заставляет PHP работать значительно медленнее. Чтобы отключить Xdebug, запустите sudo phpdismod xdebug на виртуальной машине Homestead и перезапустите службу FPM.
При отладке функциональных тестов, которые отправляют запросы к веб-серверу, проще автоматически запускать отладку, чем изменять тесты для прохождения через настраиваемый заголовок или файл cookie для запуска отладки. Чтобы заставить Xdebug запускаться автоматически, измените файл /etc/php/7.x/fpm/conf.d/20-xdebug.ini внутри виртуальной машины Homestead и добавьте следующую конфигурацию:
; If Homestead.yaml contains a different subnet for the IP address, this address may be different...
xdebug.client_host = 192.168.10.1
xdebug.mode = debug
xdebug.start_with_request = yesЧтобы отладить CLI-приложение PHP, используйте псевдоним оболочки xphp внутри вашей виртуальной машины Homestead:
xphp /path/to/scriptBlackfire - это сервис для профилирования веб-запросов и CLI-приложений. Он предлагает интерактивный пользовательский интерфейс, который отображает данные профиля в виде графиков вызовов и временных шкал. Он создан для использования в разработке, тестировании и производстве без дополнительных затрат для конечных пользователей. Кроме того, Blackfire обеспечивает проверку производительности, качества и безопасности кода и параметров конфигурации php.ini.
Blackfire Player - это приложение с открытым исходным кодом для веб-сканирования, веб-тестирования и веб-скрапинга, которое может работать совместно с Blackfire для создания сценариев профилирования.
Чтобы включить Blackfire, используйте параметр "features" в файле конфигурации Homestead:
features:
- blackfire:
server_id: "server_id"
server_token: "server_value"
client_id: "client_id"
client_token: "client_value"Учетные данные сервера Blackfire и учетные данные клиента требуют наличие аккаунта Blackfire. Blackfire предлагает различные варианты профилирования приложения, включая инструмент командной строки и расширение браузера. Пожалуйста, просмотрите документацию Blackfire для получения более подробной информации.
Свойство networks файла Homestead.yaml настраивает сетевые интерфейсы для вашей виртуальной машины Homestead. Вы можете настроить столько интерфейсов, сколько необходимо:
networks:
- type: "private_network"
ip: "192.168.10.20"Чтобы включить мостовой (bridge) интерфейс, настройте параметр 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, используя сценарий after.sh в корне каталога Homestead. В этот файл вы можете добавить любые команды оболочки, которые необходимы для правильной настройки вашей виртуальной машины.
При настройке Homestead, Ubuntu может спросить вас, сохранять ли исходную конфигурацию пакета или перезаписать ее новым файлом конфигурации. Чтобы избежать этого, вы должны использовать следующую команду, чтобы избежать перезаписи любой конфигурации, ранее записанной Homestead:
sudo apt-get -y \
-o Dpkg::Options::="--force-confdef" \
-o Dpkg::Options::="--force-confold" \
install package-nameПри использовании Homestead вместе со своей командой вы можете настроить Homestead, чтобы он лучше соответствовал вашему личному стилю разработки. Для этого вы можете создать файл user-customizations.sh в корне каталога Homestead (тот же каталог, где находится ваш файл Homestead.yaml). В этом файле вы можете сделать любую настройку, какую захотите; однако файл user-customizations.sh должен быть добавлен в список игнорируемых, если вы пользуетесь системами контроля версий (VCS).
По умолчанию Homestead устанавливает для параметра natdnshostresolver значение on. Это позволяет Homestead использовать настройки DNS вашей операционной системы. Если вы хотите изменить это поведение, добавьте следующие параметры конфигурации в ваш файл Homestead.yaml:
provider: virtualbox
natdnshostresolver: 'off'