Error con ventana acoplable y reaccionar, digital envolvente rutinas::no compatible

0

Pregunta

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"
    ]
  }
}

docker node.js reactjs webpack
2021-11-24 04:43:15
2

Mejor respuesta

1

Cambiar su línea de

"start": "react-scripts start",

a

"start": "react-scripts --openssl-legacy-provider start"

Pero hay que ser conscientes de que OpenSSL implementaciones de los algoritmos que se han considerado legado. Más OpenSSl

2021-11-24 07:37:17
0

El paquete de actualización.json "inicio" de script para leer:

"start": "react-scripts --openssl-legacy-provider start"

Asegúrese de que la reconstrucción de la ventana acoplable de la imagen, de lo contrario obtendrá el mismo error.

docker build --pull --rm -f "Dockerfile" -t yourappname:latest "."
2021-12-08 21:53:56

En otros idiomas

Esta página está en otros idiomas

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Slovenský
..................................................................................................................