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

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

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

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

[실습] User Microservice 만들기

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

✅ User Microservice 만들기

DB까지는 셋팅을 했으니 아래 구조에 맞게 User Service를 만들어보자.
notion image
 
 

✅ Spring Boot 프로젝트 셋팅 & DB 연결

  1. Spring Boot 프로젝트 셋팅
    1. start.spring.io
      https://start.spring.io/
      notion image
      • Artifact와 Name을 user-service라고 지어주자.
      • Package name을 Java 컨벤션에 맞게 userservice라고 지어주자.
      • Java 21 버전을 선택하자. 아래 과정을 Java 21 버전을 기준으로 진행할 예정이다.
      • Dependencies는 Spring Boot DevTools, Spring Web, MySQL Driver, Spring Data JPA를 선택하자.
       
  1. application.yml 작성하기
    1. 이 프로젝트에서는 application.properties를 지우고 application.yml을 생성했다.
      server: port: 8080 spring: datasource: url: jdbc:mysql://localhost:3306/user-db # DB 주소 username: root # DB 계정 password: password # DB 비밀번호 driver-class-name: com.mysql.cj.jdbc.Driver jpa: hibernate: ddl-auto: update show-sql: true
       
  1. Spring Boot 서버 실행시켜서 DB 연결 제대로 되는 지 확인하기
    1. Spring Boot 실행시켰을 때 아래와 같은 에러 안 뜨고 서버가 실행되면, 정상적으로 DB가 잘 연결된 것이다.
      notion image
       
 

✅ 회원가입 API 만들기

  1. User 엔티티 생성하기
    1. domain/User
      @Entity @Table(name = "users") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long userId; private String email; private String name; private String password; public User() { } public User(String email, String name, String password) { this.email = email; this.name = name; this.password = password; } public Long getUserId() { return userId; } public String getEmail() { return email; } public String getName() { return name; } public String getPassword() { return password; } }
       
  1. Repository 만들기
    1. domain/UserRepository
      public interface UserRepository extends JpaRepository<User, Long> { }
       
  1. Controller 만들기
    1. controller/UserController
      @RestController @RequestMapping("/users") public class UserController { private final UserService userService; public UserController(UserService userService) { this.userService = userService; } @PostMapping("sign-up") public ResponseEntity<Void> signUp( @RequestBody SignUpRequestDto signUpRequestDto ) { userService.signUp(signUpRequestDto); return ResponseEntity.noContent().build(); } }
       
  1. DTO 만들기
    1. dto/SignUpRequestDto
      public class SignUpRequestDto { private String email; private String name; private String password; public String getEmail() { return email; } public String getName() { return name; } public String getPassword() { return password; } }
       
  1. Service 만들기
    1. service/UserService
      @Service public class UserService { private final UserRepository userRepository; public UserService(UserRepository userRepository) { this.userRepository = userRepository; } @Transactional public void signUp(SignUpRequestDto signUpRequestDto) { User user = new User( signUpRequestDto.getEmail(), signUpRequestDto.getName(), signUpRequestDto.getPassword() ); this.userRepository.save(user); } }
       
  1. 서버 다시 실행시키기
    1. notion image
       
  1. API 잘 작동하는 지 테스트해보기
    1. notion image
 
  1. DB에 데이터 잘 들어갔는 지 확인하기
    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 입문/실전 강의의 수업 자료 중 일부입니다.