socket fd를 통해 chunked 데이터 처리 관련 질문
docker의 unix socket을 통해 event를 받아오려고 하는데 자꾸 chunked data가 0이 나오네요..;;
unix-socket(/var/run/docker.sock)과 connection 맺은 다음에 해당 fd를 epoll에 등록,
socket에 data가 올때마다 data를 읽으려고 했는데..
계속 socket read를 하면 chunked data의 length가 0이 나오고 호출한 api에 대한 응답이 끊기는것 같습니다.
원래 Transfer-Encoding: chunked일 때 0이 나오면 끝나는 것은 알고 있는데 왜 connection(?http connection)이 유지되지 못하고 0을 반환하고 끝나버리는지 도저히 모르겠네요..
socket 관련 설정을 아무리 변경해봐도 동작을 안합니다.
socket을 nonblocking socket으로 변경도 해보고, setsockopt으로 SO_KEEPALIVE 옵션도 줘봤는데
뭔가 document를 읽어봐도 이게 문제는 아닌것 같아서 질문 드립니다.
struct sockaddr_un server; server.sun_family = AF_UNIX; std::strcpy(server.sun_path, "/var/run/docker.sock"); if(connect(docker_fd, (struct sockaddr*) &server, sizeof(struct sockaddr_un)) < 0) { close(docker_fd); perror("failed to connect to docker.sock"); exit(EXIT_FAILURE); } int keep_alive = 1; if(setsockopt(docker_fd, SOL_SOCKET, SO_KEEPALIVE, &keep_alive, sizeof(keep_alive)) < 0){ perror("failed"); } int flag = fcntl(docker_fd, F_GETFL, 0); if(fcntl(docker_fd, F_SETFL, flag | O_NONBLOCK) < 0){ perror("failed"); }; char msg[] = "GET /events HTTP/1.1\nHost: docker\nAccept: */*\n\n"; if(send(docker_fd, msg, sizeof(msg), 0) < 0) { close(docker_fd); perror("failed"); }
events api를 보내놓고 응답이 왔을 때 다음과 같이 read를 했습니다..
char buffer[1024]; int temp = read(docker_fd, buffer, sizeof(buffer)-1); if(temp < 0){ close(docker_fd); perror("failed"); }
이러고 buffer를 찍어보면 chunked가 0이 찍히고 끝나버리네요..
HTTP/1.1 200 OK^MApi-Version: 1.39 Content-Type: application/json Docker-Experimental: false Ostype: linux Server: Docker/18.09.3 (linux) Date: Tue, 30 Jul 2019 08:50:12 GMT Transfer-Encoding: chunked 0
Transfer-Encoding: chunked 까지만 나오고 끝나야 맞을 것 같은데 0이..;;
chunked까지만 찍히고 그 이후에 버퍼에 쌓였을 때 epoll event 발생,
그 때 다시 소켓버퍼를 read하고 싶습니다.
뭔가 설정을 잘못했거나,
혹은 read를 하는 시점에 원래 connection(?)이 끊기고 streaming이 종료되는건지 궁금합니다.
고수님들 답변 부탁드려요~ㅠ
댓글 달기