mod_isapi - Apache HTTP Server Version 2.4

Apache Server 2.4

<-

아파치 모듈 mod_isapi

이 문서는 최신판 번역이 아닙니다. 최근에 변경된 내용은 영어 문서를 참고하세요.
설명:Windows용 아파치에서 ISAPI Extension 사용
상태:Base
모듈명:isapi_module
소스파일:mod_isapi.c
지원:Win32 only

요약

이 모듈은 Internet Server extension API를 구현한다. 그래서 제약은 있지만 Windows용 아파치에서 Internet Server extension을 (즉, ISAPI .dll 모듈) 사용할 수 있다.

ISAPI extension 모듈(.dll 파일)은 제삼자가 작성한다. Apache Group이 이들 모듈을 만들지 않았으며, 지원도 하지 않는다. ISAPI extension 사용에 관한 문제는 ISAPI 제작자에게 직접 연락하길 바란다. 제발 이런 문제를 아파치 메일링리스트나 버그보고 페이지에 올리지 마라.

top

사용법

서버설정파일에서 AddHandler 지시어를 사용하여 ISAPI 파일 확장자와 isapi-handler 핸들러를 연결한다. .dll 파일을 ISAPI extension으로 처리하려면 httpd.conf 파일에 다음과 같이 추가한다.

AddHandler isapi-handler .dll

아파치 서버는 요청한 모듈을 메모리에 계속 둘 수 없다. 그러나 httpd.conf에서 다음과 같은 설정으로 특정 모듈을 미리 읽어들일 수는 있다.

ISAPICacheFile c:/WebWork/Scripts/ISAPI/mytest.dll

ISAPI extension을 미리 읽어들이던지 미리 읽어들이지 않던지 관계없이 ISAPI extension은 CGI 스크립트와 동일한 권한과 제약을 따른다. 즉, ISAPI .dll 파일이 있는 디렉토리에 Options ExecCGI가 필요하다.

mod_isapi의 ISAPI 지원에 대한 자세한 내용과 설명은 추가 설명개발자 정보를 참고하라.

top

추가 설명

아파치 ISAPI 구현은 비동기 입출력에 대한 "마이크로소프트 특유의" 확장기능을 제외한 ISAPI 2.0 규약을 모두 만족한다. 아파치의 입출력 구조로는 ISAPI가 사용할 수 있는 방식으로 비동기 입출력을 할 수 없다. ISA가 비동기 입출력과 같이 지원하지 않는 기능을 사용하려 한다면, 디버깅에 도움을 주기위해 오류 로그에 기록을 남긴다. 로그가 매우 커질 수 있기때문에 ISAPILogNotSupported Off 지시어를 사용하면 로그에 기록하지 않는다.

Microsoft IIS와 같은 서버는 ISAPI extension을 메모리로 읽어들여서 메모리 사용량이 매우 많지 않거나 특별히 설정하지 않는한 그대로 메모리에 둔다. 아파치는 현재 ISAPICacheFile 지시어를 사용하지 않는다면 요청을 받을때마다 ISAPI extension을 메모리에 읽어들이고 버린다. 비효율적이지만, 아파치의 메모리 구조상 이것이 가장 효율적인 방법이다. 여러 ISAPI 모듈이 아파치 서버와 약간 호환이 안맞기때문에 서버의 안정성을 위해 모듈을 메모리에서 버린다.

또, 아파치는 ISAPI Extension을 지원하지만, ISAPI Filter를 지원하지 않음을 기억하라. 나중에 필터를 지원할 수 있지만, 현재는 계획이 없다.

top

개발자 정보

아파치 2.0 mod_isapi 모듈을 프로그래밍한다면, ServerSupportFunction 호출을 다음 지시어로 제한해야 한다.

HSE_REQ_SEND_URL_REDIRECT_RESP
사용자를 다른 위치로 리다이렉션한다.
완전한 URL을 사용해야 한다 (예를 들어, http://server/location).
HSE_REQ_SEND_URL
사용자를 다른 위치로 리다이렉션한다.
완전한 URL이 아니며, 프로토콜과 서버명을 넘길 수 없다 (예를 들어, /location같은 것만 가능).
브라우저가 아니라 서버가 리다이렉션을 처리한다.

경고

최근 문서를 보면 Microsoft가 두 HSE_REQ_SEND_URL 기능간의 차이를 없앤 것처럼 보인다. 아파치는 계속 이 둘의 아규먼트 조건과 행동을 다르게 처리할 것이다.

HSE_REQ_SEND_RESPONSE_HEADER
headers 문자열 아규먼트에 빈줄이 (줄바꿈문자가 두번 연속) 있다면 아파치는 헤더 다음 내용을 응답 내용으로 사용한다. headers 아규먼트가 NULL로 끝나기때문에, 응답 내용에 NULL을 사용할 수 없다.
HSE_REQ_DONE_WITH_SESSION
ISAPI가 처리를 마치면 세션이 끝나기때문에 아파치는 아무 일도 하지 않는다.
HSE_REQ_MAP_URL_TO_PATH
아파치는 가상 이름을 물리적(실제) 이름으로 변환한다.
HSE_APPEND_LOG_PARAMETER
문구를 아래 로그중 한곳에 남긴다.

첫번째로 나온 %{isapi-parameter}n 항목은 언제나 사용할 수 있으며 권장한다.

HSE_REQ_IS_KEEP_CONN
협상된 Keep-Alive 상태를 반환한다.
HSE_REQ_SEND_RESPONSE_HEADER_EX
fKeepConn 옵션을 무시하는 것을 제외하고는 문서에 나온데로 동작한다.
HSE_REQ_IS_CONNECTED
요청이 중간에 끊어졌다면 false를 반환한다.

지원하지 않는 ServerSupportFunction 호출을 하면 아파치는 FALSE를 반환하고 GetLastError 값을 ERROR_INVALID_PARAMETER로 설정한다.

ReadClient는 (ISAPIReadAheadBuffer로 정의한) 초기버퍼크기를 넘어선 요청 내용을 가져온다. ISAPIReadAheadBuffer 설정 (ISAPI 핸들러를 부르기전 버퍼의 바이트수) 보다 짧은 요청은 extension을 부를때 전부 전달된다. 요청이 길면, ISAPI extension은 ReadClient로 나머지 요청 내용을 가져와야 한다.

WriteClient를 지원하지만, HSE_IO_SYNC 옵션만 사용하거나 (0 값) 아무 옵션도 사용하지 않아야 한다. 다른 WriteClient 요청은 FALSE를 반환하며 실패하고, GetLastError 값은 ERROR_INVALID_PARAMETER가 된다.

GetServerVariable은 지원하지만, (다른 서버에서 정의하는) 확장 서버변수는 없다. GetServerVariable에서 모든 일반적인 아파치 CGI 환경변수와 ALL_HTTP, ALL_RAW 값을 사용할 수 있다.

아파치 2.0 mod_isapi는 이후 ISAPI 규약에 나온 추가 기능을 지원하고, 비동기 입출력과 TransmitFile 기능을 조금 흉내낸다. 또, ISAPI .dll을 미리 읽어들여서 성능을 높이는 아파치 1.3 mod_isapi에는 없는 기능을 지원한다.

top

ISAPIAppendLogToErrors 지시어

설명:ISAPI exntension의 HSE_APPEND_LOG_PARAMETER 요청을 오류 로그에 기록한다
문법:ISAPIAppendLogToErrors on|off
기본값:ISAPIAppendLogToErrors off
사용장소:주서버설정, 가상호스트, directory, .htaccess
Override 옵션:FileInfo
상태:Base
모듈:mod_isapi

ISAPI exntension의 HSE_APPEND_LOG_PARAMETER 요청을 오류 로그에 기록한다.

top

ISAPIAppendLogToQuery 지시어

설명:ISAPI exntension의 HSE_APPEND_LOG_PARAMETER 요청을 질의문자열에 기록한다
문법:ISAPIAppendLogToQuery on|off
기본값:ISAPIAppendLogToQuery on
사용장소:주서버설정, 가상호스트, directory, .htaccess
Override 옵션:FileInfo
상태:Base
모듈:mod_isapi

ISAPI exntension의 HSE_APPEND_LOG_PARAMETER 요청을 질의문자열에 기록한다 (CustomLog %q 항목에 덧붙인다).

top

ISAPICacheFile 지시어

설명:서버가 시작할때 메모리로 읽어들일 ISAPI .dll 파일들
문법:ISAPICacheFile file-path [file-path] ...
사용장소:주서버설정, 가상호스트
상태:Base
모듈:mod_isapi

아파치 서버가 시작할때 메모리로 읽어들여서 서버를 종료할때까지 메모리에 남아있을 파일명을 공백으로 구분하여 지정한다. 이 지시어는 ISAPI .dll 파일별로 여러번 사용할 수 있다. 파일의 전체 경로를 적는다. 절대 경로가 아니면 ServerRoot에 상대 경로로 받아들인다.

top

ISAPIFakeAsync 지시어

설명:비동기 ISAPI 콜백을 지원하는 척한다
문법:ISAPIFakeAsync on|off
기본값:ISAPIFakeAsync off
사용장소:주서버설정, 가상호스트, directory, .htaccess
Override 옵션:FileInfo
상태:Base
모듈:mod_isapi

on으로 설정하면 비동기 ISAPI 콜백 지원을 흉내낸다.

top

ISAPILogNotSupported 지시어

설명:ISAPI extension이 지원하지 않는 기능을 요청하면 로그에 기록한다
문법:ISAPILogNotSupported on|off
기본값:ISAPILogNotSupported off
사용장소:주서버설정, 가상호스트, directory, .htaccess
Override 옵션:FileInfo
상태:Base
모듈:mod_isapi

ISAPI extension이 지원하지 않는 기능을 요청하면 서버 오류 로그에 기록한다. 나중에 관리자가 문제를 추적하는데 도움이 된다. 원하는 모든 ISAPI 모듈이 정상적으로 동작하면 다시 off로 되돌려야 한다.

top

ISAPIReadAheadBuffer 지시어

설명:ISAPI extension의 미리읽기버퍼(read ahead buffer) 크기
문법:ISAPIReadAheadBuffer size
기본값:ISAPIReadAheadBuffer 49152
사용장소:주서버설정, 가상호스트, directory, .htaccess
Override 옵션:FileInfo
상태:Base
모듈:mod_isapi

ISAPI extension을 처음 호출할때 미리읽기버퍼의 최대 크기를 지정한다. (이 크기보다 큰) 나머지 자료는 ReadClient 콜백을 사용하여 읽어야 한다. 어떤 ISAPI extension은 ReadClient 기능을 지원하지 않는다. 이 경우 ISAPI extension 제작자에게 문의하라.