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

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

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

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

Node.js

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

Q&A

解決済

1回答

1369閲覧

mongodb Node.js MongooseError: Operation `user.findOne()` buffering timed out after 10000ms

Patao150205

総合スコア10

MongoDB

MongoDBはオープンソースのドキュメント指向データベースの1つです。高性能で、多くのリトルエンディアンシステムを利用することができます。

Node.js

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

0グッド

0クリップ

投稿2021/06/06 20:57

前提・実現したいこと

passport.jsを使って認証機能を実現しようとしています。ログイン情報をフォームから送信したあと、その情報を元にmongodbからuserのデータをフェッチしようと試みていますが、下記のエラーが発生します。

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

serializeUserにemailが渡されたあと数秒後エラーが発生しています。

test@yahoo.co.jp  config/account.js:37 エラー MongooseError: Operation `user.findOne()` buffering timed out after 10000ms

該当のソースコード

Javascript

1const passport = require("passport"); 2const LocalStrategy = require("passport-local").Strategy; 3const User = require("../models/m_user.js"); 4const mongoose = require("mongoose"); 5const { DATABASEURL, OPTIONS } = require("../config/mongo.config.js"); 6 7passport.use( 8 "emailAndPasswordStrategy", 9 new LocalStrategy({ usernameField: "email", passReqToCallback: true }, async (req, email, password, done) => { 10 await mongoose.connect(DATABASEURL, OPTIONS); 11 const db = mongoose.connection; 12 db.on("error", (err) => { 13 done(err); 14 }); 15 User.findOne({ 16 email, 17 password, 18 }) 19 .then((user) => { 20 if (!user) { 21 done(null, false, req.flash("notFoundUser", "メールアドレスもしくはパスワードを正しく入力してください。")); 22 return; 23 } 24 done(null, user.email); 25 }) 26 .catch((err) => { 27 done(err); 28 }) 29 .then(() => { 30 db.close(); 31 }); 32 }) 33); 34 35passport.serializeUser((email, done) => { 36 done(null, email); 37 console.log(email); 38}); 39 40passport.deserializeUser((email, done) => { 41 User.findOne({ email }) 42 .then((user) => { 43 done(null, user); 44 }) 45 .catch((err) => { 46 done(err); 47 }); 48}); 49 50const initialize = () => { 51 return [passport.initialize(), passport.session()]; 52}; 53 54module.exports = { 55 initialize, 56}; 57

試したこと

ググって見ましたが、データベースにコネクションする前にModelを動作させると起こるエラーのようです。
しかし、ソースコードを見ていただければ分かるように、async/awaitで制御を行っています。
制御方法のやり方が違うのでしょうか?

補足情報(FW/ツールのバージョンなど)

参考にしたサイト

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

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

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

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

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

guest

回答1

0

自己解決

処理が不足していた。
deserializeUser

投稿2021/06/07 01:12

Patao150205

総合スコア10

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問