기본 콘텐츠로 건너뛰기

Blocking Method와 ThreadPool

Blocking Method

 블로킹 메서드는 다른 쓰레드로 제어권을 양도 하지 않고, 할당된 Task가 완료될 때까지 제어권을 넘겨주지 않으려 할 때 사용 하는 메서드 이다.

 Java에서 대표적인 블로킹 메소드는 InputStream 클래스의 read()와 ServerSocket 클래스의 accept()가 있다.

단점

  - 블로킹 메서드의 단점 중 하나는 무한 대기에 빠질 수 있다는 점이다. 이로 인해 대기중인 다른 쓰레드가 살행되지 않는 경우가 생길 수 있다.

Blocking I/O

  - java에서  블로킹 소켓은 ServerSocket, Socket 두 가지 클래스를 사용한다. 
  - 클라이언트 연결 요청시 서버는 accept하고 클라이언트와 연결된 소켓을 새로 생성하는데 이 때 해당 메서드가 완료되기 전까지 스레드에 블로킹이 된다. 
  - 클라이언트가 연결된 소켓으로 서버에 데이터 전송시 서버는 read를 호출하고 다 읽을 때 까지 스레드가 블로킹 된다. 
blocking io model에 대한 이미지 검색결과

병렬처리 문제

  - 데이터 입출력에서 스레드의 블로킹이 발생해 동시에 여러 클라이언트에 대한 처리가 불가하다.
  - 이를 해결위해 연결된 클라이언트 별로 각자 쓰레드를 할당하는 방법이 있다.
  - 클라이언트 접속요청 오면 서버는 새로운 스레드를 하나 생성하고 클라이언트에게 I/O 처리를 넘겨준다.
  - 동시 요청은 해결되었으나, 동시 접속으로 인한 스레드 생성, 할당, 제거하는 시간이 길어진다.
  - 또한 계속되는 스레드 생성은 힙 메모리의 부족을 야기할 수 있다.

스레드 풀(Thread Pool)

   - 스레드 증가로인한 메모리 부족을 피하기 위해 일정개수의 스레드를 풀에 미리 생성한다.
  - 클라이언트 요청이 들어오면 일단 작업 큐에 들어가게하고, 스레드 풀에서 스레드를 할당 받는다.
  - 스레드풀 사용시 스레드 생성, 제거에 대한 오버해드가 사라지고 동시접속을 처리할 수있다.
  - Java 에서는 java.util.concurrent.Executors에서 스레드 풀을 제공한다.
    1) newFixedThreadPool
      - parameter로 주어진 스레드 개수만큼 스레드를 생성하고, 애플리케이션 종료까지 유지한다.
    2) newChachedThreadPool
      - 처리할 작업이 많아지면 스레드를 증가하여 생성한다.
      - 놀고있는 스레드가 많다면 해당 스레드를 종료한다.
      - 스레드 개수를 유동적으로 조절. But 스레드가 많아지면 메모리 부족이 발생할 수도 있다.
    3) newSingleThreadExecutor
      - 스레드를 하나만 생성해 스레드가 비정상적으로 종료되면 하나의 스레드를 다시 생성한다.
    4) newSheduledThreadPool
      - 스레드와 관련된 작업을 특정 시간 이후에 실행되거나 주기적으로 작업을 실행할 수 있는 스레드 풀을 생성한다.

댓글

이 블로그의 인기 게시물

[스프링부트2.0 낚시게시판] 01. 프로젝트 생성 및 환경을 세팅해 보자

첫번째. 이클립스에서 프로젝트를 생성해 보자. 빠밤! 1. 이클립스 실행하고 프로젝트 생성하기  - 이클립스 실행 후 File -> New -> Spring Starter Project클릭 ( 부트는 Spring Starter Project로!! )        해당 프로젝트 설정을 본인의 입맛에 맞게? 해주자. 처음엔 저와 똑같이 하는게 삽질(?)의 노고를 덜 수 있으니 저 같은 초보 개발자 분들이나 이제 막 공부를 시작 하셧다면 위와 가이 설정 하는걸 추천.  - New Spring Starter Project Dependencies    - Spring Boot Version : 2.0.2    - Core : DevTools, Security, Lombok 클릭    - Web : web  클릭    - SQL : JPA, H2 클릭    - template Engines : Mstache   --> 타임리프(요즘 회사에서 많이 쓴다고해서)   - 그다음 다음 -> Finish 클릭하게 되면 Maven에 관한 프로젝트가 생성된다.   처음엔 메이븐 디펜던시부분을 받느라 시간이 걸릴수 있다. 프로젝트 구조는 스프링과 별반 차이가 없어 보인다 프로젝트 구조 관련해선 조만간 포스팅 해봐야 겠다. (요즘 책 읽을 시간도 없어서...😂) 두번째. 실행을 해보자.  스프링 부트2.0의 특징은 자체적으로 톰켓이 내장 되어 있어 따로 톰켓을 설정하는 부분이 없어서 아주 매우 편안하게 되었다.    - 실행은 src/main/java 밑에 com.fishing.board 패키지 밑에 FishBoardApplication.java 오른쪽 클릭 후...

[Spring] 웹 개발에 필요한 기본 정보들

이번 시간에는 웹 어플리케이션 개발에 필요한 기본 정보를 알아보려한다. MVC 패턴과 이 내용들을 잘 다룰줄 안다면 기본적인 웹 동작은 구현할 수 있을 것이다. 웹 애플리케이션의 종류 화면으로 응답하는 웹 애플리케이션 웹 페이지 형태로 클라이언트에 응답한다. 데이터로 응답하는 웹 애플리케이션 사용자 인터페이스와 데이터를 분리해서 취급하는 애플리케이션은 JSON or Xml을 사용해 데이터 형태로 클라인언트에 응답한다. 애플리케이션 설정 서블릿 컨테이너 설정 스프링 MVC를 이용해 웹 애플리케이션을 할때 ContextLoaderListener, DispatcherServlet, CharacterEncodingFilter를 서블릿 컨테이너에 등록해야 한다. 애플리케이션 컨텍스트 설정 MessageSource와 PropertySourcePlaceholderConfigurer의 빈 정의도 필요하다. 프런트 컨트롤러 설정 자바 기반설정은 @EnableWebMvc를 추가하면 된다. XML에선 <mvc:annotation-driven>요소룰 추하가면 된다. @Controller 구현 컨트롤러에서 구현하는 처리 내용 선언형 처리 : 메서드 시그니처를 참조해 프런트 컨트롤러가 하는 일 프로그래밍형 처리 : 컨트롤러 클래스의 메서드 안에 하는 일 분류 처리내용 선언형 요청매핑 요청 데이터 취득 입력값 검사 수행 프로그래밍형 입력값 검사 결과 확인 비즈니스 로직 호출 이동 대상 확인 및 데이터 연계 이동 대상 지정 컨트롤러 클래스 작성 @Controller public class WelcomController {   } POJO 클래스에 @Controller를 지정하면 다음 효과를 얻을 수 있다. 컴포넌트 스캔 기능을 사용해 DI 컨테이너에 빈으로 등록할 수 있다. 요청을 처리하는 메...

[자바 웹 프로그래밍]1장 첫번째 양파껍질 벗기기

자바 웹 프로그래밍 Next Step 책을 가지고 스터디를 시작했다. 1장은 학습 방향과 학습법에 관한 얘기인데, 나에게 와 닿은 부분을 남겨본다. 웹 개발자 공부 순서  웹을 처음 접했을 때 어디서부터 어느것 부터 공부해야하고 어떤 책을 봐야할지 매우 막막했던 기억이 있다. 본 책에서는 HTML --> CSS --> 자바스크립트 --> 자바 --> 자바웹프로그래밍 --> DB  이 순서로 학습 방향을 제시하고 있다. 백앤드 개발자로 가고 싶어 Spring 프로젝트를 몇차례 진행한 결론은 자바스크립트의 흐름은 어느정도 알고 있는게 도움이 된다는 결론이다.  다음으로 소프트웨어 학습하는 좋은 방법 몇가지가 나오는데, 그 중 내가 최근에 똑같이 느꼈던 것이 있어 적어본다. '일단 무엇인가 만들어보는 경험을 한 후 이론적인 개념을 학습하고, 다시 다음 단계 경험을 하고 이론적인 개념을 학습하는 과정을 반복하는 것이라 생각한다' 라는 구절이 나오는데, 최근 몇차례 Spring 프로젝트를 하면서, 이론에 대한 대략적인것을 기반으로 수많은 삽질과 성취를 이루고 난 다음, 삽질했던 부분을 책이나 인터넷 자료를 봤을때 부족했던 부분이 '아 이건 이렇게 쓰는거구나' 라는 것이 확실히 느낄 수 있었다. 전에는 무조건 '이론먼저 완벽하게 하고 프로젝트 하자!' 식이었는데 이는 경험상 별로 효과를 보지 못한것 같다(이론 금방 까먹는다.. 왜 써야 되는지 못느껴서). 책을 통한 학습  다음 몇가지 책을 추천했는데, 내가 읽은것과 앞으로 읽어봐야 할것을 나열하겠다. 1. 열혈강의 자바 웹 개발 워크북 - 엄진영  이 책 나에게 웹의 세계로 인도를 해주셧던 엄진영 강사님 책이다. 웹이 어떻게 나왔는지 부터 스트링 사용까지 차례대로 차근차근 따라할 수 있게 아주 잘 설명되고 좋은 소스코드를 제공하고 있다. 웹 처음이라면 반드시 볼것을 추천한다. 2. SQL 첫걸음 3. 코딩을 지탱하는 기술...