javascript - tutorial - Error: No se puede encontrar el módulo npm ''momento''
node js tutorial pdf (3)
¿Puedes probar la instalación de meteor npm install
en la raíz de tu proyecto?
Si el momento no aparece en esa lista, ¿puedes probar la meteor npm install --save moment
? ¿ meteor npm install --save moment
?
De lo contrario, ¿podría publicar su paquete.js? Debería estar en la aplicación / programas / servidor /
Tengo una aplicación Meteor que funciona perfectamente en localhost, pero cuando la despliego a un servidor heroku
remoto, obtengo los siguientes errores.
(Estoy implementando esto )
¿Alguna idea de cómo solucionar esto, por favor?
2016-09-09T13:26:02.533532+00:00 heroku[web.1]: Starting process with command `.meteor/heroku_build/bin/node .meteor/heroku_build/app/main.js`
2016-09-09T13:26:06.806440+00:00 heroku[web.1]: Process exited with status 1
2016-09-09T13:26:06.813921+00:00 heroku[web.1]: State changed from starting to crashed
2016-09-09T13:26:06.704013+00:00 app[web.1]: /app/.meteor/heroku_build/app/programs/server/node_modules/fibers/future.js:280
2016-09-09T13:26:06.704027+00:00 app[web.1]: throw(ex);
2016-09-09T13:26:06.704028+00:00 app[web.1]: ^
2016-09-09T13:26:06.704029+00:00 app[web.1]:
2016-09-09T13:26:06.704030+00:00 app[web.1]: Error: Can''t find npm module ''moment''. Did you forget to call ''Npm.depends'' in package.js within the ''modules-runtime'' package?
2016-09-09T13:26:06.704031+00:00 app[web.1]: at Object.Npm.require (/app/.meteor/heroku_build/app/programs/server/boot.js:198:17)
2016-09-09T13:26:06.704032+00:00 app[web.1]: at options.fallback (packages/modules-runtime/modules-runtime.js:21:1)
2016-09-09T13:26:06.704032+00:00 app[web.1]: at require (packages/modules-runtime/.npm/package/node_modules/install/install.js:88:1)
2016-09-09T13:26:06.704033+00:00 app[web.1]: at meteorInstall.server.main.js (server/main.ts:1:19)
2016-09-09T13:26:06.704035+00:00 app[web.1]: at require (packages/modules-runtime/.npm/package/node_modules/install/install.js:82:1)
2016-09-09T13:26:06.704035+00:00 app[web.1]: at server/main.ts:65:4
2016-09-09T13:26:06.704036+00:00 app[web.1]: at /app/.meteor/heroku_build/app/programs/server/boot.js:292:10
2016-09-09T13:26:06.704036+00:00 app[web.1]: at Array.forEach (native)
Si me heroku run bash
para iniciar sesión en heroku. En /app/typings/globals
veo lo siguiente:
es6-collections es6-promise google-maps google.maps meteor moment
Esto parece coincidir con lo que está en el localhost de Windows:
Los momentos también existen en node_modules
Aquí está my node_modules/moment/package.js
:
var profile = {
resourceTags: {
ignore: function(filename, mid){
// only include moment/moment
return mid != "moment/moment";
},
amd: function(filename, mid){
return //.js$/.test(filename);
}
}
};
Mi package.json
:
{
"dependencies": {
"@angular/common": "^2.0.0-rc.4",
"@angular/compiler": "^2.0.0-rc.4",
"@angular/core": "^2.0.0-rc.4",
"@angular/forms": "^0.2.0",
"@angular/http": "^2.0.0-rc.4",
"@angular/platform-browser": "^2.0.0-rc.4",
"@angular/platform-browser-dynamic": "^2.0.0-rc.4",
"@ionic/cloud-angular": "^0.4.0",
"angular2-meteor": "^0.6.2",
"angular2-moment": "^0.8.2",
"es6-shim": "^0.35.0",
"ionic-angular": "^2.0.0-beta.11",
"ionic-native": "1.3.2",
"ionicons": "3.0.0",
"meteor-client-side": "^1.3.4",
"moment": "^2.14.1",
"reflect-metadata": "^0.1.3",
"rxjs": "5.0.0-beta.6",
"socket.io": "^1.4.8",
"zone.js": "^0.6.12"
},
fragmento de registros al implementar:
remote: -----> Building Meteor app with ROOT_URL: https://git.heroku.com/remote-thewhozoo.git
remote: server/collections.ts (1, 21): Cannot find module ''meteor/mongo''.
remote: server/collections.ts (2, 29): Cannot find module ''api/models''.
remote: server/methods.ts (1, 22): Cannot find module ''meteor/meteor''.
remote: server/methods.ts (2, 28): Cannot find module ''meteor/check''.
remote: server/main.ts (1, 25): Cannot find module ''moment''.
remote: server/main.ts (2, 22): Cannot find module ''meteor/meteor''.
remote:
remote: Unable to resolve some modules:
remote:
remote: "moment" in /tmp/build_29ec6195d953bd56c0670f7d9ee489a4/server/main.js
remote: (os.linux.x86_64)
remote:
remote: If you notice problems related to these missing modules, consider running:
remote:
remote: meteor npm install --save moment
remote:
remote: -----> Moving built slug to /tmp/build_29ec6195d953bd56c0670f7d9ee489a4/.meteor/heroku_build/app
remote: -----> Installing npm production dependencies on built slug
remote:
remote: > [email protected] install /tmp/build_29ec6195d953bd56c0670f7d9ee489a4/.meteor/heroku_build/app/programs/server/node_modules/fibers
remote: > node build.js || nodejs build.js
remote:
remote: `linux-x64-v8-4.5` exists; testing
remote: Binary is fine; exiting
remote:
remote: > [email protected] install /tmp/build_29ec6195d953bd56c0670f7d9ee489a4/.meteor/heroku_build/app/programs/server
remote: > node npm-rebuild.js
remote:
remote: {
remote: "meteor-dev-bundle": "0.0.0",
remote: "npm": "3.10.6",
remote: "ares": "1.10.1-DEV",
remote: "http_parser": "2.7.0",
remote: "icu": "56.1",
remote: "modules": "46",
remote: "node": "4.5.0",
remote: "openssl": "1.0.2h",
remote: "uv": "1.9.1",
remote: "v8": "4.5.103.37",
remote: "zlib": "1.2.8"
remote: }
index.d.ts
declare module ''moment'' {
var moment: moment.MomentStatic;
export = moment;
}
Tengo enlaces simbólicos en la raíz del proyecto de meteoritos:
ACTUALIZAR
He encontrado el problema, creo, pero todavía no estoy 100% seguro de cómo resolverlo.
El problema es que los enlaces simbólicos apuntan a directorios que existen localmente, pero no en el servidor remoto.
ACTUALIZAR
Elimino todos los enlaces simbólicos y, en su lugar, despliego los archivos y sigo teniendo el mismo error cuando el servidor intenta iniciar:
2016-09-11T15:23:06.155551+00:00 heroku[web.1]: State changed from crashed to starting
2016-09-11T15:23:09.146909+00:00 heroku[web.1]: Starting process with command `.meteor/heroku_build/bin/node .meteor/heroku_build/app/main.js`
2016-09-11T15:23:13.712742+00:00 heroku[web.1]: State changed from starting to crashed
2016-09-11T15:23:13.640003+00:00 app[web.1]: /app/.meteor/heroku_build/app/programs/server/node_modules/fibers/future.js:280
2016-09-11T15:23:13.640048+00:00 app[web.1]: throw(ex);
2016-09-11T15:23:13.640073+00:00 app[web.1]: ^
2016-09-11T15:23:13.640075+00:00 app[web.1]: Error: Can''t find npm module ''moment''. Did you forget to call ''Npm.depends'' in package.js within the ''modules-runtime'' package?
2016-09-11T15:23:13.640076+00:00 app[web.1]: at Object.Npm.require (/app/.meteor/heroku_build/app/programs/server/boot.js:198:17)
2016-09-11T15:23:13.640077+00:00 app[web.1]: at options.fallback (packages/modules-runtime/modules-runtime.js:21:1)
2016-09-11T15:23:13.640078+00:00 app[web.1]: at meteorInstall.server.main.js (server/main.ts:1:19)
2016-09-11T15:23:13.640079+00:00 app[web.1]: at require (packages/modules-runtime/.npm/package/node_modules/install/install.js:82:1)
2016-09-11T15:23:13.640079+00:00 app[web.1]: at server/main.ts:65:4
2016-09-11T15:23:13.723869+00:00 heroku[web.1]: Process exited with status 1
¿Alguna idea, por favor?
He corrido: meteor npm install --save
Lo he encontrado en boot.js
, pero no estoy seguro de lo que estaba haciendo el autor.
try {
return require(name);
} catch (e) {
// Try to guess the package name so we can print a nice
// error message
// fileInfo.path is a standard path, use files.pathSep
var filePathParts = fileInfo.path.split(files.pathSep);
var packageName = filePathParts[1].replace(//.js$/, '''');
// XXX better message
throw new Error(
"Can''t find npm module ''" + name +
"''. Did you forget to call ''Npm.depends'' in package.js " +
"within the ''" + packageName + "'' package?");
}
ACTUALIZAR
.gitignore
el .gitignore
de node_modules/
y no recibo ningún error ahora.
Sin embargo, soy nuevo en Meteor, así que no estoy seguro de cómo probar esto. Pero cuando intento invocar la aplicación con http://remote-thewhozoo.herokuapp.com/
o https://remote-thewhozoo.herokuapp.com/
recibo un error 404:
2016-09-11T16:20:15.183895+00:00 heroku[router]: at=info method=GET path="/sockjs/info?cb=jwgw2yuvgl" host=remote-thewhozoo.herokuapp.com request_id=a49fafb2-9708-46d2-8117-2c789bfa6a3e fwd="105.186.215.147" dyno=web.1 connect=1ms service=2ms status=404 bytes=132
Verifico la base de datos de Mongo, y tiene las colecciones creadas por mi aplicación. Entonces Meteor debe estar funcionando, simplemente no sé cómo acceder a él.
Alguna idea, por favor?
Asegúrese de que esta línea: "moment": "^2.14.1"
es su paquete.json luego ejecute npm install
Creo que es un problema con tu buildpack. Intente seguir esta guía - https://meteorcoder.wordpress.com/2016/09/24/how-to-deploy-meteor-apps-with-heroku/