Eu tenho matriculados em uma janela de encaixe do curso e o professor tem fornecido uma partida de projeto com algumas bastante antigas reagir código.
Eu dockerized a reagir projeto, aqui é o simples Dockerfile:
FROM node
WORKDIR /app
COPY package.json .
RUN npm i
COPY . .
EXPOSE 3000
CMD ["npm", "start"]
Aí, eu fiz a imagem:
docker build -t goals-react .
E correu para um recipiente anexadas modo:
docker run --name goals-app --rm -p 3000:3000 goals-react
Esta é a saída que eu recebi:
> [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
Achei que era porque a reagir projeto foi utilizar uma versão antiga de reagir, então eu atualizei o pacote.json arquivo com os seguintes comandos:
npx npm-check-updates -u
npm install
Então eu removida e recriada a imagem e, em seguida, correu para um novo recipiente:
docker rmi goals-react
docker build -t goals-react .
docker run --name goals-app --rm -p 3000:3000 goals-react
Mas, para minha surpresa, recebi o mesmo erro. Então, eu pesquisei digital envelope routines::unsupported
e eu encontrei ainda outra stackoverflow discussão.
Eu executei o seguinte comando:
export NODE_OPTIONS=--openssl-legacy-provider
Então eu reconstruiu a imagem e reiniciado o recipiente, mas sem sucesso. Eu decidi ler a mensagem de erro mais a fundo e parece ser um webpack erro. Eu fui para o webpack github página e percebi que alguém tinha o mesmo problema, aqui, no entanto, a questão está fechada. Eles também recomendado o comando acima, mas que, obviamente, não funciona para mim.
Agradecemos antecipadamente por qualquer feedback e ajuda.
Editar:
Conforme solicitado pelo @MikiBelavista, aqui está o pacote.json arquivo:
{
"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"
]
}
}