在Mac OSX上使用laravel homestead/vagrant/virtualbox非常缓慢

10

我在Mac上使用Homestead + Vagrant + Virtualbox

问题

尽管我找到了很多关于如何解决响应速度慢的线程/答案(例如TTFB),但没有一个有效。我的响应时间在25-32秒之间,显然对于本地开发来说是不可接受的。

建议的解决方案

我尝试了很多这里提出的建议:https://github.com/laravel/homestead/issues/901

并且还阅读并尝试了许多这些线程中的建议:

尽管有采纳的答案,但是没有一个对我有帮助。

禁用xdebug

我可以说禁用xdebug像这里解释的那样,帮助我节省了5秒钟。

更改磁盘大小

虽然根据此处的建议将虚拟机的磁盘大小从动态更改为固定大小,并且按照此处所述进行操作(here),并按照这里的说明进行操作,没有任何帮助(结果甚至更糟)。

使用NFS(同步文件夹),如这里建议的

也将homestead / vagrant设置为NFS没有任何帮助。

尝试过以下内容(vagrant file):

Vagrant.configure("2") do |config|
  config.vm.synced_folder ".", "/vagrant", type: "nfs", mount_options:['nolock,vers=3,udp,noatime,actimeo=1']
end

也尝试过 (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']

NFS在这两种情况下都可以工作,但是对于页面加载的TTFB并没有改变任何事情。

关闭natdnshostresolver设置

我也尝试按照这里建议的关闭natdnshostresolver,但这并没有改变什么。

调整Virtualbox镜像

当然,我也尝试过增加RAM、CPU、图形等等,但是如你所料,这并没有帮助。

有其他建议吗

现在,我也愿意尝试例如valet或您提供的任何其他建议/解决方案。

非常感谢!

更新1

在@emotality建议改进后,修改了VM上的nginx.conf确实有所帮助。为了完整起见,以及可能还可以微调一些,这里是nginx.conf文件的整个http部分。

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/*;
}


更新2

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

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

使用nginx还是apache? - emotality
@emotality 感谢您的留言!这是 nginx/1.15.8 - wbq
已回答,不确定是否是问题,让我们看看?请告诉我 :) - emotality
尝试安装bindfs插件 vagrant plugin install vagrant-bindfs,并将映射保留在 homestead.yaml 文件中而非vagrant文件中。我还建议销毁虚拟机并重新开始。 - Razor
@dev_dari,你可以分享一下你的homestead.yaml文件(如果你进行了任何更改,也请附上Vagrantfile),以及你使用的homestead/vagrant/virtualbox版本号。尝试同步一个新的Laravel项目而不是你自己的,这样我们至少可以缩小问题范围。 - Razor
显示剩余4条评论
6个回答

4
感谢大家的帮助,但我发现了一个相当有趣的解决方案,或者说是我的问题。
我正在使用本地环境进行wordpress安装。在wp-content文件夹中有一个名为“object-cache.php”的文件,它使用Memcached。Memcached已经安装在Homestead中,但似乎与我的生产服务器配置不同。
这导致本地文件没有正确缓存,最终导致代码从数据库中拉取每个请求的所有可用选项。
总之,这是一个巨大的缓存问题。
现在移除object-cache.php文件是我的解决方案(结果是TTFB为1.23秒)。
如果有人遇到类似的问题,我在这里留下了这篇文章。再次感谢大家为此付出的所有帮助和思考。

3
我的Laravel项目在使用Postman时也很慢,每次请求时都需要启动,这会为每个请求增加10-15秒。我的解决方案是调整Keep-Alive设置。假设发生的情况是它打开一个新连接,进行握手、传输资源、关闭连接,并针对页面上的每个资源重复此过程。我可能错了,但请尝试以下操作并查看结果。:)

这仅适用于本地开发,不建议在生产环境中使用。


Apache

$ sudo nano /etc/apache2/httpd.conf

在顶部:

KeepAlive On
MaxKeepAliveRequests 200
KeepAliveTimeout 300

然后重新启动Apache


Nginx

$ sudo nano /etc/nginx/nginx.conf

http {}块中:

keepalive_disable none;
keepalive_requests 200;
keepalive_timeout 300s;

接着重新启动nginx


1
非常感谢您详细的回答。我登录了vagrant并使用nano编辑了nginx.conf文件。我注释掉了 keepalive_timeout 65; 并添加了您建议的行。我注意到TTFB大约减少了3秒,但总体上,单个页面加载仍需要22-23秒(最佳情况)。所以目前看来它确实有些帮助。也许在nginx.conf中还有其他调整,这就是为什么我会将nginx.conf的http部分添加到我的问题中。谢谢! - wbq
这真让我烦恼.. 你尝试过销毁虚拟机并重新开始吗? - emotality
是的,已经这样做了好几次。不过没有使用你的nginx更改。我会尝试这样做。 - wbq
再次感谢。我现在已经销毁了Vagrant并重新启动了它。重新执行了您建议的更改,并确保Bindfs(由@Razor建议)正在运行。不幸的是,仍然没有更好的结果。我猜这可能与文件数量(14242)有关? - wbq

0
我曾经有一个站点在本地开发时连接到'localhost'而不是'127.0.0.1',这个小事实导致DNS查找需要很长时间,甚至GraphQL响应需要3秒钟。也许你那边有类似的情况。

谢谢回复。我刚刚弄明白了,将在几分钟内发布我的结果。 - wbq

0
@wbq的答案是最好的。但它缺少了一个对我有效的东西。 我尝试了所有的方法:最新版本的Vagrant、Virtualbox、NFS文件夹、增加RAM等,检查代码(并没有在其他环境中出现这个问题)。每次发出请求都需要8-12秒钟。不多说了,这是我的解决方案:
在.env文件中:
CACHE_DRIVER=memcached

(使用 CACHE_DRIVER=array 代替)

https://laravel.com/docs/6.x/cache

10年前的信息:在PHP中使用Memcached和内部缓存有什么区别?


0
在Catalina(MacMini Late 2012(双SSD和16MB RAM)升级后),通过VirtualBox使用Vagrant对我来说非常缓慢,不仅限于PHP或Javascript项目,尽管这是我主要工作的内容。我花了一点时间进行研究,对我起作用的解决方案是将/sbin/nfsdVirtualBox添加到Mac上的设置->隐私中的完全磁盘访问,如下面的链接所述。我希望这能帮助其他人。在我的情况下,TTFB从大约15秒降至不到1秒。(对于Vagrant来说,这相当不错!)

just adding and enabling nfsd to the full disk access list should work

https://github.com/hashicorp/vagrant/issues/10961#issuecomment-567430897


1
这个答案实际上并没有像表面上那样有用,我不确定是否应该撤回它或者怎么办?我转而使用 Laravel Valet,它非常简单易用,但与生产环境有所不同,唉。 - Jeremy Anderson

-1

对于在macOS“High Sierra”或更高版本上运行Homestead的用户,对我有效的解决方案就是在homestead.rb文件中更改一些设置。

无论您在homestead.rb文件中找到什么,都要将settings['cpus'] ||= 1的设置更改为settings['cpus'] ||= 2。您还可以增加内存大小(我没有这样做),并将值设置为大于默认值settings['memory'] ||= 2048

之前,我几乎尝试了网上找到的所有解决方案,包括确保设置了nfs,添加脚本和其他建议,但都没有起作用,直到我将cpu默认值设置增加到settings['cpus'] ||=2

在终端中,运行npm run dev或任何php artisan命令的简单任务需要约10到15秒,直到提示符可以继续执行其他命令。

通过以上更改,现在只需要2到3秒

我希望这能帮助到任何在 macOS 上遇到类似缓慢性能问题的人,特别是在“High Sierra”或更高版本上。我现在使用的是 macOS“Catalina”,一切都正常了。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接