2023-07-07 15:57:53 -05:00
|
|
|
const { R } = require("redbean-node");
|
|
|
|
const { log } = require("../../src/util");
|
2023-08-09 08:05:15 -05:00
|
|
|
const Database = require("../database");
|
2023-07-07 15:57:53 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Run incremental_vacuum and checkpoint the WAL.
|
2023-08-11 02:46:41 -05:00
|
|
|
* @returns {Promise<void>} A promise that resolves when the process is finished.
|
2023-07-07 15:57:53 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
const incrementalVacuum = async () => {
|
|
|
|
try {
|
2023-08-09 08:05:15 -05:00
|
|
|
if (Database.dbConfig.type !== "sqlite") {
|
|
|
|
log.debug("incrementalVacuum", "Skipping incremental_vacuum, not using SQLite.");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-07-07 15:57:53 -05:00
|
|
|
log.debug("incrementalVacuum", "Running incremental_vacuum and wal_checkpoint(PASSIVE)...");
|
|
|
|
await R.exec("PRAGMA incremental_vacuum(200)");
|
|
|
|
await R.exec("PRAGMA wal_checkpoint(PASSIVE)");
|
|
|
|
} catch (e) {
|
|
|
|
log.error("incrementalVacuum", `Failed: ${e.message}`);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
incrementalVacuum,
|
|
|
|
};
|