[Error] aws 연결 시 sequelize connection error

DevOps · 2021. 11. 14. 02:19

어떤 에러인가요?

aws 서버와 db가 통신하지 못해 sequelize connection error가 났다.

에러 메시지

SequelizeConnectionError: connect ETIMEDOUT 
SequelizeConnectionError: ER_BAD_DB_ERROR 

에러 핸들링 방법

첫 번째 ETIMEOUT은 config.js에 데이터베이스 포트 번호를 안 써줘서 생긴 오류였다.
포트번호를 추가해주니 해결되었다.

두 번째 ER_BAD_DB_ERROR는 database가 생성되지 않아 생긴 오류였다.
sequelize.sync()코드가 자동으로 데이터베이스를 생성해주는 줄 알았는데 아니었나보다.
ec2에서 직접 데이터베이스를 생성하고 마이그레이션을 돌리니 해결되었다.
자동으로 연결해주는 부분은 다음에 좀 더 공부해봐야겠다.

그리고 시퀄라이즈에서 기본적으로 제공하는 model index.js를 그대로 사용하니 NODE_ENV를 읽어오지 못하는 것 같아
https://www.youtube.com/watch?v=vMXnXXfFm-I&t=15s
이걸 참고해서 수정했다.

수정한 model.index 코드는 다음과 같다.

'use strict';

const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const basename = path.basename(__filename);
const env = process.env.NODE_ENV || 'development';
const config = require(__dirname + '/../config/config.js')[env];
const db = {};

let sequelize = new Sequelize(config.database, config.username, config.password, config);

fs.readdirSync(__dirname)
  .filter((file) => {
    return file.indexOf('.') !== 0 && file !== basename && file.slice(-3) === '.js';
  })
  .forEach((file) => {
    const model = require(path.join(__dirname, file))(sequelize, Sequelize.DataTypes);
    db[model.name] = model;
  });

Object.keys(db).forEach((modelName) => {
  if (db[modelName].associate) {
    db[modelName].associate(db);
  }
});

db.sequelize = sequelize;
db.Sequelize = Sequelize;

module.exports = db;