1 回答

TA貢獻1864條經驗 獲得超2個贊
編輯:
我想我知道為什么現在您的項目需要很長時間才能開始。我仔細查看了 php-fpm 文件夾中的 Dockerfile,你有這個命令:
CMD composer install ; wait-for-it database:3306 -- bin/console doctrine:migrations:migrate ; php-fpm
如您所見,該命令將安裝所有 composer 依賴項,然后等待它可以連接到配置中定義的數據庫容器docker-compose.yml:
services:
database:
build:
context: ./database
environment:
- MYSQL_DATABASE=${DATABASE_NAME}
- MYSQL_USER=${DATABASE_USER}
- MYSQL_PASSWORD=${DATABASE_PASSWORD}
- MYSQL_ROOT_PASSWORD=${DATABASE_ROOT_PASSWORD}
ports:
- "3306:3306"
volumes:
- ./database/init.sql:/docker-entrypoint-initdb.d/init.sql
- ./database/data:/var/lib/mysql
一旦數據庫啟動并運行,它將運行遷移文件以src/src/Migrations更新數據庫,然后啟動 php-fpm。
在所有這些都完成之前,您的項目還沒有準備好,您將收到漂亮的“502 Bad Gateway”錯誤。
您可以通過運行來驗證這一點以及發生了什么,docker-compose up但-d這次省略參數,這樣您就不會在分離模式下運行,這將實時顯示所有容器日志。
你會看到一堆日志,包括與 composer 在后臺所做的相關的日志,例如:
api-app | - Installing ocramius/package-versions (1.8.0): Downloading (100%)
api-app | - Installing symfony/flex (v1.6.3): Downloading (100%)
api-app |
api-app | Prefetching 141 packages
api-app | - Downloading (100%)
api-app |
api-app | - Installing symfony/polyfill-php73 (v1.16.0): Loading from cache
api-app | - Installing symfony/polyfill-mbstring (v1.16.0): Loading from cache
Composer 安裝可能需要更多或更少的時間,具體取決于您是否緩存了所有存儲庫。
如果您想在開發過程中加快速度,這里的解決方案是composer install從 Dockerfile 中刪除命令,并僅在您想要更新/安裝新依賴項時手動運行它。這樣,您就可以避免composer install每次運行時都被運行docker-compose up -d。
要手動執行此操作,您需要連接到您的容器,然后composer install手動運行,或者如果您的操作系統中直接安裝了 composer,您只需導航到 src 文件夾并運行相同的命令。
這個+下面的技巧應該可以幫助你在本地有一個足夠快的項目。
我有一個類似的配置并且一切正常,docker-compose第一次運行該命令應該需要一些時間,因為需要構建圖像,但之后它甚至不需要一秒鐘就可以運行。
然而,據我所知,您安裝了很多可能會影響您的性能的卷。當我在 Mac 上使用 nginx 和 Symfony 運行測試時,一開始我的表現非常糟糕,頁面加載至少需要 30 秒。
在我的案例中,一種加快速度的解決方案是在我的某些卷上使用該:delegated選項來加快它們的訪問速度。
嘗試將該選項添加到您的卷中,看看它是否為您改變了什么:
[...]
volumes:
- ../src:/var/www:delegated
[...]
如果delegated這對您來說不是一個好的選擇,請閱讀更多關于其他選項的信息consistent,并cached 在此處查看最適合您需求的選項。
- 1 回答
- 0 關注
- 254 瀏覽
添加回答
舉報