ОШИБКА: Ошибка разбора URL: не определено при переносе базы данных в heroku - PullRequest
0 голосов
/ 04 ноября 2018

Я использую 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;

Не совсем уверен, в чем проблема. Просматривая логи героки, я вижу throw new Error('Dialect needs to be explicitly supplied as of v4.0.0');

Но я добавил диалект в файле config.js. Имеет ли значение, является ли файл конфигурации файлом .js или .json?

Просто чтобы уточнить, открывается настоящее веб-приложение, и я вижу обработчик ошибок, который я настроил. Поэтому я не получаю сообщение об ошибке приложения при открытии URL-адреса маршрута

1 Ответ

0 голосов
/ 09 марта 2019

производство: { use_env_variable: 'DATABASE_URL', },

поменяйте производство на это и перейдите к герою, чтобы установить переменную среды

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...