Estou usando o Homestead + Vagrant + Virtualbox em um Mac .
Problema
Embora eu tenha encontrado muitos tópicos / respostas sobre como corrigir tempos de resposta lentos (por exemplo, TTFB), nenhum deles funcionou. Meus tempos de resposta variam entre 25 e 32 segundos, o que obviamente não é aceitável para o desenvolvimento local.
Soluções sugeridas
Tentei várias soluções sugeridas aqui: https://github.com/laravel/homestead/issues/901
E também leu e tentou muitas sugestões desses tópicos:
- Respostas muito lentas em Homestead
- Vagrant Homestead lento
- carregamento lento e lento da página após 60 segundos da última solicitação
- Acelere a latência de sincronização entre host e convidado no Vagrant (pastas de sincronização NFS)
Mesmo tendo respostas aceitas, nenhuma delas me ajudou.
Desabilitando o xdebug
Posso dizer que desativar o xdebug como explicado aqui me ajudou a economizar 5 segundos.
Alterar o tamanho do disco
Embora alterar o tamanho do disco da VM de dinâmico para fixo, como sugerido aqui e explicado aqui , não ajudou em nada (o resultado foi ainda pior).
Usando NFS (sincronizar pastas) como sugerido aqui
Também a definição de N / homestead / vagrant não ajudou em nada.
Tentei (arquivo vagrant):
Vagrant.configure("2") do |config|
config.vm.synced_folder ".", "/vagrant", type: "nfs", mount_options:['nolock,vers=3,udp,noatime,actimeo=1']
end
Também tentei (homestead.yaml)
folders:
-
map: '/Users/myuser/PhpstormProjects/example.com'
to: /home/vagrant/code
type: "nfs"
options:
mount_options: ['nolock','vers=3','udp','noatime','actimeo=1']
O NFS estava funcionando nos dois casos, mas não mudou nada em relação ao TTFB no carregamento da página.
Definindo natdnshostresolver: off
Também tentei desativar o natdnshostresolver, como sugerido aqui. Isso não mudou nada.
Ajustando a imagem do Virtualbox
Claro que também tentei aumentar a RAM, CPUs, gráficos, etc., mas como você pode imaginar, não ajudou.
Quaisquer outras sugestões
A partir de agora, também estou aberto a tentar, por exemplo, manobrista ou quaisquer outras recomendações / soluções que você possa dar.
Muito obrigado antecipadamente!
Atualização 1
Alterar o nginx.conf na minha VM (depois que a @ totalidade sugeriu um tweak) ajudou um pouco. Por uma questão de completude e da possibilidade de haver ajustes ainda um pouco mais, aqui está toda a parte http do arquivo nginx.conf.
http {
##
# Basic Settings
##
sendfile on;
tcp_nopush on;
tcp_nodelay on;
# keepalive_timeout 65;
types_hash_max_size 2048;
# server_tokens off;
keepalive_disable none;
keepalive_requests 200;
keepalive_timeout 300s;
server_names_hash_bucket_size 64;
# server_name_in_redirect off;
include /etc/nginx/mime.types;
default_type application/octet-stream;
##
# SSL Settings
##
ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
ssl_prefer_server_ciphers on;
##
# Logging Settings
##
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
##
# Gzip Settings
##
gzip on;
# gzip_vary on;
# gzip_proxied any;
# gzip_comp_level 6;
# gzip_buffers 16 8k;
# gzip_http_version 1.1;
# gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
##
# Virtual Host Configs
##
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}
Atualização 2
Conteúdo de homestead.yaml:
ip: 192.168.10.14
memory: 4096
cpus: 2
provider: virtualbox
natdnshostresolver: off
authorize: ~/.ssh/id_rsa.pub
keys:
- ~/.ssh/id_rsa
folders:
-
map: '/Users/myUser/PhpstormProjects/exampleproject.com'
to: /home/vagrant/code
type: "nfs"
options:
mount_options: ['nolock','vers=3','udp','noatime','actimeo=1']
sites:
-
map: exampleproject.local
to: /home/vagrant/code
databases:
- homestead
features:
-
mariadb: false
-
ohmyzsh: false
-
webdriver: false
name: exampleproject
hostname: exampleproject
Conteúdo do Vagrantfile:
# -*- mode: ruby -*-
# vi: set ft=ruby :
require 'json'
require 'yaml'
VAGRANTFILE_API_VERSION ||= "2"
confDir = $confDir ||= File.expand_path("vendor/laravel/homestead", File.dirname(__FILE__))
homesteadYamlPath = File.expand_path("Homestead.yaml", File.dirname(__FILE__))
homesteadJsonPath = File.expand_path("Homestead.json", File.dirname(__FILE__))
afterScriptPath = "after.sh"
customizationScriptPath = "user-customizations.sh"
aliasesPath = "aliases"
require File.expand_path(confDir + '/scripts/homestead.rb')
Vagrant.require_version '>= 2.2.4'
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
if File.exist? aliasesPath then
config.vm.provision "file", source: aliasesPath, destination: "/tmp/bash_aliases"
config.vm.provision "shell" do |s|
s.inline = "awk '{ sub(\"\r$\", \"\"); print }' /tmp/bash_aliases > /home/vagrant/.bash_aliases"
end
end
if File.exist? homesteadYamlPath then
settings = YAML::load(File.read(homesteadYamlPath))
elsif File.exist? homesteadJsonPath then
settings = JSON::parse(File.read(homesteadJsonPath))
else
abort "Homestead settings file not found in " + File.dirname(__FILE__)
end
Homestead.configure(config, settings)
if File.exist? afterScriptPath then
config.vm.provision "shell", path: afterScriptPath, privileged: false, keep_color: true
end
if File.exist? customizationScriptPath then
config.vm.provision "shell", path: customizationScriptPath, privileged: false, keep_color: true
end
if Vagrant.has_plugin?('vagrant-hostsupdater')
config.hostsupdater.aliases = settings['sites'].map { |site| site['map'] }
elsif Vagrant.has_plugin?('vagrant-hostmanager')
config.hostmanager.enabled = true
config.hostmanager.manage_host = true
config.hostmanager.aliases = settings['sites'].map { |site| site['map'] }
end
end
vagrant plugin install vagrant-bindfs
e mantenha o mapeamentohomestead.yaml
fora do arquivo vagrant. Eu também sugiro destruir a VM e começar de novo.==> myproject: Bindfs seems to not be installed on the virtual machine, installing now myproject: Bindfs 1.13.7 is installed ==> myproject: Machine is ready to use bindfs! ==> myproject: Creating bind mounts after synced_folders... myproject: /home/vagrant/code => /home/vagrant/code
. Infelizmente, isso não resolveu o problema.Respostas:
Meus projetos do Laravel também são lentos, mas apenas ao usar o Postman, assumindo que ele é inicializado toda vez que faço uma solicitação que adiciona 10 a 15 segundos a cada solicitação. Minha solução foi ajustar as
Keep-Alive
configurações.Assumindo o que está acontecendo, ele abre uma nova conexão, realiza handshakes, transfere recursos, fecha a conexão e se repete para todos os recursos da sua página. Posso estar errado, mas tente abaixo e vamos ver. :)
Isso é apenas para desenvolvimento local, não sugiro isso para o ambiente de produção.
Apache
No topo:
Então reinicie o apache
nginx
No
http {}
bloco:Em seguida, reinicie o nginx
fonte
keepalive_timeout 65;
e adicionei suas linhas sugeridas. Reconheci uma ligeira diminuição de cerca de 3 segundos no TTFB, mas, em suma, ainda tenho 22-23 segundos (melhor caso) para um único carregamento de página. Parece que ajudou um pouco até agora. Talvez haja outros ajustes no nginx.conf que eu possa fazer, e é por isso que adicionarei a parte http do nginx.conf à minha pergunta. Valeu!Obrigado a todos vocês, mas achei uma solução bastante interessante ou melhor, um problema que eu tinha.
Eu estava usando o ambiente local para uma instalação do wordpress. Havia um arquivo chamado " object-cache.php " na pasta wp-content que usa o Memcached. O Memcached está instalado no homestead, mas parece ter uma configuração diferente do meu servidor ativo.
Isso faz com que os arquivos locais não sejam armazenados em cache adequadamente, o que resulta no código que extrai todas as opções disponíveis do banco de dados para cada solicitação.
Então, em suma, foi um grande problema de armazenamento em cache.
Remover o arquivo object-cache.php agora é minha solução (resultando em um TTFB de 1,23 segundos).
Apenas deixo isso aqui, caso alguém tenha um problema semelhante. Obrigado novamente por toda a ajuda e pensei que vocês colocaram nisso.
fonte
Uma vez eu tive um site conectando-se ao 'localhost' em vez de '127.0.0.1' no meu local para desenvolvimento, esse pequeno fato fez com que a pesquisa de DNS levasse séculos e até o GraphQL demorou 3 segundos para responder. Talvez seja algo semelhante do seu lado.
fonte
O Vagrant via VirtualBox na Catalina (MacMini, final de 2012 (pós-atualização dupla de SSD e 16 MB de RAM)) tem sido incrivelmente lento para mim, não se limitando a projetos PHP ou Javascript, embora seja nisso que eu esteja trabalhando principalmente. Eu passei um pouco de tempo pesquisando e a solução que funcionou para mim foi adicionar
/sbin/nfsd
eVirtualBox
paraFull Disk Access
emSettings->Privacy
no Mac, como descrito no link abaixo. Espero que isso ajude outra pessoa. No meu caso, o TTFB passou de cerca de 15 segundos para menos de 1. (Isso é muito bom para o Vagrant, ha!)https://github.com/hashicorp/vagrant/issues/10961#issuecomment-567430897
fonte
Para aqueles que executam o Homestead no macOS "High Sierra" ou posterior, a solução que funcionou para mim foi tão simples quanto alterar algumas configurações no arquivo homestead.rb .
Onde quer que você encontre no seu arquivo homestead.rb , as configurações para
settings['cpus'] ||= 1
alterá-losettings['cpus'] ||= 2
. Além disso, você pode aumentar o tamanho da memória (não o fiz) e definir o valor maior que o padrãosettings['memory'] ||= 2048
.Antes de experimentar quase todas as soluções encontradas na Web, desde garantir
nfs
foi definido, adicionar scripts e outras sugestões e nenhuma funcionou até eu aumentar as configurações de valor padrão da CPU para as configurações ['cpus'] || = 2No terminal, a tarefa simples de executar
npm run dev
ou qualquerphp artisan
comando levou cerca de 10 a 15 segundos até que o prompt estivesse livre para prosseguir com outros comandos.Com as alterações acima, agora leva apenas 2 a 3 segundos !
Espero que isso ajude qualquer pessoa com esse mesmo desempenho lento, especialmente no macOS. "High Sierra" ou posterior. Estou no macOS "Catalina" e tudo funciona bem agora.
fonte