Me he matriculado en una ventana acoplable curso y el instructor ha proporcionado un proyecto de arranque con algunos de los más antiguos de reaccionar código.
Yo dockerized el proyecto react, aquí está el simple Dockerfile:
FROM node
WORKDIR /app
COPY package.json .
RUN npm i
COPY . .
EXPOSE 3000
CMD ["npm", "start"]
A continuación, he construido la imagen:
docker build -t goals-react .
Y corrió un contenedor que se adjunta en la modalidad de:
docker run --name goals-app --rm -p 3000:3000 goals-react
Este es el resultado que he recibido:
> [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
Supuse que era debido a que el proyecto react estaba usando una versión antigua de reaccionar, así que he actualizado el paquete.json archivo con los comandos siguientes:
npx npm-check-updates -u
npm install
Luego se me quita y vuelve a crear la imagen, y luego corrió un nuevo contenedor:
docker rmi goals-react
docker build -t goals-react .
docker run --name goals-app --rm -p 3000:3000 goals-react
Pero para mi sorpresa he recibido el mismo error. Así que busqué en google digital envelope routines::unsupported
y me encontré con otro de stackoverflow discusión.
Ejecuté el siguiente comando:
export NODE_OPTIONS=--openssl-legacy-provider
A continuación, he reconstruido la imagen y se reinicia el contenedor, pero fue en vano. Me decidí a leer el mensaje de error más a fondo y parece ser un webpack de error. Fui a la webpack página de github y me di cuenta de que alguien tenía el mismo problema, a la derecha aquí, sin embargo, el tema está cerrado. También se recomienda el comando anterior, pero que, obviamente, no funciona para mí.
Gracias de antemano por cualquier comentario y ayuda.
Editar:
Según lo solicitado por @MikiBelavista, aquí está el paquete.archivo 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"
]
}
}