Mac 下 Docker 執行較慢的原因分析及個人見解

FixBug發表於2020-03-12

在mac 使用 docker 的時候,我總感覺程式在 docker 下執行速度很慢,接下來我一一分析我遇到的問題,希望大家能進行合理的討論和建議。

問題:

  1. valet 下開啟 laravel 首頁耗時 60ms,docker 下開啟耗時 12s

  2. 在解決了第一個問題的前提下,docker 下仍舊耗時 2s

解決方法:

  1. 第一個問題排查過程中發現是 DNS Lookup 時間太長導致的,搜尋後發現,是因為使用了.local域名的原因,chrome 下就會存在解析時間過長,不過 safari 下沒有這個問題。解決方法就是別在本地使用 .local的虛擬域名。

    解決前:

    image-20200312182610066

    解決後:

    image-20200312182730690

    我們再來看一下 valet 下是什麼情況:

    image-20200312182845593

    我們發現 TTFB 竟然只有 21ms,而 docker 下竟然有1.8 秒。這差距巨大的,要知道,1 s = 1000ms。

  2. 在解決了第一個問題後我們發現了第二個問題,那麼我找到官網說的docker 的快取 :cached。我使用後,說實話,貌似毛用都沒有。哈哈。

    不過天無絕人之路,我突然想到,既然這個問題是因為 docker 掛載出的問題,那麼我能不能在本地使用valet來解析網站,然後其他的 es、kafka 等元件我放到 docker 中。

    嘗試後看看結果:

    image-20200312183358476

    大家可以看到我這裡使用的 valet 在本地解析網站後,連線的 docker 中的 es。ttfb 一下子就下來了。而我們再來看看 docker 下解析:

    image-20200312183518663

    其實差距還是蠻大的。

    我們再來對比數字,1780ms/60ms = 30 ,所以我們已經提速了 30 倍。

討論:

大家有沒有好的提速的建議?

本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章