Ошибка при отправке проекта node js в heroku

Я получаю эту ошибку, когда пытаюсь отправить свой проект на heroku. Бэкэнд написан на nodeJS, фронтенд - на React. Думаю, проблема в heroku-postbuild, потому что если я его удалю, push работает. Я искал его, но до сих пор не знаю, в чем причина. Кто-нибудь может мне помочь?

/tmp/build_7504975f08f330415cdefb27437cfad9/node_modules/.bin/node: 1: /tmp/build_7504975f08f330415cdefb27437cfad9/node_modules/.bin/node: MZ����@: not found
/tmp/build_7504975f08f330415cdefb27437cfad9/node_modules/.bin/node: 1: /tmp/build_7504975f08f330415cdefb27437cfad9/node_modules/.bin/node: Syntax error: word unexpected (expecting ")")
npm ERR! code ELIFECYCLE
npm ERR! errno 2
npm ERR! [email protected] heroku-postbuild: `cd client && npm install && npm run build`
npm ERR! Exit status 2
npm ERR! 
npm ERR! Failed at the [email protected] heroku-postbuild script.
npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
npm ERR! A complete log of this run can be found in:
npm ERR!     /tmp/npmcache.W89m8/_logs/2018-11-13T21_37_22_676Z-debug.log
-----> Build failed

       We're sorry this build is failing! You can troubleshoot common issues here:
       https://devcenter.heroku.com/articles/troubleshooting-node-deploys

       Some possible problems:

       - node_modules checked into source control
         https://blog.heroku.com/node-habits-2016#9-only-git-the-important-bits

       - Node version not specified in package.json
         https://devcenter.heroku.com/articles/nodejs-support#specifying-a-node-js-version

       Love,
       Heroku

 !     Push rejected, failed to compile Node.js app.
 !     Push failed

package.json (сервер)

    {
      "name": "project",
      "version": "1.0.0",
      "description": "",
      "main": "index.js",
      "scripts": {
        "start": "node server.js",
        "server": "nodemon server.js",
        "client-install": "npm install --prefix client",
        "client": "npm start --prefix client",
        "dev": "concurrently \"npm run server\" \"npm run client\"",
        "heroku-postbuild": "cd client && npm install && npm run build"
      },

      "author": "",
      "license": "ISC",
      "dependencies": {
        "concurrently": "^4.0.1",
        "express": "^4.16.4",
        "jsonwebtoken": "^8.3.0",
        "mongoose": "^5.3.4",
        "node": "^8.10.0",
        "nodemon": "^1.18.4",
        "passport": "^0.4.0",
        "passport-jwt": "^4.0.0",
        "react-scripts": "1.0.11",
      },
      "devDependencies": {
        "nodemon": "^1.18.4",
        "react-scripts": "1.0.11"
      }
    }

package.json (клиент)

{
      "name": "client",
      "version": "0.1.0",
      "private": true,
      "dependencies": {
        "parallelshell": "^3.0.2",
        "react-dom": "^16.5.2",
        "react-redux": "^5.0.7",
        "react-router": "^4.3.1",
        "react-router-dom": "^4.3.1",
        "react-router-redux": "^4.0.8",
        "react-scripts": "2.0.5",
        "socket.io-client": "^1.7.3",
      },
      "scripts": {
        "start": "parallelshell \"react-scripts start\" \"sass --watch src/styles/scss:src/styles/css --style compressed\"",
        "build": "react-scripts build",
        "test": "react-scripts test",
        "eject": "react-scripts eject",
        "sass": "sass --watch src/styles/scss:src/styles/css --style compressed",
        "sass-nw": "sass src/styles/scss:src/styles/css"
      },
      "proxy": "http://localhost:5000/",
    }

Почему вы делаете cd в клиентскую папку при постбилде?

Pedro Silva 13.11.2018 23:50

Потому что я хочу создать свое приложение для реагирования, которое находится в папке клиента. Это нормально?

Kasia1 14.11.2018 00:04

Я думаю, поскольку heroku не позволяет вам писать в их файловой системе, а вы строите на самом деле именно это. Это может быть источником ошибки

Zadiki Hassan Ochola 14.11.2018 14:07
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
3
825
1

Ответы 1

Я столкнулся с аналогичной ошибкой при устранении неполадок в проекте. Я решил это, используя предложения из подсказки.

       Some possible problems:

   - node_modules checked into source control
     https://blog.heroku.com/node-habits-2016#9-only-git-the-important-bits

   - Node version not specified in package.json
     https://devcenter.heroku.com/articles/nodejs-support#specifying-a-node-js-version

Так что попробуйте сделать "rm -rf node_modules" в корневом каталоге, если вы отметили node_modules в репозитории. Heroku установит node_modules в развернутую среду и не требует вашей зарегистрированной версии.

Другие вопросы по теме