Inflearn brand logo image

인프런 커뮤니티 질문&답변

backendman님의 프로필 이미지
backendman

작성한 질문수

김영한의 실전 자바 - 고급 1편, 멀티스레드와 동시성

멀티스레드, 스프링mvc 관련하여 질문이 있습니다.

작성

·

81

0

@Service
public class PersonService {
public void processPerson(Person person) {

System.out.println("Processing person: " + person);

}

}

@Component
public class Common{

public void logging(Log log){

System.out.println("Processing person: " + person);

}

}

위 두 클래스는 스프링 빈으로 등록되고 싱글톤입니다.

싱글톤은 객체가 1개만 생성되는걸로 알고있습니다.

그럼 controller 단이나 외부에서 PersonService, Common 의 processPerson, logging 메서드들을 동시에 호출하면
2개의 스레드가 각 싱글톤 객체의 메서드 매개변수를 동시에 변경하니깐 스레드 세이프하지않은거 아닌가요?

 

스프링 mvc 구현할때 다 이렇게 하던데 이게 스레드 세이프한지 궁금합니다~!

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. backendman님.

싱글톤 빈은 어플리케이션 컨텍스트당 하나의 인스턴스만 존재하기 때문에 멀티스레드 환경에서 여러 스레드가 동일한 빈 인스턴스를 공유하게 됩니다. 하지만, 스프링에서 제공하는 대부분의 빈은 비즈니스 로직을 처리하는 범위 내에서는 안전하게 설계되어 있어 동시성 문제를 최소화합니다.

  1. 메서드 매개변수: 매개변수는 메서드의 일시적인 상태로 요청 스코프 내에서만 사용되기 때문에 안전합니다. 다른 스레드에서 접근할 수 없는 지역적인 상태이기 때문에 기본적으로 Thread-Safe합니다.

  2. 로컬 변수: 메서드 내에서 선언되는 로컬 변수는 각 스레드마다 독립적인 상태를 가지므로 동시성 문제와 관련이 없습니다.

  3. 싱글톤 빈의 필드: 공유 변수(필드)를 사용할 경우 동시성 문제가 발생할 수 있습니다. 이 경우, 스레드 안전성을 높이기 위해 Java의 synchronized 키워드나 더 나은 동시성 컨트롤 메커니즘을 고려할 수 있습니다.

스프링을 사용할 때의 일반적인 설계는, 싱글톤 빈이 상태 없는(stateless) 방식으로 동작하도록 구성하는 것입니다. 즉, 클래스가 특정 요청이나 스레드에 고유한 상태를 저장하지 않도록 설계합니다. 따라서, Mutable한 상태를 가지는 경우에는 주의를 기울여야 합니다.

관련 토론과 깊이 있는 설명은 아래 질문과 답변을 참고하시면 더욱 많은 정보를 얻을 수 있습니다:

위 자료를 참고하여 싱글톤 빈의 사용과 멀티쓰레드 환경에서의 설계에 도움을 받으시기를 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

backendman님의 프로필 이미지
backendman

작성한 질문수

질문하기