質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
BotKit

BotKitは、Slack等のボットを作ることに特化したオープンソースのフレームワークです。JavaScriptで記述されており、 Node.js アプリケーションとして動作します。

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Slack

Slackは、Tiny Speckという企業からリリースされたコミュニケーションツールです。GoogleDriveやGitHubなど、さまざまな外部サービスと連携することができます。

Q&A

解決済

1回答

3385閲覧

Heroku上でnode.jsのBotKitが読み込めない

KanaSakaguchi

総合スコア52

BotKit

BotKitは、Slack等のボットを作ることに特化したオープンソースのフレームワークです。JavaScriptで記述されており、 Node.js アプリケーションとして動作します。

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Slack

Slackは、Tiny Speckという企業からリリースされたコミュニケーションツールです。GoogleDriveやGitHubなど、さまざまな外部サービスと連携することができます。

0グッド

0クリップ

投稿2016/06/08 13:39

###前提・実現したいこと
下記環境でSlackBOT(BOTアカウント)を運用したいと思っています。

  • Heroku - 無料枠
  • Node.js

node - v6.2.1
npm - 3.9.3

  • BotKit

###発生している問題・エラーメッセージ
いざデプロイしてもBOTアカウントがオンラインになりません。
ログを見てみるとどうやらBotKItが読み込めていないようです。

2016-06-08T13:00:30.976547+00:00 heroku[api]: Release v18 created by 私のアドレス 2016-06-08T13:00:31.153794+00:00 heroku[slug-compiler]: Slug compilation started 2016-06-08T13:00:31.153801+00:00 heroku[slug-compiler]: Slug compilation finished 2016-06-08T13:00:30.976444+00:00 heroku[api]: Deploy 4813df0 by 私のアドレス 2016-06-08T13:00:31.168497+00:00 heroku[worker.1]: State changed from crashed to starting 2016-06-08T13:00:32.145496+00:00 heroku[worker.1]: Starting process with command `node bot/bot.js` 2016-06-08T13:00:32.782072+00:00 heroku[worker.1]: State changed from starting to up 2016-06-08T13:00:33.887886+00:00 app[worker.1]: ^ 2016-06-08T13:00:33.887887+00:00 app[worker.1]: 2016-06-08T13:00:33.887873+00:00 app[worker.1]: module.js:440 2016-06-08T13:00:33.887883+00:00 app[worker.1]: throw err; 2016-06-08T13:00:33.887896+00:00 app[worker.1]: Error: Cannot find module 'botkit' 2016-06-08T13:00:33.887902+00:00 app[worker.1]: at Module.require (module.js:466:17) 2016-06-08T13:00:33.887902+00:00 app[worker.1]: at require (internal/module.js:20:19) 2016-06-08T13:00:33.887901+00:00 app[worker.1]: at Function.Module._resolveFilename (module.js:438:15) 2016-06-08T13:00:33.887901+00:00 app[worker.1]: at Function.Module._load (module.js:386:25) 2016-06-08T13:00:33.887903+00:00 app[worker.1]: at Module._compile (module.js:541:32) 2016-06-08T13:00:33.887903+00:00 app[worker.1]: at Object.Module._extensions..js (module.js:550:10) 2016-06-08T13:00:33.887904+00:00 app[worker.1]: at tryModuleLoad (module.js:415:12) 2016-06-08T13:00:33.887902+00:00 app[worker.1]: at Object.<anonymous> (/app/bot/bot.js:1:76) 2016-06-08T13:00:33.887904+00:00 app[worker.1]: at Function.Module._load (module.js:407:3) 2016-06-08T13:00:33.887903+00:00 app[worker.1]: at Module.load (module.js:456:32) 2016-06-08T13:00:34.666068+00:00 heroku[worker.1]: State changed from up to crashed 2016-06-08T13:00:34.667249+00:00 heroku[worker.1]: State changed from crashed to starting 2016-06-08T13:00:34.617961+00:00 heroku[worker.1]: Process exited with status 1 2016-06-08T13:00:35.784322+00:00 heroku[worker.1]: Starting process with command `node bot/bot.js` 2016-06-08T13:00:36.355478+00:00 heroku[worker.1]: State changed from starting to up 2016-06-08T13:00:37.752493+00:00 app[worker.1]: module.js:440 2016-06-08T13:00:37.752549+00:00 app[worker.1]: throw err; 2016-06-08T13:00:37.752556+00:00 app[worker.1]: Error: Cannot find module 'botkit' 2016-06-08T13:00:37.752551+00:00 app[worker.1]: ^ 2016-06-08T13:00:37.752556+00:00 app[worker.1]: 2016-06-08T13:00:37.752559+00:00 app[worker.1]: at require (internal/module.js:20:19) 2016-06-08T13:00:37.752560+00:00 app[worker.1]: at Module._compile (module.js:541:32) 2016-06-08T13:00:37.752558+00:00 app[worker.1]: at Module.require (module.js:466:17) 2016-06-08T13:00:37.752561+00:00 app[worker.1]: at Object.Module._extensions..js (module.js:550:10) 2016-06-08T13:00:37.752560+00:00 app[worker.1]: at Object.<anonymous> (/app/bot/bot.js:1:76) 2016-06-08T13:00:37.752558+00:00 app[worker.1]: at Function.Module._load (module.js:386:25) 2016-06-08T13:00:37.752557+00:00 app[worker.1]: at Function.Module._resolveFilename (module.js:438:15) 2016-06-08T13:00:37.752561+00:00 app[worker.1]: at Module.load (module.js:456:32) 2016-06-08T13:00:37.752562+00:00 app[worker.1]: at tryModuleLoad (module.js:415:12) 2016-06-08T13:00:37.752562+00:00 app[worker.1]: at Function.Module._load (module.js:407:3) 2016-06-08T13:00:38.445973+00:00 heroku[worker.1]: Process exited with status 1 2016-06-08T13:00:38.461509+00:00 heroku[worker.1]: State changed from up to crashed

###該当のソースコード
botkitの読み込みコードは次の通りです。

javascript

1var Botkit = require('botkit');

###試したこと
デプロイ前にローカルに同様の環境を用意して実行した時はうまくいきました。
Herokuのbashで実行した場合もデプロイ時同様のエラーでした。

~ $ node bot/bot.js module.js:440 throw err; ^ Error: Cannot find module 'botkit' at Function.Module._resolveFilename (module.js:438:15) at Function.Module._load (module.js:386:25) at Module.require (module.js:466:17) at require (internal/module.js:20:19) at Object.<anonymous> (/app/bot/bot.js:1:76) at Module._compile (module.js:541:32) at Object.Module._extensions..js (module.js:550:10) at Module.load (module.js:456:32) at tryModuleLoad (module.js:415:12) at Function.Module._load (module.js:407:3)

もともとはbot.jsとbotkitフォルダは両方ともappに配置していました。
Heroku上でうまくいかないので調べたところnode_modulesフォルダに入れると良いとあったので入れています。
bot.jsをbotフォルダに入れているのは、ルートに置くのをやめただけです。

###補足情報
ディレクトリ構造(botkit省略)

app ├── Procfile ├── bot │   └── bot.js ├── node_modules │   └── botkit └── package.json

Procfile

worker: node bot/bot.js

package.json

json

1{ 2 "engines": { 3 "node": "6.2.1" 4 }, 5 "scripts": { 6 "start": "node bot/bot.js" 7 } 8}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

依存するモジュールをそのままアプリケーションの中に含めるのはあまり良くないと思います。
nodeモジュールは npm install でインストールし、node_modulesは.gitignoreを用いてgitの管理下から除去してください。

みたところpackage.jsonに依存モジュールの項目がないのでそれが原因だと思います。ローカルの場合はdependenciesがなくてもnode_modulesを読みにいってくれますがherokuはデプロイ時にnode_modulesをクリアして再度npm installを走らせている可能性があります。

npm install botkit --saveとすると以下のようなセクションが追加されますので試してみてください。

json

1 "dependencies": { 2 "botkit": "^0.2.0" 3 }

投稿2016/06/08 17:54

nukosuke

総合スコア145

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

KanaSakaguchi

2016/06/09 04:07

依存モジュールを定義したらうまくいきました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問