2

私は自分の nodejs アプリを Openshift でホストしています。ここに私の仕様があります:

ノード v0.10.35、エクスプレス v3.4.8

私のpackage.jsonの依存関係:

"dependencies": {
"angular-loading-bar": "^0.9.0",
"async": "^2.0.0-rc.5",
"bcrypt-nodejs": "0.0.3",
"body-parser": "~1.0.0",
"connect-flash": "^0.1.1",
"connect-mongo": "^1.2.0",
"cookie-parser": "~1.0.0",
"ejs": "^2.4.1",
"express": "~3.4.4",
"lodash": "^4.12.0",
"method-override": "~1.0.0",
"mongodb": "~2.x",
"mongoose": "~4.4.12",
"morgan": "~1.0.0",
"nodemailer": "^2.3.2",
"passport": "^0.3.2",
"passport-local": "^1.0.0",
"recaptcha2": "^1.0.8"
},

そして、ここに私のserver.jsがあります

#!/bin/env node

var express = require('express');
var fs      = require('fs');
var mongoose = require('mongoose');
var passport = require('passport');
var flash    = require('connect-flash');

var morgan       = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser   = require('body-parser');

var MongoStore = require('connect-mongo/es5')(express);

var app = express();

var server_port = process.env.OPENSHIFT_NODEJS_PORT || 8080;
var server_ip_address = process.env.OPENSHIFT_NODEJS_IP || '0.0.0.0';

//MongoD
mongodb_connection_string = process.env.OPENSHIFT_MONGODB_DB_URL + "tenders";
mongoose.connect(mongodb_connection_string);
var dbconn = mongoose.connection;
dbconn.on('error', console.error.bind(console, 'connection error:'));
dbconn.once('open', function(){
    console.log('Connected to Mongoose Database.');
});

// Close MongoD connection when app is terminated
process.on('SIGINT', function (){
   mongoose.disconnect();
   dbconn.close(function (){
       console.log("Server halted: Mongoose default connection disconnected.");
       process.exit(0);
   }); 
});

/* Configuration */
app.set('view engine', 'ejs'); // set up ejs for templating

/* Middlewares */
app.use(express.static(__dirname + "/views"));
app.use(express.static(__dirname + "/public"));

// set up our express application
app.use(morgan('dev')); // log every request to the console
app.use(bodyParser()); // get information from html forms
app.use(cookieParser()); // read cookies (needed for auth)

/** Persistent database backed session **/
app.use(express.session({ 
    secret: process.env.SECRET,
    store: new MongoStore({mongooseConnection : mongoose.connection}) 
}));

app.use(passport.initialize());
app.use(passport.session());
app.use(flash()); 

require('./routes/routes')(app, passport); 
require('./config/passport')(passport);  configuration

app.use(function(req, res) {
    res.redirect('/')
});

app.use(function (err, req, res, next) {
  if (err.name === 'UnauthorizedError') {
    res.status(401);
    res.json({"message" : err.name + ": " + err.message});
  }
});

/* Start server */
app.listen(server_port, server_ip_address, function(){
    console.log("Listening on " + server_ip_address + ":" + server_port);
});

問題は、データベースのセッション コレクションのエントリ数を数えることからわかるように、connect-mongo が毎秒新しいセッションを作成していることです。現在 Web サイトを使用しているアクティブなユーザーがいない場合でも、セッションが作成されています。これは正常ですか?

編集:ほとんどのAPI呼び出しで、ユーザーがpassport isauthenticatedメソッドを使用してログインしているかどうかを確認するために使用するミドルウェアが原因ですか。しかし、奇妙なことは、リダイレクトを続ける以下のnode.logからわかるように、サーバーにリクエストを行っているユーザーがいない場合でも呼び出されることです

GET / 302 3ms - 40b
GET / 302 3ms - 40b
GET / 302 2ms - 40b
GET / 302 2ms - 40b
GET / 302 3ms - 40b
GET / 302 20ms - 40b
GET / 302 3ms - 40b
GET / 302 2ms - 40b
GET / 302 3ms - 40b
GET / 302 4ms - 40b
4

3 に答える 3

0

Express-session >= 1.10.0 を使用していて、ユーザーがページを更新するたびにすべてのセッションをデータベースに再保存したくない場合は、期間を制限してセッションを遅延更新できます。あなたは新しいバージョンのconnect-mongoと古いバージョンのexpress imを使用しているため、100%確信が持てませんが、これはCookieまたは未初期化セッションのいずれかが原因だと思います.

// Configuring sessions
var session = require('express-session');
var MongoStore = require('connect-mongo')(session);
app.use(session({
    secret: 'JohnSecret',
    saveUninitialized: false, // don't create session until something stored
    resave: false, //don't save session if unmodified
    store: new MongoStore({
      url: 'mongodb://localhost/John',
      autoRemove: 'interval',
      autoRemoveInterval: 10 // In minutes. Default
    })
}));
于 2016-06-08T13:27:52.053 に答える
0

わかりました。HAProxy がバックエンド サーバーを継続的にチェックして、稼働していることを確認するという問題です。そうすることで、すぐにセッションが作成され、データベースが乱雑になります。だからここに私の(汚れた)修正があります:

  1. /ping各セッションを破棄して HAProxy の httpchk を処理する API を作成する

    app.get('/ping', function(req, res){ req.session.destroy(); res.send(200); });

  2. haproxy/confに変更option httpchk GET /するように構成するoption httpchk GET /ping

  3. RHC を使用して HAProxy カートリッジを再起動するrhc cartridge-restart --cartridge haproxy

于 2016-06-08T17:05:35.167 に答える