【问题标题】:Laravel sail endpoints take a long timeLaravel 帆端点需要很长时间
【发布时间】:2022-01-03 18:44:40
【问题描述】:

我有一个 api,我们更新到 laravel 8 以便能够使用 laravelsai,我的意思是把它放在 docker 中,但是当使用 api 端点时,当它在 docker 中启动时,它们平均需要 30 秒每个端点,我附上一张图片:

我还附上了我的 docker-compose 的配置:

# For more information: https://laravel.com/docs/sail
version: '3'
services:
    laravel.test:
        build:
            context: ./docker/7.4
            dockerfile: Dockerfile
            args:
                WWWGROUP: '${WWWGROUP}'
        image: sail-7.4/app
        extra_hosts:
            - 'host.docker.internal:host-gateway'
        ports:
            - '${APP_PORT:-80}:80'
        environment:
            WWWUSER: '${WWWUSER}'
            LARAVEL_SAIL: 1
            XDEBUG_MODE: '${SAIL_XDEBUG_MODE:-off}'
            XDEBUG_CONFIG: '${SAIL_XDEBUG_CONFIG:-client_host=host.docker.internal}'
        volumes:
            - '.:/var/www/html'
        networks:
            - sail
        depends_on:
            - mysql
            - redis
            - meilisearch
            - selenium
    mysql:
        image: 'mysql:8.0'
        ports:
            - '${FORWARD_DB_PORT:-3307}:3306'
        environment:
            MYSQL_ROOT_PASSWORD: '${DB_PASSWORD}'
            MYSQL_DATABASE: '${DB_DATABASE}'
            MYSQL_USER: '${DB_USERNAME}'
            MYSQL_PASSWORD: '${DB_PASSWORD}'
            MYSQL_ALLOW_EMPTY_PASSWORD: 'yes'
        volumes:
            - 'sailmysql:/var/lib/mysql'
        networks:
            - sail
        command:
           - --sort_buffer_size=1073741824
        healthcheck:
          test: ["CMD", "mysqladmin", "ping", "-p${DB_PASSWORD}"]
          retries: 3
          timeout: 5s
    redis:
        image: 'redis:alpine'
        ports:
            - '${FORWARD_REDIS_PORT:-6379}:6379'
        volumes:
            - 'sailredis:/data'
        networks:
            - sail
        healthcheck:
          test: ["CMD", "redis-cli", "ping"]
          retries: 3
          timeout: 5s
    meilisearch:
        image: 'getmeili/meilisearch:latest'
        ports:
            - '${FORWARD_MEILISEARCH_PORT:-7700}:7700'
        volumes:
            - 'sailmeilisearch:/data.ms'
        networks:
            - sail
        healthcheck:
          test: ["CMD", "wget", "--no-verbose", "--spider",  "http://localhost:7700/health"]
          retries: 3
          timeout: 5s
    mailhog:
        image: 'mailhog/mailhog:latest'
        ports:
            - '${FORWARD_MAILHOG_PORT:-1025}:1025'
            - '${FORWARD_MAILHOG_DASHBOARD_PORT:-8025}:8025'
        networks:
            - sail
    selenium:
       image: 'selenium/standalone-chrome'
       volumes:
            - '/dev/shm:/dev/shm'
       networks:
           - sail
networks:
    sail:
        driver: bridge
volumes:
    sailmysql:
        driver: local
    sailredis:
        driver: local
    sailmeilisearch:
        driver: local

使用的系统是拉拉维尔帆的窗户。

需要注意的是,当我在不提升docker的情况下使用api时,平均耗时不到5秒。 还要检查 docker 在 CPU 和 RAM 方面是否有某种限制,但它表明它已经分配了大约 12GB 和 4 个内核来使用。 如果有人知道问题可能出在哪里,那将对我有很大帮助。

问候和感谢!

【问题讨论】:

标签: laravel docker api laravel-sail


【解决方案1】:

最后我能够通过将项目放在 ubuntu 虚拟机的文件夹中来解决它,这使得 docker 读取文件的速度更快。

我从这些帖子中得到的信息:

Laravel 8 & Laravel Sail for dev on Windows 10 is slow. How to speed up?

Laravel Sail / Docker is slow

【讨论】:

    【解决方案2】:

    这很奇怪,因为我的工作正常,没有延迟。顺便说一句,这是我的docker-composer.yml 副本,试试看。虽然唯一的区别是我使用的是 PHP 8 而不是 PHP 7.4 但这应该不是问题。

    # For more information: https://laravel.com/docs/sail
    version: '3'
    services:
        laravel.test:
            build:
                context: ./docker/8.0
                dockerfile: Dockerfile
                args:
                    WWWGROUP: '${WWWGROUP}'
            image: sail-8.0/app
            ports:
                - '${APP_PORT:-80}:80'
            environment:
                WWWUSER: '${WWWUSER}'
                LARAVEL_SAIL: 1
            volumes:
                - '.:/var/www/html'
            networks:
                - sail
            depends_on:
                - mysql
                - redis
                - selenium
         mysql:
             image: 'mysql:8.0'
             ports:
                 - '${FORWARD_DB_PORT:-3306}:3306'
             environment:
                 MYSQL_ROOT_PASSWORD: '${DB_PASSWORD}'
                 MYSQL_DATABASE: '${DB_DATABASE}'
                 MYSQL_USER: '${DB_USERNAME}'
                 MYSQL_PASSWORD: '${DB_PASSWORD}'
                MYSQL_ALLOW_EMPTY_PASSWORD: 'yes'
            volumes:
                 - 'sailmysql:/var/lib/mysql'
            networks:
                - sail
             healthcheck:
               test: ["CMD", "mysqladmin", "ping"]
    
        redis:
            image: 'redis:alpine'
            ports:
                - '${FORWARD_REDIS_PORT:-6379}:6379'
            volumes:
                - 'sailredis:/data'
            networks:
                - sail
            healthcheck:
              test: ["CMD", "redis-cli", "ping"]
        meilisearch:
            image: 'getmeili/meilisearch:latest'
            ports:
                - '${FORWARD_MEILISEARCH_PORT:-7700}:7700'
            volumes:
                - 'sailmeilisearch:/data.ms'
            networks:
                - sail
        mailhog:
            image: 'mailhog/mailhog:latest'
            ports:
                - '${FORWARD_MAILHOG_PORT:-1025}:1025'
                - '${FORWARD_MAILHOG_DASHBOARD_PORT:-8025}:8025'
            networks:
                - sail
        selenium:
           image: 'selenium/standalone-chrome'
           volumes:
                - '/dev/shm:/dev/shm'
           networks:
               - sail
    networks:
        sail:
            driver: bridge
    volumes:
        sailmysql:
             driver: local
        sailredis:
            driver: local
        sailmeilisearch:
            driver: local
    

    【讨论】:

    • 当然,使用不同版本的php我认为不是问题,我在帖子中没有提到的是我在我的机器上使用Windows,你是否也使用Windows ?
    • 我实际上将 mac 和 windows 10 用于开发目的,我可以证明两者都工作正常。尝试检查您的窗口是否有更新,因为其中也包含一些修复程序并使用最新版本的 docker
    • 太奇怪了,我会继续寻找,看看我发现了什么,还是谢谢你
    • 不知道这是否会产生影响,但你试过我的docker-compose.yml吗?因为我也注意到有这样的变量XDEBUG_MODE: '${SAIL_XDEBUG_MODE:-off}' XDEBUG_CONFIG: '${SAIL_XDEBUG_CONFIG:-client_host=host.docker.internal}' 以防万一。 :)
    • 我要弹出它看看会发生什么,使用版本 8 以及 xdebug 的版本。谢谢你的贡献,我会告诉你会发生什么
    猜你喜欢
    • 1970-01-01
    • 2019-07-02
    • 2017-05-14
    • 2013-09-07
    • 2020-08-26
    • 2014-10-09
    • 2012-11-26
    • 2019-12-27
    • 2017-10-22
    相关资源
    最近更新 更多