Поделиться через


Функция RpcServerUseProtseqEpExW (rpcdce.h)

Функция RpcServerUseProtseqEpEx сообщает библиотеке времени выполнения RPC использовать указанную последовательность протокола в сочетании с указанной конечной точкой для получения удаленных вызовов процедур.

Синтаксис

RPC_STATUS RpcServerUseProtseqEpExW(
  RPC_WSTR     Protseq,
  unsigned int MaxCalls,
  RPC_WSTR     Endpoint,
  void         *SecurityDescriptor,
  PRPC_POLICY  Policy
);

Параметры

Protseq

Указатель на строковый идентификатор последовательности протокола для регистрации в библиотеке времени выполнения RPC.

MaxCalls

Длина очереди невыполненной работы для последовательности протокола ncacn_ip_tcp . Все остальные последовательности протоколов игнорируют этот параметр. Используйте RPC_C_PROTSEQ_MAX_REQS_DEFAULT, чтобы указать значение по умолчанию. См. заметки.

Endpoint

Указатель на сведения об адресе конечной точки для использования при создании привязки для последовательности протокола, указанной в Protseq.

SecurityDescriptor

Указатель на необязательный параметр, предоставленный для подсистемы безопасности. Используется только для последовательностей протоколов ncacn_np и ncalrpc . Все остальные последовательности протоколов игнорируют этот параметр. Использование дескриптора безопасности в конечной точке для обеспечения безопасности сервера не рекомендуется. Этот параметр не отображается в спецификации DCE для этого API.

Policy

Указатель на структуру RPC_POLICY , которая содержит флаги, которые задают атрибуты, относящиеся к транспорту. В случае ncadg_mq транспорта эти флаги указывают свойства очереди серверного процесса-получения. В случае ncacn_ip_tcp или ncadg_ip_udp транспорта эти флаги ограничивают выделение портов для динамических портов и позволяют многосетевым компьютерам выборочно привязываться к сетевым картам.

Параметры флагов в поле Политика действуют только в том случае, если используются последовательности протоколов ncacn_ip_tcp, ncadg_ip_udp или ncadg_mq . Для всех остальных последовательностей протоколов время выполнения RPC игнорирует эти значения.

Примечание Части политики, связанные с динамическими конечными точками, игнорируются при вызове функции RpcServerUseProtseqEpEx, так как порт указан в самой конечной точке.
 

Возвращаемое значение

Значение Значение
RPC_S_OK
Вызов выполнен успешно.
RPC_S_PROTSEQ_NOT_SUPPORTED
Последовательность протоколов не поддерживается на этом узле.
RPC_S_INVALID_RPC_PROTSEQ
Недопустимая последовательность протокола.
RPC_S_INVALID_ENDPOINT_FORMAT
Недопустимый формат конечной точки.
RPC_S_OUT_OF_MEMORY
Системе не хватает памяти.
RPC_S_DUPLICATE_ENDPOINT
Конечная точка является дубликатом.
RPC_S_INVALID_SECURITY_DESC
Недопустимый дескриптор безопасности.
 
Примечание Список допустимых кодов ошибок см. в разделе Возвращаемые значения RPC.
 

Комментарии

Параметры и эффекты RpcServerUseProtseqEpEx , вложенные в RpcServerUseProtseqEp. Разница заключается в параметре Policy , который позволяет задавать определенные политики в конечных точках. Если задать для поля NICFlags структуры RPC_POLICY значение 0, эта расширенная функция будет эквивалентна исходному объекту RpcServerUseProtseqEp при использовании с транспортом ncacn_ip_tcp или ncadg_ip_udp .

Серверное приложение вызывает RpcServerUseProtseqEpEx для регистрации одной последовательности протокола в библиотеке времени выполнения RPC. При каждой регистрации последовательности протокола RpcServerUseProtseqEpEx включает указанные сведения об адресе конечной точки.

Чтобы получать запросы на удаленные вызовы процедур, сервер должен зарегистрировать по крайней мере одну последовательность протоколов в библиотеке времени выполнения RPC. Серверное приложение может много раз вызывать эту подпрограмму для регистрации дополнительных последовательностей протоколов и конечных точек. Для каждой последовательности протокола, зарегистрированной сервером, библиотека времени выполнения RPC создает одну или несколько конечных точек, через которые сервер получает запросы на удаленные вызовы процедур. Библиотека времени выполнения RPC создает разные конечные точки для каждой последовательности протокола. Однако каждый интерфейс в процессе доступен через любую конечную точку. Дополнительные сведения см. в статье Написание защищенного клиента или сервера RPC.

Для MaxCalls значение, предоставленное приложением, является лишь подсказкой. Время выполнения RPC или поставщик сокетов Windows может переопределить значение. Например, в Windows XP или Windows 2000 Профессиональная значение ограничено 5. Значения больше 5 игнорируются, а вместо этого используется 5. В Windows Server 2003 и Windows 2000 Server это значение будет учитываться.

Приложения должны быть осторожны, чтобы передать разумные значения в MaxCalls. Большие значения на сервере, расширенном сервере или сервере центра обработки данных могут привести к использованию большого объема памяти нестраничного пула. Использование слишком малого значения также является неблагоприятным, так как это может привести к тому, что пакеты TCP SYN будут удовлетворены TCP RST с сервера, если очередь невыполненной работы будет исчерпана. Разработчик приложения должен сбалансировать объем памяти и требования к масштабируемости при определении правильного значения maxCalls.

Если компьютер настроен для использования выборочной привязки, успешное возвращение не гарантирует, что сервер создал конечные точки для всех сетевых интерфейсов, присутствующих на компьютере. Время выполнения RPC может не прослушивать некоторые сетевые интерфейсы в зависимости от параметров выборочной привязки. Кроме того, если интерфейс еще не получил IP-адрес с помощью DHCP, сервер RPC не будет прослушивать сетевой интерфейс, пока ему не будет назначен DHCP-адрес. Успешное возвращение подразумевает, что сервер прослушивает по крайней мере один сетевой интерфейс; Полный список дескрипторов привязки, по которым можно получить вызовы удаленных процедур, можно получить с помощью вызова функции RpcServerInqBindings.

Дополнительные сведения см. в разделах Привязка на стороне сервера, Привязка строк, Настройка реестра для выделения портов и Выборочная привязка, А также Очередь сообщений RPC и справочные страницы MIDL и ncadg_mq.

Примечание

Заголовок rpcdce.h определяет RpcServerUseProtseqEpEx в качестве псевдонима, который автоматически выбирает версию ANSI или Юникод этой функции на основе определения константы препроцессора ЮНИКОД. Использование псевдонима, не зависящий от кодирования, с кодом, который не является нейтральным для кодировки, может привести к несоответствиям, которые приводят к ошибкам компиляции или времени выполнения. Дополнительные сведения см. в разделе Соглашения для прототипов функций.

Требования

Требование Значение
Минимальная версия клиента Windows 2000 Professional [только классические приложения]
Минимальная версия сервера Windows 2000 Server [только классические приложения]
Целевая платформа Windows
Header rpcdce.h (включая Rpc.h)
Библиотека Rpcrt4.lib
DLL Rpcrt4.dll

См. также раздел

RPC_POLICY

RpcServerUseAllProtseqsEx

RpcServerUseAllProtseqsIfEx

RpcServerUseProtseqEx

RpcServerUseProtseqIfEx

Написание защищенного клиента или сервера RPC