【问题标题】:Cannot deploy my reactjs webpack application on google app engine无法在谷歌应用引擎上部署我的 reactjs webpack 应用程序
【发布时间】:2017-05-27 15:36:34
【问题描述】:

我正在尝试部署我的反应应用程序,它是 100% 前端但在 webpack 服务器上运行。我需要将其作为灵活的环境部署到 Google 应用引擎,但在创建 gcloud app deploy 后出现此错误

sh: 1: webpack: not found
npm ERR! file sh
npm ERR! code ELIFECYCLE
npm ERR! errno ENOENT
npm ERR! syscall spawn
npm ERR! react-hot-boilerplate@1.0.0 bundle: `webpack --config webpack.config.js`
npm ERR! spawn ENOENT
npm ERR! 
npm ERR! Failed at the react-hot-boilerplate@1.0.0 bundle 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!     /root/.npm/_logs/2017-05-27T15_14_54_097Z-debug.log

npm ERR! Linux 3.16.0-4-amd64
npm ERR! argv "/nodejs/bin/node" "/nodejs/bin/npm" "start"
npm ERR! node v6.10.3
npm ERR! npm  v3.10.10
npm ERR! code ELIFECYCLE
npm ERR! react-hot-boilerplate@1.0.0 prestart: `npm run bundle`
npm ERR! Exit status 1
npm ERR! 
npm ERR! Failed at the react-hot-boilerplate@1.0.0 prestart script 'npm run bundle'.
npm ERR! Make sure you have the latest version of node.js and npm installed.
npm ERR! If you do, this is most likely a problem with the react-hot-boilerplate package,
npm ERR! not with npm itself.
npm ERR! Tell the author that this fails on your system:
npm ERR!     npm run bundle
npm ERR! You can get information on how to open an issue for this project with:
npm ERR!     npm bugs react-hot-boilerplate
npm ERR! Or if that isn't available, you can get their info via:
npm ERR!     npm owner ls react-hot-boilerplate
npm ERR! There is likely additional logging output above.

npm ERR! Please include the following file with any support request:
npm ERR!     /app/npm-debug.log

我已关注this tutorial 并且所有依赖项都已安装。 不幸的是,我无法让它工作。

这是我目前的情况

server.js

 var webpack = require('webpack');
var WebpackDevServer = require('webpack-dev-server');
var config = require('./webpack.config');

new WebpackDevServer(webpack(config), {
  publicPath: config.output.publicPath,
  hot: true,
  historyApiFallback: true
}).listen(3000, 'localhost', function (err, result) {
  if (err) {
    return console.log(err);
  }

  console.log('Listening at http://localhost:3000/');
}); 

webpack.config.js

'use strict';

var path = require('path');
var webpack = require('webpack');
var env = process.env.NODE_ENV

module.exports = {
  devtool: 'eval',
  entry: [
    'whatwg-fetch',
    'webpack-dev-server/client?http://localhost:3000',
    'webpack/hot/dev-server',
    'babel-polyfill',
    './app/index'
  ],
  output: {
    path: path.join(__dirname, 'dist'),
    filename: 'bundle.js',
    library: 'Redux',
    libraryTarget: 'umd',
    publicPath: '/static/'
  },
  plugins: [
   new webpack.optimize.OccurrenceOrderPlugin(),
    new webpack.HotModuleReplacementPlugin()

  ],
  module: {
    loaders: [
      {  test: /\.js$/,
        loaders: ['babel-loader'], exclude: /node_modules/,
        include: path.join(__dirname, 'app')
      },

      {
            test: /\.json$/,
            loader: 'json'
        },

    {test: /\.scss$/, loader: "style-loader!raw-loader!sass-loader?includePaths[]=" + path.resolve(__dirname, "./node_modules/compass-mixins/lib") + "&includePaths[]=" + path.resolve(__dirname, "./mixins/app_mixins")},
  /*  { test: /\.scss$/, loaders: ['style', 'css', 'sass?includePaths[]=' + path.resolve(__dirname, './node_modules/compass-mixins/lib','raw']}, */
     { test: /\.css$/, loader: "style-loader!css-loader" },
     //{ test: /\.json$/, loader: 'json-loader' },
     { test: /\.(jpe?g|png|gif|svg)$/i,loader:'file'},
     {test: /\.(woff|woff2|ttf|eot)$/, loader: 'file'},
     { test: /\.(png|woff|woff2|eot|ttf|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,loader: 'url' }



  ]
  },
  node: {
    fs: 'empty',
    net: 'empty',
    tls: 'empty'
  },

devtool: 'source-map'
};

package.json

"scripts": {
    "start": "node server.js",
    "bundle": "webpack --config webpack.config.js",
    "prestart": "npm run bundle",
    "lint": "eslint src"
  },

我做错了什么。

感谢您的帮助

【问题讨论】:

    标签: node.js reactjs google-app-engine webpack gcloud


    【解决方案1】:

    您需要更改脚本。在 App Engine 中全局安装 Webpack 不是最好的方法,直接从 node_modules 使用。

    首先,确保 webpack 在你的生产依赖中:

    npm install --save webpack
    

    编辑您的package.json 脚本:

    "scripts": {
        "start": "node server.js",
        "bundle": "./node_modules/.bin/webpack --config webpack.config.js",
        "prestart": "npm run bundle"
    },
    

    现在一个简单的npm install 在干净的安装中就足以捆绑你的应用程序了。

    【讨论】:

      【解决方案2】:

      您能否在package.json 文件中显示您的依赖关系?

      我在运行 gcloud app deploy 时遇到了类似的问题

      Error: Cannot find module 'webpack-dev-server'
      at Function.Module._resolveFilename (module.js:469:15)
      

      我解决了将 package.json 中的给定依赖项(wepack-dev-server)从 devDependencies 移动到 dependencies 的问题。

      如果其他人有同样的问题,我建议查看 package.json 中的 dependenciesdependencies 需要运行,devDependencies 仅用于开发,例如:单元测试、Coffeescript 到 Javascript 的转译、缩小,

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2020-11-18
        • 2020-11-21
        • 1970-01-01
        • 2017-09-04
        • 2012-04-04
        相关资源
        最近更新 更多