어떤 에러인가요?
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;
'DevOps' 카테고리의 다른 글
[Error] aws로 route53, cloudfront, elastic load balancer 를 이용한 https 배포 시 502 bad gateway 에러 (0) | 2022.01.22 |
---|---|
AWS 기본 용어 정리: S3, EC2, RDS, AMI란? (0) | 2021.11.01 |