> Java > Java베이스 > 본문

자바 리액터 리액터 패턴

Guanhui
풀어 주다: 2020-06-24 18:09:43
앞으로
2064명이 탐색했습니다.

자바 리액터 리액터 패턴

리액터 리액터 패턴

지금까지 고성능 네트워크 프로그래밍에서는 리액터 패턴을 피할 수 없었습니다. Nginx, Redis, Netty 등 많은 유명한 서버 소프트웨어나 미들웨어가 리액터 모드를 기반으로 구현됩니다.

리액터 패턴은 고성능 네트워크 프로그래밍을 위해서는 꼭 알아야 할, 꼭 알아야 할 패턴입니다.

리액터 소개

리액터 패턴은 두 가지 주요 역할로 구성됩니다: 리액터 리액터 스레드와 핸들러 프로세서:

(1) 리액터 리액터 스레드의 책임: IO 이벤트에 응답하고 이를 핸들러 프로세서에 배포하는 역할 .

(2) 핸들러 프로세서의 책임: 비즈니스 처리 논리의 비차단 실행.

위의 리액터 패턴 정의에서 우리는 이 패턴에 대해 어떤 마술적인 점도 볼 수 없습니다. 물론 리액터 패턴에는 단순한 버전부터 복잡한 버전까지 다양한 버전이 있습니다. 이전 정의에 따르면 이는 가장 간단한 버전일 뿐입니다.

다중 스레드 OIO의 치명적인 결함

Java의 OIO 프로그래밍에서 독창적이고 가장 원시적인 네트워크 서버 프로그램은 while 루프를 사용하여 포트에서 새로운 연결을 지속적으로 모니터링합니다. 그렇다면 처리 함수를 호출하여 완료합니다. 샘플 코드는 다음과 같습니다.

@Test
 public void client() throws IOException {
   Socket client = new Socket("127.0.0.1", 9999);
   Writer writer = new OutputStreamWriter(client.getOutputStream());
   writer.write("Hello World");
   writer.flush();
   writer.close();
   client.close();
 }
 
 @Test
 public void server() throws IOException {
   ServerSocket server = new ServerSocket(9999);
   while (true){
     Socket socket = server.accept();
     Reader reader = new InputStreamReader(socket.getInputStream());
     print(reader);
     reader.close();
     socket.close();
     server.close();
   }
 }
로그인 후 복사

이 방법의 가장 큰 문제는 이전 네트워크 연결의 핸들(소켓)이 처리되지 않은 경우 후속 연결 요청입니다. 수신할 수 없으므로 이후의 모든 요청이 차단되고 서버의 처리량이 너무 낮아집니다. 서버의 경우 이는 심각한 문제입니다.

추천 튜토리얼: "Java"

위 내용은 자바 리액터 리액터 패턴의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:jb51.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿