kai_naka
@kai_naka (kai)

Are you sure you want to delete the question?

Leaving a resolved question undeleted may help others!

Segmentation faultが解決できない

解決したいこと

Laravel sailとReactで環境構築をしています。
環境構築中にエラーが発生しました。
解決方法を教えて下さい。

発生している問題・エラー

Segmentation fault

該当するソースコード

sail npm run dev

自分で試したこと

したこと

こちらを参考にしてdocker-compose.ymlを以下のように修正してsail build --no-cacheを実行
(★の一行だけ追加)

docker-compose.yml
services:
    laravel.test:
        build:
            context: ./vendor/laravel/sail/runtimes/8.2
            dockerfile: Dockerfile
            args:
                WWWGROUP: '${WWWGROUP}'
                NODE_VERSION: "16"  // ★
        image: sail-8.2/app
        extra_hosts:
            - 'host.docker.internal:host-gateway'
        ports:
            - '${APP_PORT:-80}:80'
            - '${VITE_PORT:-5173}:${VITE_PORT:-5173}'
        environment:
            WWWUSER: '${WWWUSER}'
            LARAVEL_SAIL: 1
            XDEBUG_MODE: '${SAIL_XDEBUG_MODE:-off}'
            XDEBUG_CONFIG: '${SAIL_XDEBUG_CONFIG:-client_host=host.docker.internal}'
            IGNITION_LOCAL_SITES_PATH: '${PWD}'
        volumes:
            - '.:/var/www/html'
        networks:
            - sail
        depends_on:
            - mysql
    mysql:
        image: 'mysql/mysql-server:8.0'
        ports:
            - '${FORWARD_DB_PORT:-3306}:3306'
        environment:
            MYSQL_ROOT_PASSWORD: '${DB_PASSWORD}'
            MYSQL_ROOT_HOST: '%'
            MYSQL_DATABASE: '${DB_DATABASE}'
            MYSQL_USER: '${DB_USERNAME}'
            MYSQL_PASSWORD: '${DB_PASSWORD}'
            MYSQL_ALLOW_EMPTY_PASSWORD: 1
        volumes:
            - 'sail-mysql:/var/lib/mysql'
            - './vendor/laravel/sail/database/mysql/create-testing-database.sh:/docker-entrypoint-initdb.d/10-create-testing-database.sh'
        networks:
            - sail
        healthcheck:
            test:
                - CMD
                - mysqladmin
                - ping
                - '-p${DB_PASSWORD}'
            retries: 3
            timeout: 5s
networks:
    sail:
        driver: bridge
volumes:
    sail-mysql:
        driver: local
結果(エラー文)
204.1 Preparing to unpack .../nodejs_16.20.2-1nodesource1_amd64.deb ...
204.1 Unpacking nodejs (16.20.2-1nodesource1) ...
209.0 Setting up nodejs (16.20.2-1nodesource1) ...
209.0 Processing triggers for man-db (2.10.2-1) ...
210.2 npm ERR! code EBADENGINE
210.2 npm ERR! engine Unsupported engine
210.2 npm ERR! engine Not compatible with your version of node/npm: npm@10.1.0
210.2 npm ERR! notsup Not compatible with your version of node/npm: npm@10.1.0
210.2 npm ERR! notsup Required: {"node":"^18.17.0 || >=20.5.0"}
210.2 npm ERR! notsup Actual:   {"npm":"8.19.4","node":"v16.20.2"}
210.2 
210.2 npm ERR! A complete log of this run can be found in:
210.2 npm ERR!     /root/.npm/_logs/2023-09-10T09_49_52_682Z-debug-0.log
------
failed to solve: process "/bin/sh -c apt-get update     && mkdir -p /etc/apt/keyrings     && apt-get install -y gnupg gosu curl ca-certificates zip unzip git supervisor sqlite3 libcap2-bin libpng-dev python2 dnsutils librsvg2-bin fswatch     && curl -sS 'https://keyserver.ubuntu.com/pks/lookup?op=get&search=0x14aa40ec0831756756d7f66c4f4ea0aae5267a6c' | gpg --dearmor | tee /etc/apt/keyrings/ppa_ondrej_php.gpg > /dev/null     && echo \"deb [signed-by=/etc/apt/keyrings/ppa_ondrej_php.gpg] https://ppa.launchpadcontent.net/ondrej/php/ubuntu jammy main\" > /etc/apt/sources.list.d/ppa_ondrej_php.list     && apt-get update     && apt-get install -y php8.2-cli php8.2-dev        php8.2-pgsql php8.2-sqlite3 php8.2-gd php8.2-imagick        php8.2-curl        php8.2-imap php8.2-mysql php8.2-mbstring        php8.2-xml php8.2-zip php8.2-bcmath php8.2-soap        php8.2-intl php8.2-readline        php8.2-ldap        php8.2-msgpack php8.2-igbinary php8.2-redis php8.2-swoole        php8.2-memcached php8.2-pcov php8.2-xdebug     && curl -sLS https://getcomposer.org/installer | php -- --install-dir=/usr/bin/ --filename=composer     && curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg     && echo \"deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_$NODE_VERSION.x nodistro main\" > /etc/apt/sources.list.d/nodesource.list     && apt-get update     && apt-get install -y nodejs     && npm install -g npm     && npm install -g pnpm     && curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | gpg --dearmor | tee /etc/apt/keyrings/yarn.gpg >/dev/null     && echo \"deb [signed-by=/etc/apt/keyrings/yarn.gpg] https://dl.yarnpkg.com/debian/ stable main\" > /etc/apt/sources.list.d/yarn.list     && curl -sS https://www.postgresql.org/media/keys/ACCC4CF8.asc | gpg --dearmor | tee /etc/apt/keyrings/pgdg.gpg >/dev/null     && echo \"deb [signed-by=/etc/apt/keyrings/pgdg.gpg] http://apt.postgresql.org/pub/repos/apt jammy-pgdg main\" > /etc/apt/sources.list.d/pgdg.list     && apt-get update     && apt-get install -y yarn     && apt-get install -y mysql-client     && apt-get install -y postgresql-client-$POSTGRES_VERSION     && apt-get -y autoremove     && apt-get clean     && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*" did not complete successfully: exit code: 1
自分の中での解釈

nodeのバージョンが18.17.0または20.5.0以上が必要なのに、現状はnpm8.19.4node16.20.2が入っている。

その後試したこと・確認したこと

以下のようにコンテナ内のnodeのバージョンを18.17.0にしてみる

sail root-shell
npm install -g n
n 18.17.0

nodeのバージョンを確認すると18.17.0になっている

sail node -v // v18.17.0

念の為sail npm run devしてみると同じエラー(Segmentation fault

その他

ちなみに、Laravelプロジェクトの作成方法は、以下のようにバージョン指定で作ってからsailを入れました。

composer create-project laravel/laravel:^8.0 example-app
cd example-app
composer require laravel/sail --dev
php artisan sail:install
alias sail='[ -f sail ] && bash sail || bash vendor/bin/sail'
sail up
sail composer require laravel/breeze --dev
sail php artisan breeze:install react
sail npm install
sail npm run dev  // ここでエラー

認識が合っていない部分などあるかもしれませんが、ご教示いただけますと幸いです。
よろしくお願いいたします。

0

1Answer

Your answer might help someone💌