@eggjs/logrotator 5.0.0-beta.20 → 5.0.0-beta.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agent.d.ts +2 -2
- package/dist/agent.js +3 -7
- package/dist/app/extend/agent.d.ts +3 -6
- package/dist/app/extend/agent.js +6 -7
- package/dist/app/extend/application.d.ts +5 -3
- package/dist/app/extend/application.js +5 -4
- package/dist/app/schedule/clean_log.d.ts +7 -10
- package/dist/app/schedule/clean_log.js +67 -57
- package/dist/app/schedule/rotate_by_file.d.ts +8 -11
- package/dist/app/schedule/rotate_by_file.js +14 -20
- package/dist/app/schedule/rotate_by_hour.d.ts +8 -11
- package/dist/app/schedule/rotate_by_hour.js +14 -19
- package/dist/app/schedule/rotate_by_size.d.ts +8 -11
- package/dist/app/schedule/rotate_by_size.js +14 -19
- package/dist/app.d.ts +2 -2
- package/dist/app.js +3 -7
- package/dist/boot.d.ts +6 -2
- package/dist/boot.js +14 -3
- package/dist/config/config.default.d.ts +60 -2
- package/dist/config/config.default.js +14 -3
- package/dist/index.d.ts +4 -5
- package/dist/index.js +5 -6
- package/dist/lib/day_rotator.d.ts +7 -11
- package/dist/lib/day_rotator.js +80 -5
- package/dist/lib/hour_rotator.d.ts +5 -9
- package/dist/lib/hour_rotator.js +39 -4
- package/dist/lib/rotator.d.ts +16 -2
- package/dist/lib/rotator.js +73 -3
- package/dist/lib/size_rotator.d.ts +4 -8
- package/dist/lib/size_rotator.js +67 -4
- package/dist/lib/utils.d.ts +5 -7
- package/dist/lib/utils.js +16 -3
- package/dist/types.d.ts +17 -3
- package/dist/types.js +2 -3
- package/package.json +6 -6
- package/dist/application-DLlqYOTH.d.ts +0 -8
- package/dist/application-DUxqk1cL.js +0 -7
- package/dist/boot-Fk-0g48D.js +0 -16
- package/dist/boot-GzaTgWud.d.ts +0 -10
- package/dist/config.default-CnLV2bGK.d.ts +0 -62
- package/dist/config.default-CvMzfv2b.js +0 -15
- package/dist/day_rotator-DHd2Parx.js +0 -64
- package/dist/hour_rotator-JmysNFky.js +0 -38
- package/dist/rotator-BjJMXyaY.d.ts +0 -20
- package/dist/rotator-CRROE_AN.js +0 -56
- package/dist/size_rotator-B94wnaTP.js +0 -61
- package/dist/types-CQtQr8gw.js +0 -1
- package/dist/types-RmfrK2ke.d.ts +0 -19
- package/dist/utils-Br9jwJMb.js +0 -15
package/dist/agent.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { Boot } from
|
|
2
|
-
export
|
|
1
|
+
import { Boot } from './boot.ts';
|
|
2
|
+
export default Boot;
|
package/dist/agent.js
CHANGED
|
@@ -1,7 +1,3 @@
|
|
|
1
|
-
import { Boot } from "./boot
|
|
2
|
-
|
|
3
|
-
//#
|
|
4
|
-
var agent_default = Boot;
|
|
5
|
-
|
|
6
|
-
//#endregion
|
|
7
|
-
export { agent_default as default };
|
|
1
|
+
import { Boot } from "./boot.js";
|
|
2
|
+
export default Boot;
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvYWdlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUVqQyxlQUFlLElBQUksQ0FBQyJ9
|
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-
import { LogRotator } from
|
|
2
|
-
|
|
3
|
-
//#region src/app/extend/agent.d.ts
|
|
1
|
+
import { LogRotator } from '../../lib/rotator.ts';
|
|
4
2
|
declare const _default: {
|
|
5
|
-
|
|
3
|
+
LogRotator: typeof LogRotator;
|
|
6
4
|
};
|
|
7
|
-
|
|
8
|
-
export { _default as default };
|
|
5
|
+
export default _default;
|
package/dist/app/extend/agent.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import { LogRotator } from "../../rotator
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
//#
|
|
7
|
-
export { agent_default as default };
|
|
1
|
+
import { LogRotator } from "../../lib/rotator.js";
|
|
2
|
+
// egg-schedule will load both at app and agent, so we should mount it for compatible
|
|
3
|
+
export default {
|
|
4
|
+
LogRotator,
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL2V4dGVuZC9hZ2VudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFbEQscUZBQXFGO0FBQ3JGLGVBQWU7SUFDYixVQUFVO0NBQ1gsQ0FBQyJ9
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { LogRotator } from '../../lib/rotator.ts';
|
|
2
|
+
declare const _default: {
|
|
3
|
+
LogRotator: typeof LogRotator;
|
|
4
|
+
};
|
|
5
|
+
export default _default;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import "../../rotator
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { LogRotator } from "../../lib/rotator.js";
|
|
2
|
+
export default {
|
|
3
|
+
LogRotator,
|
|
4
|
+
};
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL2V4dGVuZC9hcHBsaWNhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFbEQsZUFBZTtJQUNiLFVBQVU7Q0FDWCxDQUFDIn0=
|
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
import { Application } from
|
|
2
|
-
|
|
3
|
-
//#region src/app/schedule/clean_log.d.ts
|
|
1
|
+
import type { Application } from 'egg';
|
|
4
2
|
declare const _default: (app: Application) => {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
3
|
+
schedule: {
|
|
4
|
+
type: string;
|
|
5
|
+
cron: string;
|
|
6
|
+
};
|
|
7
|
+
task(): Promise<void>;
|
|
10
8
|
};
|
|
11
|
-
|
|
12
|
-
export { _default as default };
|
|
9
|
+
export default _default;
|
|
@@ -1,60 +1,70 @@
|
|
|
1
|
-
import
|
|
2
|
-
import fs from
|
|
3
|
-
import { exists } from
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import fs from 'node:fs/promises';
|
|
3
|
+
import { exists } from 'utility';
|
|
4
|
+
import moment from 'moment';
|
|
5
|
+
import { walkLoggerFile } from "../../lib/utils.js";
|
|
6
|
+
// clean all xxx.log.YYYY-MM-DD before expired date.
|
|
7
|
+
export default (app) => ({
|
|
8
|
+
schedule: {
|
|
9
|
+
type: 'worker', // only one worker run this task
|
|
10
|
+
cron: '0 0 * * *', // run every day at 00:00
|
|
11
|
+
},
|
|
12
|
+
async task() {
|
|
13
|
+
const logger = app.coreLogger;
|
|
14
|
+
const logDirs = new Set();
|
|
15
|
+
const loggerFiles = walkLoggerFile(app.loggers);
|
|
16
|
+
for (const file of loggerFiles) {
|
|
17
|
+
const logDir = path.dirname(file);
|
|
18
|
+
logDirs.add(logDir);
|
|
19
|
+
}
|
|
20
|
+
const maxDays = app.config.logrotator.maxDays;
|
|
21
|
+
if (maxDays && maxDays > 0) {
|
|
22
|
+
try {
|
|
23
|
+
const tasks = Array.from(logDirs, logDir => removeExpiredLogFiles(logDir, maxDays, logger));
|
|
24
|
+
await Promise.all(tasks);
|
|
25
|
+
}
|
|
26
|
+
catch (err) {
|
|
27
|
+
logger.error(err);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
logger.info('[@eggjs/logrotator] clean all log before %s days', maxDays);
|
|
31
|
+
},
|
|
30
32
|
});
|
|
33
|
+
// remove expired log files: xxx.log.YYYY-MM-DD
|
|
31
34
|
async function removeExpiredLogFiles(logDir, maxDays, logger) {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
35
|
+
// ignore not exists dir
|
|
36
|
+
const stat = await exists(logDir);
|
|
37
|
+
if (!stat) {
|
|
38
|
+
logger.warn(`[@eggjs/logrotator] logDir ${logDir} not exists`);
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
const files = await fs.readdir(logDir);
|
|
42
|
+
const expiredDate = moment().subtract(maxDays, 'days').startOf('date');
|
|
43
|
+
const names = files.filter(file => {
|
|
44
|
+
const name = path.extname(file).slice(1);
|
|
45
|
+
if (!/^\d{4}-\d{2}-\d{2}/.test(name)) {
|
|
46
|
+
return false;
|
|
47
|
+
}
|
|
48
|
+
const date = moment(name, 'YYYY-MM-DD').startOf('date');
|
|
49
|
+
if (!date.isValid()) {
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
return date.isBefore(expiredDate);
|
|
53
|
+
});
|
|
54
|
+
if (names.length === 0) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
logger.info(`[@eggjs/logrotator] start remove ${logDir} files: ${names.join(', ')}`);
|
|
58
|
+
await Promise.all(names.map(async (name) => {
|
|
59
|
+
const logFile = path.join(logDir, name);
|
|
60
|
+
try {
|
|
61
|
+
await fs.unlink(logFile);
|
|
62
|
+
}
|
|
63
|
+
catch (e) {
|
|
64
|
+
const err = e;
|
|
65
|
+
err.message = `[@eggjs/logrotator] remove logFile ${logFile} error, ${err.message}`;
|
|
66
|
+
logger.error(err);
|
|
67
|
+
}
|
|
68
|
+
}));
|
|
57
69
|
}
|
|
58
|
-
|
|
59
|
-
//#endregion
|
|
60
|
-
export { clean_log_default as default };
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xlYW5fbG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwcC9zY2hlZHVsZS9jbGVhbl9sb2cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxJQUFJLE1BQU0sV0FBVyxDQUFDO0FBQzdCLE9BQU8sRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRWxDLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDakMsT0FBTyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBRzVCLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRCxvREFBb0Q7QUFDcEQsZUFBZSxDQUFDLEdBQWdCLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDcEMsUUFBUSxFQUFFO1FBQ1IsSUFBSSxFQUFFLFFBQVEsRUFBRSxnQ0FBZ0M7UUFDaEQsSUFBSSxFQUFFLFdBQVcsRUFBRSx5QkFBeUI7S0FDN0M7SUFFRCxLQUFLLENBQUMsSUFBSTtRQUNSLE1BQU0sTUFBTSxHQUFHLEdBQUcsQ0FBQyxVQUFVLENBQUM7UUFDOUIsTUFBTSxPQUFPLEdBQUcsSUFBSSxHQUFHLEVBQVUsQ0FBQztRQUNsQyxNQUFNLFdBQVcsR0FBRyxjQUFjLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2hELEtBQUssTUFBTSxJQUFJLElBQUksV0FBVyxFQUFFLENBQUM7WUFDL0IsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNsQyxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3RCLENBQUM7UUFDRCxNQUFNLE9BQU8sR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUM7UUFDOUMsSUFBSSxPQUFPLElBQUksT0FBTyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQzNCLElBQUksQ0FBQztnQkFDSCxNQUFNLEtBQUssR0FBRyxLQUFL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
|
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
import { Application } from
|
|
2
|
-
|
|
3
|
-
//#region src/app/schedule/rotate_by_file.d.ts
|
|
1
|
+
import type { Application } from 'egg';
|
|
4
2
|
declare const _default: (app: Application) => {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
3
|
+
schedule: {
|
|
4
|
+
type: string;
|
|
5
|
+
cron: string;
|
|
6
|
+
disable: boolean;
|
|
7
|
+
};
|
|
8
|
+
task(): Promise<void>;
|
|
11
9
|
};
|
|
12
|
-
|
|
13
|
-
export { _default as default };
|
|
10
|
+
export default _default;
|
|
@@ -1,21 +1,15 @@
|
|
|
1
|
-
import "../../
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
async task() {
|
|
15
|
-
await rotator.rotate();
|
|
16
|
-
}
|
|
17
|
-
};
|
|
1
|
+
import { DayRotator } from "../../lib/day_rotator.js";
|
|
2
|
+
export default (app) => {
|
|
3
|
+
const rotator = new DayRotator({ app });
|
|
4
|
+
return {
|
|
5
|
+
schedule: {
|
|
6
|
+
type: 'worker', // only one worker run this task
|
|
7
|
+
cron: '1 0 0 * * *', // run every day at 00:00
|
|
8
|
+
disable: app.config.logrotator.disableRotateByDay,
|
|
9
|
+
},
|
|
10
|
+
async task() {
|
|
11
|
+
await rotator.rotate();
|
|
12
|
+
},
|
|
13
|
+
};
|
|
18
14
|
};
|
|
19
|
-
|
|
20
|
-
//#endregion
|
|
21
|
-
export { rotate_by_file_default as default };
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm90YXRlX2J5X2ZpbGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL3NjaGVkdWxlL3JvdGF0ZV9ieV9maWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUV0RCxlQUFlLENBQUMsR0FBZ0IsRUFBRSxFQUFFO0lBQ2xDLE1BQU0sT0FBTyxHQUFHLElBQUksVUFBVSxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUV4QyxPQUFPO1FBQ0wsUUFBUSxFQUFFO1lBQ1IsSUFBSSxFQUFFLFFBQVEsRUFBRSxnQ0FBZ0M7WUFDaEQsSUFBSSxFQUFFLGFBQWEsRUFBRSx5QkFBeUI7WUFDOUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLGtCQUFrQjtTQUNsRDtRQUVELEtBQUssQ0FBQyxJQUFJO1lBQ1IsTUFBTSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDekIsQ0FBQztLQUNGLENBQUM7QUFDSixDQUFDLENBQUMifQ==
|
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
import { Application } from
|
|
2
|
-
|
|
3
|
-
//#region src/app/schedule/rotate_by_hour.d.ts
|
|
1
|
+
import type { Application } from 'egg';
|
|
4
2
|
declare const _default: (app: Application) => {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
3
|
+
schedule: {
|
|
4
|
+
type: string;
|
|
5
|
+
cron: string;
|
|
6
|
+
disable: boolean;
|
|
7
|
+
};
|
|
8
|
+
task(): Promise<void>;
|
|
11
9
|
};
|
|
12
|
-
|
|
13
|
-
export { _default as default };
|
|
10
|
+
export default _default;
|
|
@@ -1,20 +1,15 @@
|
|
|
1
|
-
import "../../
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
await rotator.rotate();
|
|
15
|
-
}
|
|
16
|
-
};
|
|
1
|
+
import { HourRotator } from "../../lib/hour_rotator.js";
|
|
2
|
+
export default (app) => {
|
|
3
|
+
const rotator = new HourRotator({ app });
|
|
4
|
+
return {
|
|
5
|
+
schedule: {
|
|
6
|
+
type: 'worker', // only one worker run this task
|
|
7
|
+
cron: '1 * * * *', // run every hour at 01
|
|
8
|
+
disable: (app.config.logrotator.filesRotateByHour || []).length === 0,
|
|
9
|
+
},
|
|
10
|
+
async task() {
|
|
11
|
+
await rotator.rotate();
|
|
12
|
+
},
|
|
13
|
+
};
|
|
17
14
|
};
|
|
18
|
-
|
|
19
|
-
//#endregion
|
|
20
|
-
export { rotate_by_hour_default as default };
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm90YXRlX2J5X2hvdXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL3NjaGVkdWxlL3JvdGF0ZV9ieV9ob3VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV4RCxlQUFlLENBQUMsR0FBZ0IsRUFBRSxFQUFFO0lBQ2xDLE1BQU0sT0FBTyxHQUFHLElBQUksV0FBVyxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUV6QyxPQUFPO1FBQ0wsUUFBUSxFQUFFO1lBQ1IsSUFBSSxFQUFFLFFBQVEsRUFBRSxnQ0FBZ0M7WUFDaEQsSUFBSSxFQUFFLFdBQVcsRUFBRSx1QkFBdUI7WUFDMUMsT0FBTyxFQUFFLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsaUJBQWlCLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUM7U0FDdEU7UUFFRCxLQUFLLENBQUMsSUFBSTtZQUNSLE1BQU0sT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3pCLENBQUM7S0FDRixDQUFDO0FBQ0osQ0FBQyxDQUFDIn0=
|
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
import { Application } from
|
|
2
|
-
|
|
3
|
-
//#region src/app/schedule/rotate_by_size.d.ts
|
|
1
|
+
import type { Application } from 'egg';
|
|
4
2
|
declare const _default: (app: Application) => {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
3
|
+
schedule: {
|
|
4
|
+
type: string;
|
|
5
|
+
interval: number;
|
|
6
|
+
disable: boolean;
|
|
7
|
+
};
|
|
8
|
+
task(): Promise<void>;
|
|
11
9
|
};
|
|
12
|
-
|
|
13
|
-
export { _default as default };
|
|
10
|
+
export default _default;
|
|
@@ -1,20 +1,15 @@
|
|
|
1
|
-
import "../../
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
await rotator.rotate();
|
|
15
|
-
}
|
|
16
|
-
};
|
|
1
|
+
import { SizeRotator } from "../../lib/size_rotator.js";
|
|
2
|
+
export default (app) => {
|
|
3
|
+
const rotator = new SizeRotator({ app });
|
|
4
|
+
return {
|
|
5
|
+
schedule: {
|
|
6
|
+
type: 'worker',
|
|
7
|
+
interval: app.config.logrotator.rotateDuration,
|
|
8
|
+
disable: (app.config.logrotator.filesRotateBySize || []).length === 0,
|
|
9
|
+
},
|
|
10
|
+
async task() {
|
|
11
|
+
await rotator.rotate();
|
|
12
|
+
},
|
|
13
|
+
};
|
|
17
14
|
};
|
|
18
|
-
|
|
19
|
-
//#endregion
|
|
20
|
-
export { rotate_by_size_default as default };
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm90YXRlX2J5X3NpemUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL3NjaGVkdWxlL3JvdGF0ZV9ieV9zaXplLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV4RCxlQUFlLENBQUMsR0FBZ0IsRUFBRSxFQUFFO0lBQ2xDLE1BQU0sT0FBTyxHQUFHLElBQUksV0FBVyxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUV6QyxPQUFPO1FBQ0wsUUFBUSxFQUFFO1lBQ1IsSUFBSSxFQUFFLFFBQVE7WUFDZCxRQUFRLEVBQUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsY0FBYztZQUM5QyxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQztTQUN0RTtRQUVELEtBQUssQ0FBQyxJQUFJO1lBQ1IsTUFBTSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDekIsQ0FBQztLQUNGLENBQUM7QUFDSixDQUFDLENBQUMifQ==
|
package/dist/app.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { Boot } from
|
|
2
|
-
export
|
|
1
|
+
import { Boot } from './boot.ts';
|
|
2
|
+
export default Boot;
|
package/dist/app.js
CHANGED
|
@@ -1,7 +1,3 @@
|
|
|
1
|
-
import { Boot } from "./boot
|
|
2
|
-
|
|
3
|
-
//#
|
|
4
|
-
var app_default = Boot;
|
|
5
|
-
|
|
6
|
-
//#endregion
|
|
7
|
-
export { app_default as default };
|
|
1
|
+
import { Boot } from "./boot.js";
|
|
2
|
+
export default Boot;
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2FwcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRWpDLGVBQWUsSUFBSSxDQUFDIn0=
|
package/dist/boot.d.ts
CHANGED
package/dist/boot.js
CHANGED
|
@@ -1,3 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
export class Boot {
|
|
2
|
+
app;
|
|
3
|
+
constructor(app) {
|
|
4
|
+
this.app = app;
|
|
5
|
+
}
|
|
6
|
+
async didLoad() {
|
|
7
|
+
// reload logger to new fd after rotating
|
|
8
|
+
this.app.messenger.on('log-reload', () => {
|
|
9
|
+
this.app.loggers.reload();
|
|
10
|
+
this.app.coreLogger.info('[@eggjs/logrotator] %s logger reload: got log-reload message', this.app.type);
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9vdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9ib290LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sT0FBTyxJQUFJO0lBQ0UsR0FBRyxDQUFDO0lBQ3JCLFlBQVksR0FBZ0I7UUFDMUIsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7SUFDakIsQ0FBQztJQUVELEtBQUssQ0FBQyxPQUFPO1FBQ1gseUNBQXlDO1FBQ3pDLElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxZQUFZLEVBQUUsR0FBRyxFQUFFO1lBQ3ZDLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQzFCLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyw4REFBOEQsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFHLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGIn0=
|
|
@@ -1,2 +1,60 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
export interface LogrotatorConfig {
|
|
2
|
+
/**
|
|
3
|
+
* Disable rotate by day
|
|
4
|
+
*
|
|
5
|
+
* Default: `false`
|
|
6
|
+
*/
|
|
7
|
+
disableRotateByDay: boolean;
|
|
8
|
+
/**
|
|
9
|
+
* List of files that will be rotated by hour
|
|
10
|
+
*
|
|
11
|
+
* Default: `null`
|
|
12
|
+
*/
|
|
13
|
+
filesRotateByHour: string[] | null;
|
|
14
|
+
/**
|
|
15
|
+
* Hour delimiter
|
|
16
|
+
*
|
|
17
|
+
* Default: `-`
|
|
18
|
+
*/
|
|
19
|
+
hourDelimiter: string;
|
|
20
|
+
/**
|
|
21
|
+
* List of files that will be rotated by size
|
|
22
|
+
*
|
|
23
|
+
* Default: `null`
|
|
24
|
+
*/
|
|
25
|
+
filesRotateBySize: string[] | null;
|
|
26
|
+
/**
|
|
27
|
+
* Max file size to judge if any file need rotate
|
|
28
|
+
*
|
|
29
|
+
* Default: `50 * 1024 * 1024`
|
|
30
|
+
*/
|
|
31
|
+
maxFileSize: number;
|
|
32
|
+
/**
|
|
33
|
+
* Max files to keep
|
|
34
|
+
*
|
|
35
|
+
* Default: `10`
|
|
36
|
+
*/
|
|
37
|
+
maxFiles: number;
|
|
38
|
+
/**
|
|
39
|
+
* Time interval to judge if any file need rotate
|
|
40
|
+
*
|
|
41
|
+
* Default: `60000`
|
|
42
|
+
*/
|
|
43
|
+
rotateDuration: number;
|
|
44
|
+
/**
|
|
45
|
+
* Max days to keep log files, set `0` to keep all logs.
|
|
46
|
+
*
|
|
47
|
+
* Default: `31`
|
|
48
|
+
*/
|
|
49
|
+
maxDays: number;
|
|
50
|
+
/**
|
|
51
|
+
* Enable gzip compression for rotated files
|
|
52
|
+
*
|
|
53
|
+
* Default: `false`
|
|
54
|
+
*/
|
|
55
|
+
gzip: boolean;
|
|
56
|
+
}
|
|
57
|
+
declare const _default: {
|
|
58
|
+
logrotator: LogrotatorConfig;
|
|
59
|
+
};
|
|
60
|
+
export default _default;
|
|
@@ -1,3 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
export default {
|
|
2
|
+
logrotator: {
|
|
3
|
+
disableRotateByDay: false,
|
|
4
|
+
filesRotateByHour: null,
|
|
5
|
+
hourDelimiter: '-',
|
|
6
|
+
filesRotateBySize: null,
|
|
7
|
+
maxFileSize: 50 * 1024 * 1024,
|
|
8
|
+
maxFiles: 10,
|
|
9
|
+
rotateDuration: 60_000,
|
|
10
|
+
maxDays: 31,
|
|
11
|
+
gzip: false,
|
|
12
|
+
},
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmRlZmF1bHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29uZmlnL2NvbmZpZy5kZWZhdWx0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlEQSxlQUFlO0lBQ2IsVUFBVSxFQUFFO1FBQ1Ysa0JBQWtCLEVBQUUsS0FBSztRQUN6QixpQkFBaUIsRUFBRSxJQUFJO1FBQ3ZCLGFBQWEsRUFBRSxHQUFHO1FBQ2xCLGlCQUFpQixFQUFFLElBQUk7UUFDdkIsV0FBVyxFQUFFLEVBQUUsR0FBRyxJQUFJLEdBQUcsSUFBSTtRQUM3QixRQUFRLEVBQUUsRUFBRTtRQUNaLGNBQWMsRUFBRSxNQUFNO1FBQ3RCLE9BQU8sRUFBRSxFQUFFO1FBQ1gsSUFBSSxFQUFFLEtBQUs7S0FDUTtDQUN0QixDQUFDIn0=
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
export { LogRotator, RotateFile, RotatorOptions };
|
|
1
|
+
import './config/config.default.ts';
|
|
2
|
+
import './app/extend/application.ts';
|
|
3
|
+
import './types.ts';
|
|
4
|
+
export * from './lib/rotator.ts';
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import "./config.default
|
|
2
|
-
import
|
|
3
|
-
import "./
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export { LogRotator };
|
|
1
|
+
import "./config/config.default.js";
|
|
2
|
+
import "./app/extend/application.js";
|
|
3
|
+
import "./types.js";
|
|
4
|
+
export * from "./lib/rotator.js";
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyw0QkFBNEIsQ0FBQztBQUNwQyxPQUFPLDZCQUE2QixDQUFDO0FBQ3JDLE9BQU8sWUFBWSxDQUFDO0FBRXBCLGNBQWMsa0JBQWtCLENBQUMifQ==
|
|
@@ -1,12 +1,8 @@
|
|
|
1
|
-
import { LogRotator, RotateFile, RotatorOptions } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
getRotateFiles(): Promise<Map<string, RotateFile>>;
|
|
9
|
-
_setFile(srcPath: string, files: Map<string, RotateFile>): void;
|
|
1
|
+
import { LogRotator, type RotateFile, type RotatorOptions } from './rotator.ts';
|
|
2
|
+
export declare class DayRotator extends LogRotator {
|
|
3
|
+
private filesRotateBySize;
|
|
4
|
+
private filesRotateByHour;
|
|
5
|
+
constructor(options: RotatorOptions);
|
|
6
|
+
getRotateFiles(): Promise<Map<string, RotateFile>>;
|
|
7
|
+
_setFile(srcPath: string, files: Map<string, RotateFile>): void;
|
|
10
8
|
}
|
|
11
|
-
//#endregion
|
|
12
|
-
export { DayRotator };
|