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
以上が必要なのに、現状はnpm
は8.19.4
、node
は16.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