인프런 커뮤니티 질문&답변

chhun3830님의 프로필 이미지
chhun3830

작성한 질문수

스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술

동시 요청 - 멀티 쓰레드

웹서버,was 그리고 멀티쓰레드

해결된 질문

작성

·

470

0

안녕하세요, 열심히 강의 따라가고있는 학생입니다. 웹서버 was강의 보고 해당 강의보면서 궁금한게 생겼습니다.

웹서버,was 강의에서 그림으로 표현해 주시기를 여러개씩 그려주셨는데요. 그때는 서버가 여러개씩 있을 수 있구나 하면서 넘어갔는데 더 혼동이 와서요..

사용자가 웹페이지에 접속했을때

여러 서버가 있으면 어떤 서버에 있는 웹서버에 접속되는 건가요? 그럼 나머지 웹서버들은 어떻게 되는건가요?

그리고 여러 서버 중 접속 당한 서버는 비즈니스 로직을 처리할 때 어떤 was를 선택하는 건가요?

기준이 있는건가요?

그리고 멀티쓰레드 강의에서 was에서 이 멀티 쓰레드를 지원한다고했는데

만약 여러 웹서버와 was가 있고 제공되는 서비스는 쇼핑몰이라는 가정하에 두 명의 사용자가 각자 접속된 웹서버와 was가 다를때 한 개의 재고가 있는 제품을 구매하려고 한다면 어떻게 되는건가요? 이런것도 다 막아주는 어떤 서비스따로 있는건가요??

답변 1

1

안녕하세요, chhun3830 님! 공식 서포터즈 codesweaver 입니다.

서버를 여러개 두기 위해선 이 둘을 하나의 로드밸런서에 연결합니다. 사용자 요청이 로드밸런서에 도달하면, 로드밸런서 나름의 부하 체크 방법으로 여유가 있는 서버에 클라이언트 요청을 위임합니다.

 

마찬가지로 서버와 WAS 사이에도 로드 밸런서를 둘 수 있습니다. WAS와 데이터베이스 서버 사이에도 그렇습니다. (데이터베이스가 여러대가 될 경우에는 데이터베이스 사이의 동기화가 중요한 이슈가 됩니다)

 

만약 여러 웹서버와 was가 있고 제공되는 서비스는 쇼핑몰이라는 가정하에 두 명의 사용자가 각자 접속된 웹서버와 was가 다를때 한 개의 재고가 있는 제품을 구매하려고 한다면 어떻게 되는건가요? 이런것도 다 막아주는 어떤 서비스따로 있는건가요??

동시성 이슈는 보통 데이터베이스에서 트랜잭션 / 테이블 락 개념을 이용하여 해결합니다.

 

감사합니다.

chhun3830님의 프로필 이미지
chhun3830

작성한 질문수

질문하기