前提
無料プランがあるPaaSのglitchで動いていたnodejsのものをrenderの無料プランのWeb Service
で動かすとデータが消えてしまう?戻る?現象があった。
再現方法を調べると
renderで、スリープになり再びアクセスしたときに復帰しその後、sqliteでローカルにデータ保存しているデータが消えるような状態になることがわかった。
ファイル自体が消えるのか確認する為に、小さな確認コードを書いてみた
確認コードや方法が間違ってるかもしれないが、消えるという結論にいたった。
(私の勘違いなどがあるかもしれないのでファイルが消えるという思いまでの経緯も書いてみた)
renderの無料の Web サービスの説明にもそういった制限事項は見つけられなかった
google検索したが、renderについてそういったことを書いているページを見つけられないので
そもそも最近PaaS?は、こういうものなのでしょうか?
データー保存は外部データベースが前提なんでしょうか?
実現したいこと
renderでファイルを保存する方法を知りたい。
発生している問題・エラーメッセージ
現象と確認コードからスリープから復帰時に、Deploy時のファイル状態に戻ると考えらえるが
スリープから復帰時にファイルがすべて再構築されるといったログには残っていない(仕様?)
復帰時のログ
Jan 13 04:52:43 PM ==> Starting service with 'yarn start' Jan 13 04:52:46 PM yarn run v1.22.5 Jan 13 04:52:46 PM warning package.json: No license field Jan 13 04:52:46 PM $ node server.js
該当のソースコード
ファイルが消えてしまうか確認の為に、コード作成しました。
node.js
1'use strict'; 2const http = require('http'); 3const port = process.env.PORT || 1337; 4const fs = require('fs'); 5const filepath = "./test.txt"; 6 7if (!fs.existsSync(filepath)) { 8 fs.writeFileSync(filepath, new Date().toLocaleTimeString(), 'utf8'); 9} 10 11http.createServer(function (req, res) { 12 res.writeHead(200, { 'Content-Type': 'text/plain; charset=utf-8'}); 13 fs.createReadStream(filepath, 'UTF-8').pipe(res); 14}).listen(port);
試したこと
上記のコードをrenderへDeploy後、このWebにアクセスして、時刻を表示させて、
15分経過でスリープ後に、再びアクセスすると時刻が更新されたことを確認。
また、スリープさせずに、アクセスすると同じ時刻を表示することを確認。
スリープ後、復帰したかどうかは、サーバーのログ(yarn startの記録)で確認。
補足情報(FW/ツールのバージョンなど)
回答1件
あなたの回答
tips
プレビュー