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

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

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

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

cron

cronは、Unix系OS上でデーモンプロセスとして動作する、スクリプトの自動実行が可能なジョブスケジューラです。

Node.js

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

Q&A

解決済

1回答

2093閲覧

nodejsアプリがサーバー再起動で自動起動がエラーとなる

kumakake

総合スコア42

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

cron

cronは、Unix系OS上でデーモンプロセスとして動作する、スクリプトの自動実行が可能なジョブスケジューラです。

Node.js

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

0グッド

0クリップ

投稿2021/11/06 08:52

環境)
・CentOS7
・$ node -v
v10.16.3
・expressを利用

目的)
サーバーを再起動させた際、nodeアプリも自動輝度をさせたい。

現状)
起動スクリプトとして下記を作成しています。
・/opt/devel/start.sh

#!/usr/bin/bash
cd /opt/devel/sapp
/usr/local/bin/forever start bin/www

・route/app.js
var get_dum = require('./routes/api/getDum');

・getDum.js

node

1$ cat routes/api/getDum.js 2var express = require('express'); 3var config = require('config'); 4 5var router = express.Router(); 6 7router.get('/', function(req, res, next) { 8 let strDbgTitle = '/api/getCsv'; 9 10 function getCsvLine() { 11 let strDbgTitle01 = strDbgTitle + '/getCsvLine'; 12 return new Promise( function( resolve, reject ) { 13 resolve(); 14 }) 15 }; 16 17 async function main() { 18 let ret = await getCsvLine(); 19 } 20 21 main().then( function( result ) { 22 console.log( "end" ); 23 }); 24}); 25 26module.exports = router;

・crontab設定
$ crontab -l
@reboot /opt/devel/start.sh

現象)
ホームディレクトリより
$ /opt/devel/start.sh
とすると、foreverで起動されます。

ところがサーバーを再起動させると forever list で確認をしたとき
uptimeが「STOPPED」となります。

foreverのログには下記のように出ています。
/opt/devel/sapp/routes/api/getDum.js:17
async function main() {
^^^^^^^^

SyntaxError: Unexpected token function
at createScript (vm.js:56:10)
at Object.runInThisContext (vm.js:97:10)
at Module._compile (module.js:549:28)
at Object.Module._extensions..js (module.js:586:10)
at Module.load (module.js:494:32)
at tryModuleLoad (module.js:453:12)
at Function.Module._load (module.js:445:3)
at Module.require (module.js:504:17)
at require (internal/module.js:20:19)
at Object.<anonymous> (/opt/devel/sapp/app.js:17:24)
error: Forever detected script exited with code: 1
error: Script restart attempt #1
/opt/devel/sapp/routes/api/getDum.js:17
async function main() {
^^^^^^^^

SyntaxError: Unexpected token function
at createScript (vm.js:56:10)
at Object.runInThisContext (vm.js:97:10)
at Module._compile (module.js:549:28)
at Object.Module._extensions..js (module.js:586:10)
at Module.load (module.js:494:32)
at tryModuleLoad (module.js:453:12)
at Function.Module._load (module.js:445:3)
at Module.require (module.js:504:17)
at require (internal/module.js:20:19)
at Object.<anonymous> (/opt/devel/sapp/app.js:17:24)
error: Forever detected script exited with code: 1

教えて下さい)
主導でスクリプトを起動するとnodeアプリも起動してくれるのですが、サーバーの再起動でcronから呼び出すと
上記のようにSyntax Errorとなってしまいます。
再起動でnodeアプリも起動するにはどのようにすればいいのか教えて下さい。

よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

手動実行時とcron実行時で、実行しているNode.jsのバージョンが違うのではないでしょうか?
forever start -cオプションで実行するコマンドを指定できるようなので、Node.jsのパスを指定してみてはいかがでしょうか?

foreversd/forever: A simple CLI tool for ensuring that a given script runs continuously (i.e. forever)

投稿2021/11/08 09:31

KAOsaka

総合スコア531

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

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

kumakake

2021/11/08 18:11

ありがとうございます! そのとおりで、/usr/bin/nodeがv6でした。 /usr/local/bin/forever start -c /usr/local/bin/node bin/www これで動作しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問