亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Docker、Symfony nginx/php-fpm 初始化非常慢

Docker、Symfony nginx/php-fpm 初始化非常慢

PHP
慕婉清6462132 2023-03-04 16:56:23
使用此項目/Docker 設置: https://gitlab.com/martinpham/symfony-5-docker當我這樣做時,docker-compose up -d我必須等待大約 2-3 分鐘才能真正讓它工作。在加載之前,它會給我“502 Bad Gateway”并記錄錯誤:2020/05/10 09:22:23 [error] 8#8: *1 connect() failed (111: Connection refused) while connecting to upstream, client: 172.28.0.1, server: localhost, request: "GET / HTTP/1.1", upstream: "fastcgi://172.28.0.3:9000", host: "localhost"為什么 nginx 或 php-fpm 或 smth else 加載這么慢?這是我第一次使用 nginx 和 Symfony。這是正常的嗎?我希望它最多在 1-2 秒內加載,而不是 2-3 分鐘。是的,我見過類似的問題,但沒有適合我的解決方案。應該更改一些 nginx/php-fpm/docker-compose 配置——我試過了,但沒有成功。我修改了一點nginx/sites/default.conf(只是添加了 xdebug 的東西)server {    listen 80 default_server;    #listen [::]:80 default_server ipv6only=on;    server_name localhost;    root /var/www/public;    index index.php index.html index.htm;    location / {         try_files $uri $uri/ /index.php$is_args$args;    }    location ~ \.php$ {        try_files $uri /index.php =404;        fastcgi_pass php-upstream;        fastcgi_index index.php;        fastcgi_buffers 4 256k;        fastcgi_buffer_size 128k;        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;        #!!!!fixes timeouts        fastcgi_read_timeout 600;        include fastcgi_params;        fastcgi_param PHP_VALUE "xdebug.remote_autostart=1        xdebug.idekey=PHPSTORM        xdebug.remote_enable=1        xdebug.remote_port=9001        xdebug.remote_host=192.168.0.12";    }    location ~ /\.ht {        deny all;    }    location /.well-known/acme-challenge/ {        root /var/www/letsencrypt/;        log_not_found off;    }}nginx/conf.d/default.conf:upstream php-upstream {    server php-fpm:9000;}
查看完整描述

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 在此處查看最適合您需求的選項。


查看完整回答
反對 回復 2023-03-04
  • 1 回答
  • 0 關注
  • 254 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號