>Java >Java베이스 >자바 리액터 리액터 패턴

자바 리액터 리액터 패턴

Guanhui
Guanhui앞으로
2020-06-24 18:09:432112검색

자바 리액터 리액터 패턴

리액터 리액터 패턴

지금까지 고성능 네트워크 프로그래밍에서는 리액터 패턴을 피할 수 없었습니다. 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으로 문의하시기 바랍니다. 삭제