다음을 통해 공유


RpcServerUseProtseqIfExW 함수(rpcdce.h)

RpcServerUseProtseqIfEx 함수는 RPC 런타임 라이브러리에 원격 프로시저 호출 수신을 위한 인터페이스 사양의 엔드포인트와 결합된 지정된 프로토콜 시퀀스를 사용하도록 지시합니다.

통사론

RPC_STATUS RpcServerUseProtseqIfExW(
  RPC_WSTR      Protseq,
  unsigned int  MaxCalls,
  RPC_IF_HANDLE IfSpec,
  void          *SecurityDescriptor,
  PRPC_POLICY   Policy
);

매개 변수

Protseq

RPC 런타임 라이브러리에 등록할 프로토콜 시퀀스의 문자열 식별자에 대한 포인터입니다.

MaxCalls

ncacn_ip_tcp 프로토콜 시퀀스의 백로그 큐 길이입니다. 다른 모든 프로토콜 시퀀스는 이 매개 변수를 무시합니다. RPC_C_PROTSEQ_MAX_REQS_DEFAULT 사용하여 기본값을 지정합니다. 비고를 참조하세요.

IfSpec

Protseq 매개 변수에 지정된 프로토콜 시퀀스에 대한 바인딩을 만드는 데 사용할 엔드포인트 정보를 포함하는 인터페이스입니다.

SecurityDescriptor

보안 하위 시스템에 제공된 선택적 매개 변수에 대한 포인터입니다. ncacn_npncalrpc 프로토콜 시퀀스에만 사용됩니다. 다른 모든 프로토콜 시퀀스는 이 매개 변수를 무시합니다. 서버 보안을 위해 엔드포인트에서 보안 설명자를 사용하는 것은 권장되지 않습니다. 이 매개 변수는 이 API에 대한 DCE 사양에 표시되지 않습니다.

Policy

동적 포트에 대한 포트 할당을 제한하는 플래그를 포함하고 다중 호스트 컴퓨터가 네트워크 인터페이스 카드에 선택적으로 바인딩할 수 있도록 하는 RPC_POLICY 구조에 대한 포인터입니다.

반환 값

의미
RPC_S_OK
호출이 성공했습니다.
RPC_S_PROTSEQ_NOT_FOUND
이 프로토콜 시퀀스의 엔드포인트는 IDL 파일에 지정되지 않습니다.
RPC_S_PROTSEQ_NOT_SUPPORTED
프로토콜 시퀀스는 이 호스트에서 지원되지 않습니다.
RPC_S_INVALID_RPC_PROTSEQ
프로토콜 시퀀스가 잘못되었습니다.
RPC_S_INVALID_ENDPOINT_FORMAT
엔드포인트 형식이 잘못되었습니다.
RPC_S_OUT_OF_MEMORY
시스템이 메모리가 부족합니다.
RPC_S_INVALID_SECURITY_DESC
보안 설명자가 잘못되었습니다.
 
참고 유효한 오류 코드 목록은 RPC 반환 값참조하세요.
 

발언

RpcServerUseProtseqIfEx의 매개 변수 및 효과는 RpcServerUseProtseqIf확장할 있습니다. 차이점은 동적 포트에 대한 포트 할당을 제한하고 다중 호스트 컴퓨터가 네트워크 인터페이스 카드에 선택적으로 바인딩할 수 있도록 하는 Policy 매개 변수입니다.

RPC_POLICY 구조체의 NICFlags 필드를 0으로 설정하면 이 확장 API는 원래 RpcServerUseProtseqIf기능적으로 동일하며 서버는 시스템 레지스트리의 설정에 따라 NIC에 바인딩됩니다. 레지스트리 설정에서 사용 가능한 인터넷 및 인트라넷 포트를 정의하는 방법에 대한 자세한 내용은 포트 할당 및 선택적 바인딩대한 레지스트리 구성을 참조하세요.

참고정책 필드의 플래그 설정은 ncacn_ip_tcp 또는 ncadg_ip_udp 프로토콜 시퀀스가 사용 중인 경우에만 유효합니다. 다른 모든 프로토콜 시퀀스의 경우 RPC 런타임은 이러한 값을 무시합니다.
 
서버 애플리케이션은 RpcServerUseProtseqIfEx 호출하여 RPC 런타임 라이브러리에 하나의 프로토콜 시퀀스를 등록합니다. 각 프로토콜 시퀀스 등록을 통해 루틴에는 IDL 파일에 제공된 엔드포인트 주소 정보가 포함됩니다.

원격 프로시저 호출 요청을 받으려면 서버가 RPC 런타임 라이브러리에 하나 이상의 프로토콜 시퀀스를 등록해야 합니다. 서버 애플리케이션은 이 루틴을 여러 번 호출하여 추가 프로토콜 시퀀스를 등록할 수 있습니다.

서버에 의해 등록된 각 프로토콜 시퀀스에 대해 RPC 런타임 라이브러리는 서버가 원격 프로시저 호출 요청을 수신하는 하나 이상의 엔드포인트를 만듭니다. RPC 런타임 라이브러리는 각 프로토콜 시퀀스에 대해 서로 다른 엔드포인트를 만듭니다. 그러나 프로세스의 각 인터페이스는 모든 엔드포인트를 통해 액세스할 수 있습니다. 자세한 내용은 보안 RPC 클라이언트 또는 서버 작성을 참조하세요.

MaxCalls애플리케이션에서 제공하는 값은 힌트일 뿐입니다. RPC 런타임 또는 Windows 소켓 공급자가 값을 재정의할 수 있습니다. 예를 들어 Windows XP 또는 Windows 2000 Professional에서는 값이 5로 제한됩니다. 5보다 큰 값은 무시되고 5는 대신 사용됩니다. Windows Server 2003 및 Windows 2000 Server에서 값이 적용됩니다.

애플리케이션은 MaxCalls적절한 값을 전달하도록 주의해야 합니다. 서버, 고급 서버 또는 데이터 센터 서버의 값이 크면 페이징되지 않은 풀 메모리가 많이 사용될 수 있습니다. 너무 작은 값을 사용하면 백로그 큐가 소진될 경우 TCP RST가 서버에서 TCP SYN 패킷을 충족할 수 있으므로 불리합니다. 애플리케이션 개발자는 MaxCalls적절한 값을 결정할 때 메모리 공간과 확장성 요구 사항의 균형을 유지해야 합니다.

컴퓨터가 선택적 바인딩을 사용하도록 구성된 경우 성공적인 반환은 서버가 컴퓨터에 있는 모든 네트워크 인터페이스에 대한 엔드포인트를 생성했음을 보장하지 않습니다. RPC 런타임은 선택적 바인딩 설정에 따라 일부 네트워크 인터페이스에서 수신 대기할 수 없습니다. 또한 인터페이스가 DHCP를 사용하여 IP 주소를 아직 받지 못한 경우 RPC 서버는 DHCP 주소가 할당될 때까지 네트워크 인터페이스에서 수신 대기하지 않습니다. 반환이 성공하면 서버가 하나 이상의 네트워크 인터페이스에서 수신 대기하고 있음을 의미합니다. RpcServerInqBindings 함수를 호출하여 원격 프로시저 호출을 수신할 수 있는 바인딩 핸들의 전체 목록을 가져올 수 있습니다.

IDL 파일에서 모든 프로토콜 시퀀스를 등록하기 위해 서버는 RpcServerUseAllProtseqsIfEx호출합니다. 자세한 내용은 Server-Side 바인딩참조하세요. Microsoft RPC 지원 프로토콜 시퀀스 목록은 문자열 바인딩참조하세요.

메모

rpcdce.h 헤더는 RpcServerUseProtseqIfEx를 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입대한 규칙을 참조하세요.

요구 사항

요구
지원되는 최소 클라이언트 Windows XP [데스크톱 앱만 해당]
지원되는 최소 서버 Windows Server 2003 [데스크톱 앱만 해당]
대상 플랫폼 Windows
헤더 rpcdce.h(Rpc.h 포함)
라이브러리 Rpcrt4.lib
DLL Rpcrt4.dll

참고 항목

RpcServerUseAllProtseqsEx

RpcServerUseAllProtseqsIfEx

RpcServerUseProtseqEpEx

RpcServerUseProtseqEx

보안 RPC 클라이언트 또는 서버 작성