Как развернуть приложение responseJS на Heroku

Я пытаюсь развернуть приложение responseJS на heroku. Я разрабатываю на своей локальной машине. В моем файле package.json есть следующее:

"name": "sample-app",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
  "start": "webpack-dev-server --open"
}

При тестировании на моем локальном компьютере я набираю «npm start» из командной строки, и мой браузер открывается по адресу localhost: 8080, и мое приложение запускается.

Когда я развернул приложение в сервисе heroku и попытался запустить приложение, я получил ошибку приложения. Затем я посмотрел журналы и увидел следующее:

2018-09-06T13:37:57.697321+00:00 app[api]: Release v1 created by user [email protected]
2018-09-06T13:37:57.785389+00:00 app[api]: Enable Logplex by user [email protected]
2018-09-06T13:37:57.785389+00:00 app[api]: Release v2 created by user [email protected]
2018-09-06T13:38:40.000000+00:00 app[api]: Build started by user [email protected]
2018-09-06T13:37:57.697321+00:00 app[api]: Initial release by user [email protected]
2018-09-06T13:39:05.206635+00:00 app[api]: Scaled to web@1:Free by user [email protected]
2018-09-06T13:39:05.188008+00:00 app[api]: Release v3 created by user [email protected]
2018-09-06T13:39:05.188008+00:00 app[api]: Deploy 257b0e8b by user [email protected]
2018-09-06T13:39:08.000000+00:00 app[api]: Build succeeded
2018-09-06T13:39:10.243037+00:00 heroku[web.1]: Starting process with command `npm start`
2018-09-06T13:39:12.459230+00:00 app[web.1]:
2018-09-06T13:39:12.459251+00:00 app[web.1]: > [email protected] start /app
2018-09-06T13:39:12.459255+00:00 app[web.1]:
2018-09-06T13:39:12.459253+00:00 app[web.1]: > webpack-dev-server --open
2018-09-06T13:39:13.990393+00:00 app[web.1]: Project is running at http://localhost:8080/
2018-09-06T13:39:13.990876+00:00 app[web.1]: webpack output is served from /
2018-09-06T13:39:13.990913+00:00 app[web.1]: Content not from webpack is served from /app/public
2018-09-06T13:39:13.990975+00:00 app[web.1]: 404s will fallback to /index.html
2018-09-06T13:39:13.999552+00:00 app[web.1]: internal/child_process.js:323
2018-09-06T13:39:13.999556+00:00 app[web.1]: throw errnoException(err, 'spawn');
2018-09-06T13:39:13.999557+00:00 app[web.1]: ^
2018-09-06T13:39:13.999559+00:00 app[web.1]:
2018-09-06T13:39:13.999560+00:00 app[web.1]: Error: spawn EACCES
2018-09-06T13:39:13.999562+00:00 app[web.1]: at _errnoException (util.js:992:11)
2018-09-06T13:39:13.999564+00:00 app[web.1]: at ChildProcess.spawn (internal/child_process.js:323:11)
2018-09-06T13:39:13.999565+00:00 app[web.1]: at Object.exports.spawn (child_process.js:502:9)
2018-09-06T13:39:13.999567+00:00 app[web.1]: at module.exports (/app/node_modules/opn/index.js:76:26)
2018-09-06T13:39:13.999569+00:00 app[web.1]: at reportReadiness (/app/node_modules/webpack-dev-server/bin/webpack-dev-server.js:474:5)
2018-09-06T13:39:13.999571+00:00 app[web.1]: at Server.server.listen (/app/node_modules/webpack-dev-server/bin/webpack-dev-server.js:439:7)
2018-09-06T13:39:13.999572+00:00 app[web.1]: at Server.returnValue.listeningApp.listen (/app/node_modules/webpack-dev-server/lib/Server.js:615:10)
2018-09-06T13:39:13.999575+00:00 app[web.1]: at emitNone (events.js:106:13)
2018-09-06T13:39:13.999573+00:00 app[web.1]: at Object.onceWrapper (events.js:313:30)
2018-09-06T13:39:13.999576+00:00 app[web.1]: at Server.emit (events.js:208:7)
2018-09-06T13:39:14.008212+00:00 app[web.1]: npm ERR! code ELIFECYCLE
2018-09-06T13:39:14.008589+00:00 app[web.1]: npm ERR! errno 1
2018-09-06T13:39:14.009730+00:00 app[web.1]: npm ERR! [email protected] start: `webpack-dev-server --open`
2018-09-06T13:39:14.009893+00:00 app[web.1]: npm ERR! Exit status 1
2018-09-06T13:39:14.010124+00:00 app[web.1]: npm ERR!
2018-09-06T13:39:14.010297+00:00 app[web.1]: npm ERR! Failed at the [email protected] start script.
2018-09-06T13:39:14.010464+00:00 app[web.1]: npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
2018-09-06T13:39:14.050770+00:00 app[web.1]:
2018-09-06T13:39:14.051004+00:00 app[web.1]: npm ERR! A complete log of this run can be found in:
2018-09-06T13:39:14.051156+00:00 app[web.1]: npm ERR!     /app/.npm/_logs/2018-09-06T13_39_14_011Z-debug.log
2018-09-06T13:39:14.139768+00:00 heroku[web.1]: State changed from starting to crashed

Я почти уверен, что мне нужно изменить сценарий "start" на что-то другое, но я не знаю, на что мне это нужно изменить. Я думаю.

Любые идеи?

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Навигация по приложениям React: Исчерпывающее руководство по React Router
Навигация по приложениям React: Исчерпывающее руководство по React Router
React Router стала незаменимой библиотекой для создания одностраничных приложений с навигацией в React. В этой статье блога мы подробно рассмотрим...
Массив зависимостей в React
Массив зависимостей в React
Все о массиве Dependency и его связи с useEffect.
6
0
2 473
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Я погуглил вашу проблему Error: spawn EACCES и обнаружил, что другие сообщали о чем-то похожем при работе с Heroku.

Попробуйте добавить postinstall в свои сценарии, чтобы посмотреть, поможет ли это.

"name": "sample-app",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
  "start": "webpack-dev-server --open",
  "postinstall": "chmod -R +x node_modules/next/dist/bin/next-* && npm run build",
}

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

Теперь я получаю следующую ошибку. Я проверю исходный поток> [email protected] postinstall / tmp / build_4ea172a4adb229abc4dd3ce0a25b633a remote:> chmod -R + x node_modules / next / dist / bin / next- * && npm run build remote: remote: chmod: недоступен доступ ' node_modules / next / dist / bin / next- * ': Нет такого удаленного файла или каталога: npm ERR! код ELIFECYCLE remote: npm ERR! [email protected] после установки: chmod -R +x node_modules/next/dist/bin/next-* && npm run build удаленный: npm ERR! Ошибка при выполнении сценария постустановки [email protected].

Jonathan Small 06.09.2018 18:48

Ох, хорошо. Ошибка, вероятно, связана с тем, что сценарий postinstall ссылается на папку node_modules/next, которую вы, вероятно, не используете в своем проекте. Попробуйте заменить этот путь на что-то подходящее, что может вызывать у вас эту проблему.

rodiwa 06.09.2018 18:57

мне нужно указать на конкретный файл или любую папку в моем проекте? Кажется, нужно пройти через многое, просто чтобы развернуть приложение

Jonathan Small 06.09.2018 19:02
Ответ принят как подходящий

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

npm i -s express

Затем создайте файл server.js на верхнем уровне структуры вашего приложения.

Поместите этот код в файл server.js:

const express = require('express')
const app = express()
const path = require('path')
const port = process.env.PORT || 3001

app.use('/', express.static(path.join(__dirname, 'public')))

app.listen(port, () => console.info("Listening on Port", port)) 

По сути, это просто настраивает ваш сервер, а затем показывает ему, где найти страницу index.html, которую вы используете для загрузки своего реагирующего приложения, чтобы отправить его в браузер. Если ваша установка webpack выводит файл index.html в папку, отличную от «public», просто укажите имя этой папки там, где я поставил «public» после «__dirname».

Теперь вам просто нужно создать свое приложение.

Если вы используете webpack, это так же просто, как настроить скрипт сборки в вашем package.json:

"build": "webpack -p"

Затем убедитесь, что Heroku знает, как использовать вашу сборку с другим скриптом:

"heroku-postbuild": "npm run build"

Наконец, установите сценарий "start" для запуска вашего сервера (по умолчанию Heroku использует для этого имя start):

"start": node server.js

Итак, ваши скрипты package.json должны выглядеть так:

"scripts": {
    "dev-server": "webpack-dev-server --open"
    "start": "node server.js",
    "build": "webpack -p",
    "heroku-postbuild": "npm run build"
}

Теперь, если вы нажмете на Heroku, он должен работать без проблем.

Большое спасибо! Внес изменения, развернул и запустил. Большое спасибо!

Jonathan Small 07.09.2018 00:06

Не беспокойся, рад помочь

Kelly Barber 07.09.2018 16:34

После того, как возникла такая же проблема, я попробовал это, и это работает, но теперь я получаю эту ошибку /%PUBLIC_URL%/manifest.json 404 (Not Found) Any Ideas?

NormTheThird 25.03.2020 03:06

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