Added memory profiling.

This commit is contained in:
DebaucheryLibrarian 2021-10-17 23:56:49 +02:00
parent c1aea78496
commit 972b15e72d
4 changed files with 19758 additions and 174 deletions

1
.gitignore vendored
View File

@ -8,3 +8,4 @@ config/*
!config/default.js
assets/js/config/
!assets/js/config/default.js
*.heapprofile

19692
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -108,6 +108,7 @@
"html-entities": "^2.3.2",
"iconv-lite": "^0.5.1",
"inquirer": "^7.3.3",
"inspector-api": "^1.4.2",
"jsdom": "^16.3.0",
"knex": "^0.21.13",
"knex-migrate": "^1.7.4",

View File

@ -2,11 +2,15 @@
const util = require('util');
const log = require('why-is-node-running');
const Inspector = require('inspector-api');
const fs = require('fs').promises;
const dayjs = require('dayjs');
const argv = require('./argv');
const initServer = require('./web/server');
const http = require('./utils/http');
const logger = require('./logger')(__filename);
const knex = require('./knex');
const fetchUpdates = require('./updates');
const { fetchScenes, fetchMovies } = require('./deep');
@ -17,6 +21,8 @@ const { deleteScenes, deleteMovies, flushScenes, flushMovies, flushBatches } = r
const { flushOrphanedMedia } = require('./media');
const getFileEntries = require('./utils/file-entries');
const inspector = new Inspector();
function logActive() {
setTimeout(() => {
log();
@ -24,7 +30,26 @@ function logActive() {
}, typeof argv.logActive === 'number' ? argv.logActive : 60000);
}
async function stopMemorySample() {
const profile = await inspector.heap.stopSampling();
const filepath = `${dayjs().format('YYYY-MM-DD_HH-mm-ss')}.heapprofile`;
await inspector.heap.disable();
fs.writeFile(filepath, JSON.stringify(profile));
logger.info(`Saved heap sample to ${filepath}`);
}
async function init() {
try {
if (argv.memory) {
await inspector.heap.enable();
await inspector.heap.startSampling();
logger.info('Started heap sampling');
}
if (argv.logActive) {
logActive();
}
@ -124,7 +149,22 @@ async function init() {
await associateMovieScenes(storedMovies, storedScenes);
}
if (argv.memory) {
await stopMemorySample();
}
knex.destroy();
} catch (error) {
logger.error(error);
if (argv.memory) {
await stopMemorySample();
}
knex.destroy();
throw error;
}
}
module.exports = init;