mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
Added option to disable fast import for data generator
Data generator uses CSV imports for a massive speed increase, but can't be used in some environments where SQL admin isn't available. This allows us to set a flag to use the original insert-based importer.
This commit is contained in:
parent
56d984f05f
commit
8c3e5ece01
3 changed files with 15 additions and 7 deletions
|
@ -204,11 +204,16 @@ class DataGenerator {
|
||||||
|
|
||||||
async #run(transaction) {
|
async #run(transaction) {
|
||||||
if (!DatabaseInfo.isSQLite(this.knex)) {
|
if (!DatabaseInfo.isSQLite(this.knex)) {
|
||||||
|
if (process.env.DISABLE_FAST_IMPORT) {
|
||||||
|
await transaction.raw('SET FOREIGN_KEY_CHECKS=0;');
|
||||||
|
await transaction.raw('SET unique_checks=0;');
|
||||||
|
} else {
|
||||||
await transaction.raw('ALTER INSTANCE DISABLE INNODB REDO_LOG;');
|
await transaction.raw('ALTER INSTANCE DISABLE INNODB REDO_LOG;');
|
||||||
await transaction.raw('SET FOREIGN_KEY_CHECKS=0;');
|
await transaction.raw('SET FOREIGN_KEY_CHECKS=0;');
|
||||||
await transaction.raw('SET unique_checks=0;');
|
await transaction.raw('SET unique_checks=0;');
|
||||||
await transaction.raw('SET GLOBAL local_infile=1;');
|
await transaction.raw('SET GLOBAL local_infile=1;');
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (this.willClearData) {
|
if (this.willClearData) {
|
||||||
await this.clearData(transaction);
|
await this.clearData(transaction);
|
||||||
|
@ -274,7 +279,7 @@ class DataGenerator {
|
||||||
// Re-enable the redo log because it's a persisted global
|
// Re-enable the redo log because it's a persisted global
|
||||||
// Leaving it disabled can break the database in the event of an unexpected shutdown
|
// Leaving it disabled can break the database in the event of an unexpected shutdown
|
||||||
// See https://dev.mysql.com/doc/refman/8.0/en/innodb-redo-log.html#innodb-disable-redo-logging
|
// See https://dev.mysql.com/doc/refman/8.0/en/innodb-redo-log.html#innodb-disable-redo-logging
|
||||||
if (!DatabaseInfo.isSQLite(this.knex)) {
|
if (!DatabaseInfo.isSQLite(this.knex) && !process.env.DISABLE_FAST_IMPORT) {
|
||||||
await transaction.raw('ALTER INSTANCE ENABLE INNODB REDO_LOG;');
|
await transaction.raw('ALTER INSTANCE ENABLE INNODB REDO_LOG;');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,7 +101,7 @@ class TableImporter {
|
||||||
const filePath = path.join(rootFolder, `${this.name}.csv`);
|
const filePath = path.join(rootFolder, `${this.name}.csv`);
|
||||||
let now = Date.now();
|
let now = Date.now();
|
||||||
|
|
||||||
if (data.length > 5000) {
|
if (data.length > 5000 && !process.env.DISABLE_FAST_IMPORT) {
|
||||||
try {
|
try {
|
||||||
await fs.promises.unlink(filePath);
|
await fs.promises.unlink(filePath);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
class JsonImporter {
|
const TableImporter = require('../importers/TableImporter');
|
||||||
|
|
||||||
|
class JsonImporter extends TableImporter {
|
||||||
constructor(knex, transaction) {
|
constructor(knex, transaction) {
|
||||||
|
super();
|
||||||
this.knex = knex;
|
this.knex = knex;
|
||||||
this.transaction = transaction;
|
this.transaction = transaction;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue