작성
·
174
0
security config에서
SecurityContext 객체 저장 방식을
SecurityContextHolder.MODE.THREADLOCAL (스레드당 SecurityContext 객체를 할당)
그러니깐 부모스레드와 자식스레드 상호작용이 안된다는건데요.
여기까지 이해가 가는데
맨위에 이미지를 보시면
GET thread 호출시
스레드 안에서 해당 인증 객체가 안보이는게
왜 부모스레드와 자식스레드 상호작용이 안된다는 이유로
스레드 안에 해당 인증 객체가 없다는걸로 설명이 되는지 알고 싶습니다.
제가 스레드에 관련 기초적인 지식이 없어서 그런가요? ㅠㅠ
감사합니다.
답변 1
2
네
인증객체는 ThreadLocal 안에 저장이 되고 있습니다.
그리고 ThreadLocal 은 스레드 마다 고유하게 할당된 저장소 개념입니다.
즉 부모스레드와 자식스레드 각각 가지고 있죠
로그인 시 인증된 객체는 일반적으로 부모 즉 메인스레드에 할당된 ThreadLocal 에 저장이 됩니다.
자식 스레드의 ThreadLocal 에는 인증객체가 당연히 없습니다.
다시 설명하자면 부모스레드의 ThreadLocal 에 저장되어 있는 인증객체가 자식 스레드의 ThreadLocal 로 자동적으로 공유가 되지 않는다는 의미입니다.
그것이 SecurityContextHolder.MODE.THREADLOCAL 모드로 했을 때 처리 방식입니다.
그런데 SecurityContextHolder.MODE.INHERITABLETHREADLOCAL 로 했을 경우 부모스레드의 ThreadLocal 에 있는 인증객체를 자식스레드의 ThreadLocal 에도 저장해서 사용할 수 있도록 처리해 주고 있습니다.
이것을 상호작용이라는 의미로 표현한 것 뿐입니다.