스프링 websocket handler presend 질문 있습니다.

24.03.15 18:32 작성 조회수 35

0

public Message<?> preSend(Message<?> message, MessageChannel channel) {
		log.info("presend 실행은 되는지");
	    StompHeaderAccessor accessor = StompHeaderAccessor.wrap(message);
	    log.info("테스트{}",accessor.getCommand());
//	    // 메시지의 구독 명령이 CONNECT인 경우에만 실행
	    if (StompCommand.CONNECT.equals(accessor.getCommand())) {
	      StompHeaderAccessor headerAccessor = StompHeaderAccessor.wrap(message);
	      log.info("구독 명령이 떨어졌어{}",headerAccessor.getNativeHeader("test"));
	    }

	    return message;
	  }

위 코드처럼 실행했을 시 accessor.getCommand()가 connect거나 disconnect면

log.info("presend 실행은 되는지");
	    StompHeaderAccessor accessor = StompHeaderAccessor.wrap(message);
	    log.info("테스트{}",accessor.getCommand());

이것이 2번 씩 출력되는데 원래 이런건지 아니면 제가 코딩을 잘못했는지 질문있습니다.

답변 1

답변을 작성해보세요.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.03.16

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

Spring에서 WebSocket을 사용할 때 preSend 메소드가 예상치 못하게 두 번 호출되는 경우가 있을 수 있습니다. 이는 Spring의 내부 동작 방식에 따라 결정되는 부분이기도 하고, 코드나 구성에 따라 발생할 수도 있습니다. preSend 메소드는 메시지가 실제로 전송되기 전에 호출되며, 메시지를 수정하거나 다른 작업을 수행할 수 있는 후크 포인트를 제공합니다.

이중으로 로그가 출력된다면, 일단 두 가지 가능성을 살펴볼 수 있습니다.

  1. 클라이언트 쪽에서 CONNECT 및 DISCONNECT 프레임이 의도치 않게 두 번 전송되고 있을 수 있습니다. 이 경우에는 네트워크 트래픽을 캡쳐하거나 클라이언트 측 로직을 검토하여 확인할 수 있습니다.

  2. 서버 측에서 어떠한 이유로 같은 메시지에 대해 preSend를 두 번 호출하는 것일 수도 있습니다. 이 경우에는 서버의 코드 또는 구성을 재검토하여 문제가 되는 부분을 찾아야 합니다.

preSend가 두 번 호출되는 것이 의도된 행동인지 혹은 버그인지를 확인하려면 디버깅을 통해 추가적인 정보를 수집하고 분석해야 할 것입니다. preSend에서 같은 메시지에 대해 두 번의 호출이 일어나는 상황을 디버그해서 어떤 경로로 메소드가 실행되는지, 그리고 그 원인이 무엇인지를 확인해 보세요. Spring Framework의 rich WebSocket support 문서를 참고하면 preSend와 관련된 더 자세한 정보를 확인할 수 있습니다.

추가적으로, ‘spring-boot-starter-websocket’ 모듈의 자동 구성과 관련된 자세한 내용은 Spring Boot Reference Documentation의 WebSockets 절에서 찾아볼 수 있습니다. 이 문서에서는 Spring Boot가 제공하는 WebSocket 관련 자동 구성 및 설정에 대한 정보를 제공하고 있으니 이를 참고하시면 좋을 것 같습니다.

만약 문제가 지속된다면 더 자세한 로그 정보, 사용된 구성, 클라이언트 및 서버 측 코드의 나머지 부분 등을 함께 제공해주시면 문제 해결에 더 도움이 될 것입니다.