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

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

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

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

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Node.js

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

Q&A

解決済

1回答

13492閲覧

node.jsで、DB(MySQL)との接続がロストした際に再接続させたい

退会済みユーザー

退会済みユーザー

総合スコア0

Heroku

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

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Node.js

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

0グッド

0クリップ

投稿2016/09/12 10:06

###前提・実現したいこと

node.jsで、DB(MySQL)との接続がロストした際に再接続させたい

###発生している問題・エラーメッセージ

herokuを使用する際に、
仕様上定期的にDBとの接続が切れてしまうため
下記を参考に再接続する機能を実装しようとしています。
http://qiita.com/Riyaaaa_a/items/78308b29910054404102

どうやら接続自体はうまくいっている…?ようですが、
初回接続時には取得できているDBのデータが再接続以降うまく取得できません。

javascript

1var express = require('express'); 2var router = express.Router(); 3var connection = require('../mysqlConnection'); 4 5router.get('/', function(req, res, next) { 6 7 var query = '省略'; 8 connection.query(query, function(err, rows) { 9 if(err) console.log(err); 10 res.render('index', { 11 Rows: rows 12 }); 13 }); 14 15});
> Error: Cannot enqueue Query after fatal error.

###該当のソースコード

/app/mysqlConnection.js

javascript

1var mysql = require('mysql'); 2 3var connection; 4 5var get_SQL_Connection = function() { 6 7 connection = mysql.createConnection({ 8 host : 'xxxx', 9 user : 'xxxx', 10 password : 'xxxx', 11 database : 'xxxx' 12 }); 13 14 //接続時 15 connection.connect(function(err) { 16 if(err) { 17 console.log("SQL CONNECT ERROR >> " + err); 18 setTimeout(get_SQL_Connection, 2000); //接続失敗時リトライ 19 } else { 20 console.log("SQL CONNECT SUCCESSFUL."); 21 } 22 }); 23 24 //エラーのとき 25 connection.on('error', function(err) { 26 console.log("SQL CONNECTION ERROR >> " + err); 27 if(err.code === 'PROTOCOL_CONNECTION_LOST') { 28 console.log('=> RECONECT...'); 29 //再接続 30 get_SQL_Connection(); 31 } else { 32 throw err; 33 } 34 }); 35 36} 37 get_SQL_Connection(); 38 module.exports = connection;

###試したこと
勉強はじめたばかりで、どう対処したらよいのかさっぱり検討がつきません…。
すみませんが、ご教授よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

http://dev3104.hateblo.jp/entry/2016/04/07/235352

上記サイトを参考に、接続の方法を以下のように
「mysql.createConnection」から「mysql.createPool」へ変更したら解決致しました…。

javascript

1var mysql = require('mysql'); 2 3var pool = mysql.createPool({ 4 host : 'xxxx', 5 user : 'xxxx', 6 password : 'xxxx', 7 database : 'xxxx' 8}); 9 10module.exports = pool;

herokuで実行するときに発生したので
てっきりheroku絡みかと思い込んでしまったのがよくありませんでした…
そもそもnode-mysqlの話だったのですね。

お騒がせいたしました。

投稿2016/09/13 10:08

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問