tcp (7) 썸네일형 리스트형 [Java] WAS의 Keep-Alive 구현 - TCP 연결과 해제 비용 줄이기 문제 발생 시나리오 이제까지 내가 구현한 초기 웹서버 모델은 하나의 TCP 연결에 대해서 하나의 요청을 처리하는 구조이다. 일단 나는 WAS의 초기 모델을 구현했을때, HTTP Keep-Alive에 대해서는 이론적으로만 어느정도 알고 있었다. 실제로는 어떻게 동작하는지는 몰랐었다. 내가 개발한 WAS를 크롬 브라우저로 테스트하기위해서 index.html파일을 GET 요청해보았다. 해당 index.html파일은 8개의 이미지 페이지 로딩이 필요했다. Hello Client! 서버의 요청 처리 결과크롬 브라우저로 요청을 날려보니, WAS에게 요청하기 위해서 병렬로 최대 6개의 연결을 맺는것을 로그로 확인하였다.아래는 클라이언트와 연결된 소켓 6개에 대한 로.. [Java] WAS의 HTTP 버전에 따른 확장성 구현 (2): 요청 메세지 파싱 객체 설계 내가 직접 구현중인 WAS의 HTTP 버전을 공통으로 처리하는 구조에서 요청 메세지의 파싱하는 객체를 설계하고 적용할려고한다. 이때 해당 객체를 설계하고 적용할려는 과정에서 겪게되는 문제를 해결하는 과정을 쓴 글이다. 공통의 구조로 여러 HTTP 버전을 처리할수 있다면, 재사용성과 확장성이 확보되어 유지보수하기 좋을것이다. 여기서 각 객체의 역할은 공통적이어야 한다. 이때 인터페이스를 정의하고 구현체를 외부에서 주입(Dependency Injection)하여, 객체 간의 결합도를 낮추고 코드의 유연성 및 재사용성을 높일수 있다.1. HTTP 버전에 따른 파싱 로직 파악하기WAS의 HTTP 버전에 따른 확장성 구현 (1) - HTTP1.1과 HTTP2.0의 메세지 전송 포맷과 방식 차이 이해에서 HTTP/.. WAS의 HTTP 버전에 따른 확장성 구현(1) - HTTP1.1과 HTTP2.0의 메세지 전송 포맷과 방식의 차이 이해 1. HTTP/1.1과 HTTP/2.0의 메세지 전송 포맷의 차이HTTP/1.1과 HTTP/2.0은 메세지의 전송 포맷과 방식이 다르다. 텍스트 기반의 HTTP/1.1 메시지 포맷HTTP/1.1에서 메세지는 텍스트 기반 메세지이며, header와 body를 CRLF(\r\n)으로 구별한다. 따라서 HTTP/1.1 메세지를 전달 받은 웹 서버는 텍스트 단위로 파싱을 수행해야한다. 바이너리 프레임 기반의 HTTP/2.0 메시지 전송 포맷과 헤더 압축반면, HTTP/2.0에서는 메세지가 바이너리 프레임 단위로 나뉘어 전송되며, header frame와 data frame으로 구분된다. 따라서 바이너리 형식으로 인코딩된 프레임을 전달받은 웹서버는 바이너리 디코딩을 해서 파싱을 해야한다. 그리고 HTTP/1... [Java] WAS 구현- HTTP/1.1 Keep-Alive 구현 후 서버가 응답을 보내기 전에 연결이 끊기는 이슈 사건의 발단내가 구현한 HTTP 웹서버의 성능을 간단하게 테스트하고자 했다. 그중에서 HTTP Persistent Connection 기능을 구현한 것에 대해서 테스트를 해볼려했다. 처음에는 Apache Bench(ab)를 사용해서 테스트를 해보았지만, 소켓 연결을 유지한채로 여러 요청을 보내는 기능은 제공하지않았다. 그래서 HTTP Persistent Connection 성능 테스트를 지원하는 WRK을 사용하였다. WRK란?wrk is a modern HTTP benchmarking tool capable of generating significant load when run on a single multi-core CPU. It combines a multithreaded design with sca.. [Java] WAS 구현 - Request line 읽기시, 예상치 못한 EOF 반환값 이슈 HTTP/1.1 Request line 읽기시, 예상치못한 EOF 반환값 발생1. 발생한 문제의 경로 파악SocketInputStream이 주입된 BufferedReader의 readLine() 메서드로 HTTP/.1.1 요청 메세지의 첫줄인 request line을 읽었을때 null값이 발생했다.public HttpRequest(InputStream in) { try { BufferedReader br = new BufferedReader(new InputStreamReader(in)); String line = br.readLine(); if (line == null) { throw new IllegalStateException("Requ.. [Java] 1. HTTP 웹 서버 구현 - 클라이언트 요청 처리 난 이전에 잠시나마 병특으로 시스템 엔진니어로 일하면서 Apache, Nginx, Tomcat를 설치하곤 했다. 이때는 설치 위주의 업무이기 때문에 소스코드을 들여다 볼일이 없었다. 그렇기에 소프트웨어 엔진니어 관점이 아니며 동작원리를 모른채로 물에 붕뜬 느낌이 많이 들었다. 소스코드 수준에서 알아야 비로써 이해가 되기때문에 직접 웹서버를 구현해볼려고한다. HTTP를 지원하는 간단한 웹서버를 단계적으로 발전시켜나갈 생각이다. 이 글에서는 HTTP 웹서버 구현 중 클라이언트의 요청을 처리하는 기능만 구현해볼것이다. HTTP 웹 서버 구현 사항 및 주요 기술HTTP 웹 서버 구현할 사항Java로 HTTP 웹서버 구현클라이언트 요청에 대해 "Hello Client!" 를 응답웹서버 동작에 대한 간단 로깅HTT.. [JDBC] Connection에 대한 고찰 자바 애플리케이션 서버와 DB 서버와의 연결을 위해 JDBC Driver로부터 Connection 구현체를 반환받는다. 과면 이 구현체는 무엇이며, 어떠한 연결인지 알아보고자하였다. 아래의 내용부터는 연결이 성립되는 과정을 순차적으로 작성하였다.애플리케이션 서버와 DB 서버의 통신과 연결JDBC ConnectionJava 애플리케이션에서 여러 DB간의 접근을 위하여, JDBC 라이브러리는 Driver 인터페이스를 제공한다. 그리고 DB 벤더사들은 Driver 구현체를 라이브러리에 내포시켜 제공한다. 다음은 H2 라이브러리의 Driver 구현체 코드이다.package org.h2;public class Driver implements java.sql.Driver, JdbcDriverBackwardsComp.. 이전 1 다음