Błąd z docker i react, są cyfrowego koperty: nie obsługiwany

0

Pytanie

Ukończyłem kurs dokerów, i instruktor udzielił startowy projekt z dość starym kodem react.

Ja докеризовал projekt react, oto prosty plik nudziarz z niego, co:

FROM node

WORKDIR /app

COPY package.json .

RUN npm i

COPY . .

EXPOSE 3000

CMD ["npm", "start"]

Następnie zbudowałem obraz:

docker build -t goals-react .

I uruchomił pojemnik w podłączonym trybie:

docker run --name goals-app --rm -p 3000:3000 goals-react

To wynik, który otrzymałem:

> [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

Założyłem, że jest to związane z tym, że w projekcie react używana starsza wersja react, więc zaktualizowałem plik package.json następującymi drużynami:

npx npm-check-updates -u
npm install

Następnie usunąłem i odtworzył obraz, a następnie uruchomił nowy pojemnik:

docker rmi goals-react
docker build -t goals-react .
docker run --name goals-app --rm -p 3000:3000 goals-react

Ale, ku mojemu zdziwieniu, otrzymałem ten sam błąd. Dlatego ja sprawdziłem to digital envelope routines::unsupported i znalazłem jeszcze jedną dyskusję na stackoverflow.

Wykonałem następujące polecenie:

export NODE_OPTIONS=--openssl-legacy-provider

Następnie przywrócił obraz i rozpoczęło pojemnik, ale bezskutecznie. Zdecydowałem się bardziej uważnie przeczytać komunikat o błędzie, i wygląda na to, że to błąd sieci web pakietu. Wszedłem na stronę webpack github i wiedziałem, że ktoś jeszcze miał ten sam problem, właśnie tutaj, jednak problem jest zamknięta. Są one również zalecane вышеприведенную polecenie, ale to oczywiście nie działa dla mnie.

Z góry dziękuję za wszelkie opinie i pomoc.

Edytować:

Jak i prosił @MikiBelavista, to plik package.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

Najlepsza odpowiedź

1

Zmień swoją linię

"start": "react-scripts start",

Dla

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

Ale należy pamiętać, że realizacja algorytmów OpenSSL, które zostały uznane za przestarzałe. Więcej OpenSSL

2021-11-24 07:37:17
0

Zaktualizuj skrypt package.json "uruchom" do czytania:

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

Upewnij się, że przebudowali obraz nudziarz z niego, co, w przeciwnym razie dostaniesz ten sam błąd.

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

W innych językach

Ta strona jest w innych językach

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