Mi sono iscritto a un mobile e il corso di istruttore ha fornito un progetto starter con alcuni piuttosto vecchio reagire codice.
Ho dockerized il progetto react, ecco la semplice Dockerfile:
FROM node
WORKDIR /app
COPY package.json .
RUN npm i
COPY . .
EXPOSE 3000
CMD ["npm", "start"]
Poi ho costruito l'immagine:
docker build -t goals-react .
E corse come un contenitore in allegato modalità:
docker run --name goals-app --rm -p 3000:3000 goals-react
Questo è l'output che ho ricevuto:
> [email protected] start
> react-scripts start
ℹ 「wds」: Project is running at http://172.17.0.4/
ℹ 「wds」: webpack output is served from
ℹ 「wds」: Content not from webpack is served from /app/public
ℹ 「wds」: 404s will fallback to /
Starting the development server...
Error: error:0308010C:digital envelope routines::unsupported
at new Hash (node:internal/crypto/hash:67:19)
at Object.createHash (node:crypto:130:10)
at module.exports (/app/node_modules/webpack/lib/util/createHash.js:135:53)
at NormalModule._initBuildHash (/app/node_modules/webpack/lib/NormalModule.js:417:16)
at handleParseError (/app/node_modules/webpack/lib/NormalModule.js:471:10)
at /app/node_modules/webpack/lib/NormalModule.js:503:5
at /app/node_modules/webpack/lib/NormalModule.js:358:12
at /app/node_modules/loader-runner/lib/LoaderRunner.js:373:3
at iterateNormalLoaders (/app/node_modules/loader-runner/lib/LoaderRunner.js:214:10)
at iterateNormalLoaders (/app/node_modules/loader-runner/lib/LoaderRunner.js:221:10)
/app/node_modules/react-scripts/scripts/start.js:19
throw err;
^
Error: error:0308010C:digital envelope routines::unsupported
at new Hash (node:internal/crypto/hash:67:19)
at Object.createHash (node:crypto:130:10)
at module.exports (/app/node_modules/webpack/lib/util/createHash.js:135:53)
at NormalModule._initBuildHash (/app/node_modules/webpack/lib/NormalModule.js:417:16)
at /app/node_modules/webpack/lib/NormalModule.js:452:10
at /app/node_modules/webpack/lib/NormalModule.js:323:13
at /app/node_modules/loader-runner/lib/LoaderRunner.js:367:11
at /app/node_modules/loader-runner/lib/LoaderRunner.js:233:18
at context.callback (/app/node_modules/loader-runner/lib/LoaderRunner.js:111:13)
at /app/node_modules/babel-loader/lib/index.js:59:103 {
opensslErrorStack: [ 'error:03000086:digital envelope routines::initialization error' ],
library: 'digital envelope routines',
reason: 'unsupported',
code: 'ERR_OSSL_EVP_UNSUPPORTED'
}
Node.js v17.1.0
Ho pensato che fosse perché il progetto react stava usando una vecchia versione di reagire, così ho aggiornato il pacchetto.json file con i seguenti comandi:
npx npm-check-updates -u
npm install
Quindi ho cancellato e ricreato l'immagine, e poi corse in un nuovo contenitore:
docker rmi goals-react
docker build -t goals-react .
docker run --name goals-app --rm -p 3000:3000 goals-react
Ma con mia grande sorpresa, ho ricevuto lo stesso errore. Così ho cercato su google digital envelope routines::unsupported
e ho trovato ancora un altro stackoverflow discussione.
Ho eseguito il seguente comando:
export NODE_OPTIONS=--openssl-legacy-provider
Poi ho ricostruito l'immagine e riavviato il contenitore, ma senza alcun risultato. Ho deciso di leggere il messaggio di errore più a fondo e sembra essere un webpack errore. Sono andato al webpack pagina di github, e mi resi conto che qualcun altro ha avuto lo stesso problema, proprio qui, tuttavia, la questione è chiusa. Hanno anche raccomandato il comando di cui sopra, ma che, ovviamente, non funziona per me.
Grazie in anticipo per tutte le risposte e l'aiuto.
Modifica:
Come richiesto da @MikiBelavista, qui è il pacchetto.file json:
{
"name": "frontend",
"version": "0.1.0",
"private": true,
"dependencies": {
"@testing-library/jest-dom": "^5.15.1",
"@testing-library/react": "^12.1.2",
"@testing-library/user-event": "^13.5.0",
"react": "^17.0.2",
"react-dom": "^17.0.2",
"react-scripts": "4.0.3"
},
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test",
"eject": "react-scripts eject"
},
"eslintConfig": {
"extends": "react-app"
},
"browserslist": {
"production": [
">0.2%",
"not dead",
"not op_mini all"
],
"development": [
"last 1 chrome version",
"last 1 firefox version",
"last 1 safari version"
]
}
}