環境)
・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アプリも起動するにはどのようにすればいいのか教えて下さい。
よろしくお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/11/08 18:11