Экспресс-http-контекст теряется после вызова MySQL - PullRequest
0 голосов
/ 30 декабря 2018

нужна ваша помощь.Я пытаюсь реализовать глобальный идентификатор запроса для моего приложения nodejs.Для этого я использую lib экспресс-http-context для установки идентификатора запроса.Но он не работает, как ожидалось, когда мой код обращается к данным из базы данных MySQL.Похоже, что существует проблема совместимости в cls , используемой express-http-context и mysql .

Пример кода и выводниже:

const app = require('express')();
const httpContext = require('express-http-context');
const mysql = require('mysql');
const { INTERNAL_SERVER_ERROR, OK, NOT_FOUND } = require('http-status-codes');
const http = require('http');
const uuidv4 = require('uuid/v4');

const pool = mysql.createPool({
  host: '127.0.0.1',
  port: 3306,
  user: 'root',
  password: 'Redhat@123',
  database: 'user',
  connectionLimit: 10,
});

pool.query('SELECT 1 + 1 AS solution', (error) => {
  if (error) {
    console.log('Unable to connect to MySQL:- ', error.message);
    process.exit(1);
  }
  console.log('MySQL PING is Working');
});

app.use(httpContext.middleware);
app.use((req, res, next) => {
  httpContext.set('requestId', uuidv4());
  console.log('request Id set is: ', httpContext.get('requestId'));
  next();
});

const getUserDetailsRepository = (userId, callback) => {
  console.log('inside getuserDetails repository for request id: ', httpContext.get('requestId'));
  pool.getConnection((connectionError, connection) => {
    if (connectionError) {
      console.log('got ConnError getuserDetails repository for request id: ', httpContext.get('requestId'));
      callback(connectionError);
    } else {
      const query = 'SELECT * from user where id = ?';
      connection.query(query, [userId], (queryError, results) => {
        connection.release();
        if (queryError) {
          console.log('got queryError getuserDetails repository for request id: ', httpContext.get('requestId'), queryError.message);
          callback(queryError);
        } else {
          console.log('Got response inside getuserDetails repository for request id: ', httpContext.get('requestId'));
          callback(null, results);
        }
      });
    }
  });
};

const userGetDetails = (req, res, next) => {
  const { userId } = req.params;
  console.log('inside getUserDetails controller for request id: ', httpContext.get('requestId'));
  getUserDetailsRepository(userId, (error, result) => {
    if (error) {
      console.log('got Error in getuserDetails controller for request id: ', httpContext.get('requestId'))
      res.sendStatus(INTERNAL_SERVER_ERROR);
    } else if (result) {
      console.log('Got response inside getuserDetails repository for request id: ', httpContext.get('requestId'));
      res.status(OK).json(result);
    } else {
      res.sendStatus(NOT_FOUND);
    }
  });
};

app.get('/user/:userId', userGetDetails);

const server = http.createServer(app);
server.listen(3000, () => console.log('Http server started listening on port'));

Вывод:

Http server started listening on port
MySQL PING is Working
request Id set is:  ea4895ab-8003-4d28-99aa-b03af7027ae8
inside getUserDetails controller for request id:  ea4895ab-8003-4d28-99aa-b03af7027ae8
inside getuserDetails repository for request id:  ea4895ab-8003-4d28-99aa-b03af7027ae8
Got response inside getuserDetails repository for request id:  undefined
Got response inside getuserDetails repository for request id:  undefined

1 Ответ

0 голосов
/ 05 мая 2019

Я надеюсь, что это решение решит вашу проблему и сэкономит много часов для тех, у кого есть эта проблема

. Вы можете просто использовать bindEmitter для решения проблемы

app.use((req, res, next) => {
  httpContext.ns.bindEmitter(req);
  httpContext.ns.bindEmitter(res);
  var requestId = req.headers["x-request-id"] || uuidv4();
  httpContext.set("requestId", requestId);
  console.log('request Id set is: ', httpContext.get('requestId'));
  next();
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...