set mongo profiling

This commit is contained in:
Jan Prochazka
2022-12-09 15:14:21 +01:00
parent e6ac878b74
commit 61dc9da3f0
5 changed files with 66 additions and 7 deletions

View File

@@ -197,4 +197,12 @@ module.exports = {
testConnectionPermission(conid, req);
return this.loadDataCore('serverSummary', { conid });
},
summaryCommand_meta: true,
async summaryCommand({ conid, command, row }, req) {
testConnectionPermission(conid, req);
const opened = await this.ensureOpened(conid);
if (opened.connection.isReadOnly) return false;
return this.loadDataCore('summaryCommand', { conid, command, row });
},
};

View File

@@ -118,14 +118,19 @@ async function handleDriverDataCore(msgid, callMethod) {
}
}
async function handleServerSummary({ msgid, options }) {
async function handleServerSummary({ msgid }) {
return handleDriverDataCore(msgid, driver => driver.serverSummary(systemConnection));
}
async function handleSummaryCommand({ msgid, command, row }) {
return handleDriverDataCore(msgid, driver => driver.summaryCommand(systemConnection, command, row));
}
const messageHandlers = {
connect: handleConnect,
ping: handlePing,
serverSummary: handleServerSummary,
summaryCommand: handleSummaryCommand,
createDatabase: props => handleDatabaseOp('createDatabase', props),
dropDatabase: props => handleDatabaseOp('dropDatabase', props),
};

View File

@@ -128,7 +128,8 @@ export interface EngineDriver {
getNewObjectTemplates(): NewObjectTemplate[];
// direct call of pool method, only some methods could be supported, on only some drivers
callMethod(pool, method, args);
loadSummary(pool): Promise<ServerSummary>;
serverSummary(pool): Promise<ServerSummary>;
summaryCommand(pool, command, row): Promise<void>;
analyserClass?: any;
dumperClass?: any;

View File

@@ -9,6 +9,11 @@
export let conid;
let refreshToken = 0;
async function callAction(command, row) {
await apiCall('server-connections/summary-command', { conid, refreshToken, command, row });
refreshToken += 1;
}
</script>
{#await apiCall('server-connections/server-summary', { conid, refreshToken })}
@@ -22,10 +27,18 @@
emptyMessage={'No databases'}
columns={summary.columns.map(col => ({
...col,
slot: col.dataType == 'bytes' ? 1 : null,
slot: col.columnType == 'bytes' ? 1 : col.columnType == 'actions' ? 2 : null,
}))}
>
<svelte:fragment slot="1" let:row let:col>{formatFileSize(row?.[col.fieldName])}</svelte:fragment>
<svelte:fragment slot="2" let:row let:col>
{#each col.actions as action, index}
{#if index > 0}
<span> | </span>
{/if}
<Link onClick={() => callAction(action.command, row)}>{action.header}</Link>
{/each}
</svelte:fragment>
</ObjectListControl>
</div>
{/await}