JSCODE Logo
프로그래밍 과외블로그후기멘토진
회사명 : JSCODE대표 : 박재성사업자 등록번호 : 244-22-01557통신판매업 : 제 2023-인천미추홀-0381 호
학원 명칭 : 제이에스코드(JSCODE)원격학원학원설립ㆍ운영 등록번호 : 제6063호

서울특별시 구로구 경인로 20가길 11(오류동, 아델리아)

Copyright ⓒ 2025 JSCODE - 최상위 현업 개발자들의 프로그래밍 교육 All rights reserved.

이용약관개인정보처리방침
← 블로그 목록으로 돌아가기

[실습] 사용자 서비스에서 Kafka로 ‘회원가입 완료 이벤트’ 발행하기

JSCODE 박재성
JSCODE 박재성
2025-12-06
author
JSCODE 박재성
category
MSA
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 MSA 입문/실전
slug
practice-publish-signup-event
type
post
updatedAt
Dec 6, 2025 05:43 AM

✅ 사용자 서비스에서 Kafka로 ‘회원가입 완료 이벤트’ 발행하기

게시글 서비스에서 사용해야 하는 사용자 데이터(user_id, name)를 동기화하기 위해서, 사용자 서비스에서 user_id, name의 데이터가 생성/변경/삭제가 될 때마다 카프카로 이벤트를 발행해주어야 한다. 현재 프로젝트에서는 사용자 데이터를 생성하는 회원가입 API가 구현되어 있다. 따라서 데이터 동기화를 위해 회원가입 API에 이벤트 발행 로직을 추가해보자.
notion image
 
 

✅ 코드 작성하기

user-service에서 아래 코드 작성하기
  1. application.yml에 Kafka 설정 추가해주기
    1. server: port: 8080 spring: datasource: url: jdbc:mysql://localhost:3306/user-db username: root password: password driver-class-name: com.mysql.cj.jdbc.Driver jpa: hibernate: ddl-auto: update show-sql: true kafka: # Kafka 서버 주소 bootstrap-servers: localhost:9092 consumer: key-deserializer: org.apache.kafka.common.serialization.StringDeserializer value-deserializer: org.apache.kafka.common.serialization.StringDeserializer producer: key-serializer: org.apache.kafka.common.serialization.StringSerializer value-serializer: org.apache.kafka.common.serialization.StringSerializer client: point-service: url: http://localhost:8082
       
  1. Kafka로 전달할 메시지 객체 만들기
    1. event/UserSignedUpEvent
      public class UserSignedUpEvent { private Long userId; private String name; public UserSignedUpEvent(Long userId, String name) { this.userId = userId; this.name = name; } public Long getUserId() { return userId; } public String getName() { return name; } }
       
  1. 회원 가입을 완료하는 대로 Kafka 메시지 발행하도록 처리하기
    1. service/UserService
      @Service public class UserService { private final UserRepository userRepository; private final PointClient pointClient; private final KafkaTemplate<String, String> kafkaTemplate; public UserService(UserRepository userRepository, PointClient pointClient, KafkaTemplate<String, String> kafkaTemplate) { this.userRepository = userRepository; this.pointClient = pointClient; this.kafkaTemplate = kafkaTemplate; } @Transactional public void signUp(SignUpRequestDto signUpRequestDto) { User user = new User( signUpRequestDto.getEmail(), signUpRequestDto.getName(), signUpRequestDto.getPassword() ); User savedUser = this.userRepository.save(user); // 회원가입하면 포인트 1000점 적립 pointClient.addPoints(savedUser.getUserId(), 1000); // '회원가입 완료' 이벤트 발행 UserSignedUpEvent userSignedUpEvent = new UserSignedUpEvent( savedUser.getUserId(), savedUser.getName() ); this.kafkaTemplate.send( "user.signed-up", toJsonString(userSignedUpEvent) ); } // 객체를 Json 형태의 String으로 만들어주는 메서드 // (클래스로 분리하면 더 좋지만 편의를 위해 메서드로만 분리) private String toJsonString(Object object) { ObjectMapper objectMapper = new ObjectMapper(); try { String message = objectMapper.writeValueAsString(object); return message; } catch (JsonProcessingException e) { throw new RuntimeException("Json 직렬화 실패"); } } ... }
       
  1. 서버 다시 실행시키기
    1. notion image
 
author
JSCODE 박재성
category
MSA
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 MSA 입문/실전
slug
type
series-footer
updatedAt
Dec 6, 2025 05:45 AM
📎
이 글은 비전공자도 이해할 수 있는 MSA 입문/실전 강의의 수업 자료 중 일부입니다.