디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

kqueue와 epoll의 시스템 아키텍처 및 설계 철학 비교

나르시갤로그로 이동합니다. 2025.11.24 05:46:11
조회 98 추천 0 댓글 0

kqueue와 epoll의 시스템 아키텍처 및 설계 철학 비교 (Linux vs BSD)

서버 백엔드 개발에서 리눅스 환경은 epoll을, macOS 및 FreeBSD 등 BSD 계열은 kqueue를 I/O 멀티플렉싱 기술로 사용합니다. 본 글에서는 두 기술의 단순 성능 비교를 넘어, 시스템 아키텍처 관점에서의 설계 철학 차이를 분석합니다.

1. 모든 것은 파일이다(Everything is a File) 범용 이벤트 서브시스템의 차이

리눅스(epoll)는 유닉스의 모든 것은 파일이다라는 철학을 따릅니다. 이에 따라 소켓 외의 시스템 자원도 파일 디스크립터(File Descriptor, FD)로 추상화하여 관리합니다. * 타이머: timerfd * 시그널: signalfd * 이벤트: eventfd

이 방식은 read, close 등 표준 파일 API를 일관되게 사용할 수 있다는 장점이 있습니다. 그러나 파일이 아닌 객체를 관리하기 위해 FD를 생성해야 하므로 커널 메모리를 소비하고 FD 테이블의 슬롯을 점유하게 됩니다.

반면, BSD의 kqueue 범용 이벤트 통지 시스템(Generic Event Notification)으로 설계되었습니다. 파일 소켓, 타이머, 시그널, 프로세스 상태 변경 등을 모두 독립적인 '이벤트(kevent)'로 취급합니다. 따라서 파일이 아닌 이벤트를 감지하기 위해 별도의 FD를 생성할 필요 없이, 해당 이벤트에 맞는 필터(EVFILT_READ, EVFILT_TIMER, EVFILT_PROC)를 설정하여 처리합니다.

2. 상태 변경 시 시스템 콜 호출 구조: O(N) vs O(1)

다수의 감시 대상 상태를 변경해야 할 때, 두 시스템은 API 호출 구조에서 차이를 보입니다.

  • epoll: 기본적으로 epoll_ctl 시스템 콜을 사용하여 감시 대상을 추가하거나 수정합니다. 여러 대상을 수정하려면 대상의 수(N)만큼 시스템 콜을 호출해야 합니다. (단, epoll_wait는 이벤트 수신만 담당)
  • kqueue: kevent 함수는 이벤트의 등록과 수신(Poll)을 동시에 수행할 수 있도록 설계되었습니다. 변경 사항(changelist)을 배열로 구성하여 kevent 호출 시 한 번에 전달할 수 있으므로, 다수의 상태 변경 시 시스템 콜 호출 횟수를 최소화할 수 있습니다.

3. 자원 효율성: 타이머 처리 방식

타이머 구현 방식에서 자원 관리의 차이가 발생합니다.

  • epoll (Linux): 고해상도 타이머를 사용하기 위해 timerfd_create를 호출하여 FD를 생성해야 합니다. 대량의 클라이언트(예: 1만 개)에 대해 개별 타이머를 설정할 경우, 1만 개의 추가적인 FD가 생성되어 ulimit 제한에 도달하거나 커널 구조체 오버헤드가 발생할 수 있습니다.
  • kqueue (BSD): EVFILT_TIMER를 사용합니다. 이는 FD를 생성하지 않고 커널 내부의 타이머 기능을 직접 참조합니다. 따라서 사용자 프로세스는 FD 소모 없이 다수의 타이머 이벤트를 등록 및 관리할 수 있습니다.

4. 인터페이스 통합 수준 (Unified Interface)

이벤트 감지를 위한 API 구성에서도 차이가 있습니다.

  • Linux: 감시 대상에 따라 서로 다른 API를 사용해야 하는 경우가 많습니다.
    • 파일 변경 감지: inotify
    • 프로세스 상태 감지: waitpid 또는 signalfd
    • 소켓 I/O: epoll
  • BSD: kqueue 하나의 인터페이스로 다양한 이벤트를 통합 처리합니다.
    • 파일 변경 감지: EVFILT_VNODE
    • 프로세스 종료 감지: EVFILT_PROC
    • 시그널 감지: EVFILT_SIGNAL

5. 결론: 설계 접근 방식의 차이

kqueue struct kevent 구조체와 다형적인 필드(data, fflags)를 사용하여 초기 학습 비용이 높을 수 있습니다. 그러나 이는 다양한 이벤트를 단일 메커니즘으로 처리하기 위한 설계의 결과입니다.

요약하자면, 리눅스는 기존의 파일 디스크립터 모델을 확장하여 새로운 기능을 수용하는 방식으로 발전해 왔으며, BSD는 별도의 통합된 이벤트 서브시스템을 구축하는 방식을 택했습니다. 이러한 설계의 차이는 대규모 동시성 처리 및 자원 관리 효율성 측면에서 서로 다른 특성을 보입니다.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 이제는 의미 없어진 것 같은 시상식은? 운영자 25/12/01 - -
AD 따뜻한 겨울나기! 방한용품 SALE 운영자 25/11/27 - -
2905090 [한국전파진흥협회] 2026년 상반기 클라우드 아키텍처 전문가 양성과정 [1] 프갤러(14.32) 11.27 125 0
2905089 미국영어보단 영국영어발음이 쉽고 멋지지않냐? [5] 헬마스터갤로그로 이동합니다. 11.27 118 0
2905088 나님 왤케 특별하실깡? [1] ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 86 0
2905081 이재명이 잘하고있긴함 타이밍뒷.통수한방(1.213) 11.27 91 1
2905080 [대한민국] 차이나인에 대한 답글 1급시크릿공문(121.172) 11.27 61 0
2905079 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 84 0
2905078 [대한민국] FBI 부정선거 조사 착수와 메인 뉴스에 나오는 법조인들 1급시크릿공문(121.172) 11.27 79 0
2905076 회사에 다른오퍼를 빌미로 연봉협상 시도하는거 [13] 프갤러(112.219) 11.27 150 0
2905075 33세 남성 벌레인생 나같은 성욕부시레기도 결혼 가능하려나 ㅇㅇ(203.232) 11.27 96 0
2905073 이재명 대통령님 전자정부프레임워크를 러스트 기반으로 이전해주십 [4] 프갤러(110.8) 11.27 132 0
2905072 [대한민국] 이재명 때문에- [1] 1급시크릿공문(121.172) 11.27 95 1
2905070 개발자 새끼들이 씹덕 애니 프사 하는 이유는? [2] ㅇㅇ(211.235) 11.27 89 0
2905069 졸라 피곤하네..ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 11.27 59 0
2905067 오늘은 에러처리 패키지 구조를 잡아야겠어요 [2] 나르시갤로그로 이동합니다. 11.27 78 0
2905066 산책로 다리 ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 11.27 73 0
2905065 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 11.27 57 0
2905064 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 11.27 71 0
2905063 찬반논란인데 너희 생각은? ㅇㅇ(203.232) 11.27 79 0
2905061 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥냥덩이의우웅한하룽♥갤로그로 이동합니다. 11.27 108 0
2905060 이재명이 잘 하고 잇다는 증거.jpg [4] 야옹아저씨갤로그로 이동합니다. 11.27 136 1
2905058 죽은 인터넷 이론 발명도둑잡기(118.216) 11.27 86 0
2905057 음기 충전 발명도둑잡기(118.216) 11.27 116 0
2905056 북한학자 조희승의 가야사- 임나는 한반도가 아닌 일본 서부지역에 발명도둑잡기(118.216) 11.27 48 0
2905053 영화 <프랑스> 인기래서 생각나는 예전 글 발명도둑잡기(118.216) 11.27 62 0
2905047 내가 예술계 새 트렌드 알려준다 발명도둑잡기(118.216) 11.27 70 0
2905042 지금 분위기가 프갤러(49.165) 11.27 100 0
2905041 Le Solitaire. Theo Mercier 발명도둑잡기(118.216) 11.27 64 0
2905040 DB는 조인을 안하는게 걍 최선인듯 [2] 프갤러(58.29) 11.27 117 0
2905038 책사풍후의 게임 엔진 개발 일지_프로젝트 삼국사기 책사풍후갤로그로 이동합니다. 11.27 92 0
2905036 씨발국가 완전 중국 다 되었네 이딴 병신같은걸로 전과 ㅋㅋㅋㅋ ㅇㅇ(39.7) 11.27 122 0
2905034 ai는 코드를 낳고 ㅇㅇ갤로그로 이동합니다. 11.27 81 1
2905033 노력한 보상을 갈취당하고 주식이란 도박에 몰두하는 시민들 발명도둑잡기(118.216) 11.27 76 0
2905027 위성 쏘는 이유가 나오는 영화 <에너미 오브 더스테이츠> [1] 발명도둑잡기(118.216) 11.27 105 0
2905025 국내에 외국계 기업 특 ) 짱깨랑 양키랑 좇본 인도 대기업들 몰렸는데 타이밍뒷.통수한방(1.213) 11.27 89 0
2905023 윤도현-타잔 발명도둑잡기(118.216) 11.27 65 0
2905022 위성 싸서 좋은점은 짱깨들밖에없잖누 ㅋㅋㅋㅋㅋ 타이밍뒷.통수한방(1.213) 11.27 65 0
2905021 위성 쏘는 이유 중 하나가 야당 감시다 발명도둑잡기(118.216) 11.27 64 0
2905017 내일 또 클리앙새끼를 누리호 ㅇㅈㄹ하면서 난리치겠누 [1] 타이밍뒷.통수한방(1.213) 11.27 91 0
2905015 냥덩이 잡아다가 누리호에 묶어서 쏴올렸다는데? 발명도둑잡기(118.216) 11.27 72 0
2905014 누리호 궤도 진입 성공 대 실패 예상 댓글좀 발명도둑잡기(118.216) 11.27 66 0
2905013 오늘의 영상 기획 실마리: 작품 발표를 로케트 발사처럼 패러디 발명도둑잡기(118.216) 11.27 60 0
2905010 조선이 위성을 쏘아도 한국은 도발이라고 표현하는데 발명도둑잡기(118.216) 11.27 72 0
2905009 법무부 영문 표기가 Ministry of Justice 발명도둑잡기(118.216) 11.27 72 0
2905008 DB 검색할 때 %like%는 걍 없다고 생각하고 써야함? [3] 프갤러(58.29) 11.27 95 0
2905006 이거 항소하면 무죄 내지는 벌금50까지 줄여지냐? 씨발국가야? ㅇㅇ(39.7) 11.26 117 2
2905005 대통령보다 연봉높은 우주청 현실 [1] 타이밍뒷.통수한방(1.213) 11.26 182 0
2905004 개인 자격으로 인공위성 만들어 발사한 미디어아티스트 송호준 [1] 발명도둑잡기(118.216) 11.26 57 0
2905003 해외기사들보면 삼성 lg제품 존나 광고하네 타이밍뒷.통수한방(1.213) 11.26 139 0
2905002 소프트웨어 엔지니어의 몰입 손발이시립디다갤로그로 이동합니다. 11.26 72 0
2905001 [공식] 누리호 4차 발사 현장 생중계 발명도둑잡기(118.216) 11.26 45 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2