Post

[멋쟁이사자처럼 백엔드 스쿨] 은행 시스템 개선: thread & logging 기능 추가

[멋쟁이사자처럼 백엔드 스쿨] 은행 시스템 개선: thread & logging 기능 추가

학습을 목표로 자바 프로젝트를 진행하고 있습니다.

file read, write 기능을 활용한 은행 오픈, 마감 기능 추가

파일 입출력 유틸 작성

파일 입출력 작성 시 https://github.com/eun2ce/likelion/blob/main/lionbank/src/main/java/org/lionbank/util/FileReaderTask.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
package org.lionbank.util;

import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;

public class FileReaderTask extends Thread {
  private String logMessage;  // 로그 메시지
  private static final String LOG_FILE = "log.txt";  // 로그 파일 경로

  // 생성자, 로그 메시지를 받아서 설정
  public FileReaderTask(String logMessage) {
    this.logMessage = logMessage;
  }

  // 쓰레드 실행 시 로그를 파일에 기록
  @Override
  public void run() {
    writeLogToFile(logMessage);
  }

  // 로그를 파일에 작성하는 메서드
  private void writeLogToFile(String message) {
    try (BufferedWriter writer = new BufferedWriter(new FileWriter(LOG_FILE, true))) {
      // 현재 시간 얻기
      String timestamp = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
      // 로그 내용 작성
      writer.write("[" + timestamp + "] " + message);
      writer.newLine();
    } catch (IOException e) {
      System.out.println("로그 파일을 작성하는 중 오류가 발생했습니다: " + e.getMessage());
    }
  }
}

결과

아래와 같은 내용이 log.txt 파일에 남는다.

fetch logfile

자세한 패치 내용은 이 곳을 참고해주세요.

This post is licensed under CC BY 4.0 by the author.