错误:将数据库迁移到heroku时,解析url时出错:未定义



我正在使用Sequelize作为ORM,并试图将我的数据库迁移到Heroku。运行heroku run sequelize db:migrate

我刚收到

Loaded configuration file "config/config.js".
Using environment "production".
ERROR: Error parsing url: undefined

以下是我的配置文件:

module.exports = {
"development": {
"username": "root",
"password": "password",
"database": "vueapp",
"host": "127.0.0.1",
"dialect": "postgres"
},
"test": {
"username": "root",
"password": null,
"database": "database_test",
"host": "127.0.0.1",
"dialect": "mysql"
},
"production": {
"use_env_variable": process.env.DATABASE_URL,
"dialect": "postgres",
"ssl": true,
"dialectOptions": {
"ssl": true
}
}
}

和索引文件

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')[env];
const User = require("./user")
const Hour = require('./hours');
const db = {
User,
Hour
};
let sequelize;
if (config.use_env_variable) {
sequelize = new Sequelize(config.use_env_variable, config);
} else {
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 = sequelize['import'](path.join(__dirname, file));
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;

不完全确定问题是什么。浏览heroku日志,我看到一个throw new Error('Dialect needs to be explicitly supplied as of v4.0.0');

但是我已经在config.js文件中添加了方言。配置文件是.js文件还是.json文件有关系吗?

为了澄清,实际的web应用程序打开了,我可以看到我设置的错误处理程序。因此,当打开路由URL 时,我实际上并没有收到应用程序错误

生产:{use_env_variable:"DATABASE_URL",},

将您的生产更改为此,然后转到heroku设置环境变量

您后来解决问题了吗

这有点令人困惑,但Damilola是正确的。您需要将use_env_variable的值保留为"DATABASE_URL"。您可能会想将其更改为process.env.DATABASE_URL。这是不正确的。

这样做将允许Sequelize注入保存到Heroku环境变量DATABASE_URL的值。

生产:{use_env_variable:"DATABASE_URL",方言:;postgres";,协议:";postgres";}

最新更新