트랜잭션에 궁금함이 있습니다.
329
작성한 질문수 37
- 단일 프로세스 환경이면 동기화로 처리하는 방법은 좋은 방법일까요?
tps가 많을 경우 속도 느려진다는 단점이 있을 것 같습니다.
tps 많다면 결국 서버를 늘려야 하겠죠. 그럼 결국 멀티 프로세스 환경으로 넘어가네요..ㅎㅎ... - 멀티 프로세스 환경(다중 서버)일 경우 어떤식으로 처리하는게 좋을까요?
- 강사님이 다른 질문에 올려주신 디비에 유니크 제약 조건을 이용하여 공통 예외 처리를 하는 내용도 봤습니다.
다른 서버에 데이터 등록 요청을 하지 않는다면 멀티 프로세스 환경에서도 좋은 방법인 것 같습니다.
다만 다른 서버에 데이터를 등록했으니 예외를 잡아 등록된 다른 서버 데이터를 삭제 요청 후 에러를 발생시키는게 좋은 방법일까요?
https://www.inflearn.com/questions/59250 - 강사님이 올려주신 디비 강의에 해당 관련 내용이 있는지도 궁금합니다. 있다면 어느 강의에서 볼 수 있을지도 궁금하네요.
- 강의에 없다면 어떤 키워드를 참고해서 검색하면 될지도 궁금하네요.
코드도 비슷하게나마 올려봅니다.
@Transactional
public synchronized void createUser(String username){
...
Optional<User> findUserOptional = repository.findByUsername(username);
if(!findUserOptional.isPresent()){
~~~ 블라블라 다른 서버에 데이터 등록(MSA 구조)
em.persist(user);
}else{
throw new RuntimeException("username already exists.");
}
...
}
답변 1
1
안녕하세요. 정민영님
실무에서는 장애 영향 등을 고려해서 항상 서버를 2대 이상 사용하기 때문에 synchronized 키워드를 사용해도 효과가 없습니다.
분산락, 보상트랜잭션을 검색해보시면 도움이 되실거에요.
감사합니다.
트랙잭션 격리수준 선택에 대해서 질문
0
25
1
spring initialiser 어떤걸 선택해야될지 모르겠어요
0
61
2
트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.
0
73
1
jdbc 학습하다 궁금해서 질문드려요
0
104
1
정상이체와 이체중 예외발생 차이
0
86
2
이번 강의부터가 JDBC 직접 사용 맞나요?
0
103
1
순수한 서비스 계층에 대한 의문???
0
94
2
3_4test, 4test 자동 리소스 안됨
0
66
2
데이터베이스 선택 관련 질문.
0
77
2
after 메서드 사용 유무
0
67
2
데이터베이스 접근 및 DB 락
0
65
1
@SpingBootTest, @TestConfiguration
0
68
1
Read Committed 격리 수준 사용 관련 질문
0
62
1
AopCheck Test 부분의 EnhancerBySpring 확인 법??
0
74
2
커리큘럼 관련 질문
0
85
1
서비서 계층 스프링 프레임워크 사용
0
100
1
validation(toMember)의 위치
0
91
2
데이터 계층에서 서비스 로직의 datasource를 인식하는 방법
0
178
2
member 상수 질문
0
140
2
ctrl + F6 이후로 con 인식이 안 됩니다
0
171
2
DrivenManager 와 Connection 반환에 대한 질문입니다!
0
121
1
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
127
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
107
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
105
1





