Node.js 를 이용 하여 파일 순환 복 사 를 어떻게 실현 합 니까?
이번에 Node.js 프로젝트 를 작성 할 때 로그 모듈 을 사 용 했 는데 작은 문제 가 발생 했 습 니 다.
이것 은 정시 에 자동화 작업 을 설정 할 수 있 는 프로젝트 이기 때문에 출력 정보 가 계속 증가 하고 로그 파일 이 시간 에 따라 계속 커진다 는 것 을 의미한다.로그 파일 크기 를 제어 하지 않 으 면 서버 의 디스크 가 조만간 가득 찰 것 입 니 다.그래서 파일 크기 를 제한 하 는 것 이 필요 합 니 다.
가장 이상 적 인 제어 방식 은 파일 크기 가 제한 을 초과 할 때 가장 먼저 기 록 된 데 이 터 를 지 우 는 것 이다.FIFO 와 유사 한 대기 열 입 니 다.
#
- 1 xxx
......
100 abc
#
+ 101 xxxx
log4js 의 file rolling기록 로그 라 고 하면 많은 Node.js 개발 자 들 이 log4js 를 찾 을 것 입 니 다.먼저 log4js 가 이 문 제 를 어떻게 처리 하 는 지 보 겠 습 니 다.
log4js 는 많은 appenders(로 그 를 기록 하 는 매개체 로 이해 할 수 있 음)로 나 뉘 는데 file rolling 기능 은 함수 로 설정 할 수 있 습 니 다.
file rolling 기능 은 날짜 와 파일 크기 두 가지 방식 이 있 습 니 다.
파일 크기 를 조절 하려 면 후 자 를 선택해 야 합 니 다.
이 기능 이 우리 의 요 구 를 만족 시 키 는 지 시험 하기 위해 서 순환 코드 를 써 서 로 그 를 씁 니 다.
const log4js = require('log4js')
// log4js
log4js.configure({
appenders: {
everything: {
type: 'file',
filename: 'a.log',
maxLogSize: 1000,
backups: 0
},
},
categories: {
default: {
appenders: ['everything'],
level: 'debug'
}
}
});
const log = log4js.getLogger();
for (let i = 0; i < 41; i++) {
const str = i.toString().padStart(6, '000000');
log.debug(str);
}
실행 후 두 개의 파일 a.log 와 a.log.1 을 생 성 합 니 다.그 중에서 a.log.1 은 20 줄 의 데이터 가 있 고 실제 크기 는 1kb 이 며 a.log 는 1 줄 의 데이터 만 있다.
파일 크기 를 확실히 제 어 했 지만 두 가지 문 제 를 가 져 올 수 있 습 니 다.
문자열 바 꾸 기?
메모리 에서 순환 복사 작업 을 완료 하려 면 문자열 이나 Buffer 를 사용 하면 됩 니 다.
예 를 들 어 파일 크기 를 1GB 로 제한 하고 로그 파일 10 개 를 동시에 기록 하면 최소 10GB 메모리 공간 을 차지 합 니 다!
메모리 가 디스크 공간 보다 더 귀중 하 다.이렇게 뚜렷 한 성능 문 제 는 분명히 가장 좋 은 해결 방법 이 아니다.
file roll
수요 에 따라 실현 절 차 를 두 단계 로 나 눌 수 있다.
파일 의 시작 부분 내용 을 삭제 할 수 없 으 니 생각 을 바 꾸 어 파일 의 끝 부분 만 유지 합 니 다(크기 제한 을 초과 하지 않 습 니 다).
뭐?이것 은 같은 뜻 이 아 닙 니까?
약간 차이 가 있어 요.
삭 제 는 기 존 파일 에서 이 루어 지 는 작업 이 며,보존 내용 은 임시 파일 을 통 해 이 루어 집 니 다.
그래서 생각 은:
쓰기 동작 에 대해 tail 명령 을 사용 하여 실현 할 수 있 습 니 다.최종 구현 코드 는 다음 과 같 습 니 다.
private write(name: string, buf?: Buffer | string) {
// append buf to tmp file
const tmpName = name.replace(/(.*\/)(.*$)/, '$1_\.$2\.tmp');
if (!existsSync(tmpName)) {
copyFileSync(name, tmpName);
}
buf && appendFileSync(tmpName, buf);
// if busy, wait
if (this.stream && this.stream.readable) {
this.needUpdateLogFile[name] = true;
} else {
try {
execSync(`tail -c ${limit} ${tmpName} > ${name}`);
try {
if (this.needUpdateLogFile[name]) {
this.needUpdateLogFile[name] = false;
this.write(name);
} else {
existsSync(tmpName) && unlinkSync(tmpName);
}
} catch (e) {
console.error(e);
}
} catch (e) {
console.error(e);
}
}
}
총결산이 기능 을 완성 하면 두 가지 깨 달 음 이 있다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Express + AWS S3 이미지 업로드하기웹 사이트 및 모바일 애플리케이션 등에서 원하는 양의 데이터를 저장하고 보호할 수 있다. 데이터에 대한 액세스를 최적화, 구조화 및 구성할 수 있는 관리 기능을 제공한다. AWS S3 에 저장된 객체에 대한 컨테이너...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.