RpcServerUseAllProtseqsEx-Funktion (rpcdce.h)
Die RpcServerUseAllProtseqsEx-Funktion weist die RPC-Laufzeitbibliothek an, alle unterstützten Protokollsequenzen für den Empfang von Remoteprozeduraufrufen zu verwenden.
Syntax
RPC_STATUS RpcServerUseAllProtseqsEx(
unsigned int MaxCalls,
void *SecurityDescriptor,
PRPC_POLICY Policy
);
Parameter
MaxCalls
Backlogwarteschlangenlänge für die ncacn_ip_tcp Protokollsequenz. Alle anderen Protokollsequenzen ignorieren diesen Parameter. Verwenden Sie RPC_C_PROTSEQ_MAX_REQS_DEFAULT, um den Standardwert anzugeben. Siehe Hinweise.
SecurityDescriptor
Zeiger auf einen optionalen Parameter, der für das Sicherheitssubsystem bereitgestellt wird. Wird nur für ncacn_np - und ncalrPC-Protokollsequenzen verwendet. Alle anderen Protokollsequenzen ignorieren diesen Parameter. Die Verwendung eines Sicherheitsdeskriptors für den Endpunkt, um einen Server zu schützen, wird nicht empfohlen. Dieser Parameter wird in der DCE-Spezifikation für diese API nicht angezeigt.
Policy
Zeiger auf die RPC_POLICY-Struktur , mit der Sie die Standardrichtlinien für die dynamische Portzuordnung und -bindung an Netzwerkschnittstellenkarten (NICs) auf mehreren Computern (Computer mit mehreren Netzwerkkarten) überschreiben können.
Rückgabewert
Wert | Bedeutung |
---|---|
|
Der Aufruf war erfolgreich. |
|
Es gibt keine unterstützten Protokollsequenzen. |
|
Genügend Arbeitsspeicher ist nicht verfügbar. |
|
Der Sicherheitsdeskriptor ist zu kurz. |
Hinweise
Wenn Sie das Feld NICFlags der RPC_POLICY Struktur auf 0 festlegen, entspricht diese erweiterte API funktionell dem ursprünglichen RpcServerUseAllProtseqs, und der Server bindet basierend auf den Einstellungen in der Systemregistrierung an NiCs. Informationen dazu, wie die Registrierungseinstellungen die verfügbaren Internet- und Intranetports definieren, finden Sie unter Konfigurieren der Registrierung für Portzuordnungen und selektive Bindung.
Für jede von einem Server registrierte Protokollsequenz erstellt die RPC-Laufzeitbibliothek einen oder mehrere Endpunkte, über die der Server Remoteprozeduraufrufanforderungen empfängt. Die RPC-Laufzeitbibliothek erstellt unterschiedliche Endpunkte für jede Protokollsequenz. Der Endpunktname wird durch die RPC-Laufzeit oder das Betriebssystem generiert. Beispielsweise wird für ncacn_ip_tcp die Portnummer dynamisch durch die RPC-Laufzeit bestimmt, abhängig von der Verfügbarkeit und den Registrierungseinstellungen.
Anwendungen müssen darauf achten, angemessene Werte in MaxCalls zu übergeben. Große Werte auf Server, Advanced Server oder Datacenter Server können dazu führen, dass eine große Menge an nicht ausgelagertem Poolspeicher verwendet wird. Die Verwendung eines zu kleinen Werts ist ebenfalls ungünstig, da dies dazu führen kann, dass TCP SYN-Pakete von TCP RST vom Server erfüllt werden, wenn die Backlogwarteschlange erschöpft ist. Ein Anwendungsentwickler sollte bei der Ermittlung des richtigen Werts für MaxCalls zwischen Arbeitsspeicherbedarf und Skalierbarkeitsanforderungen abwägen.
Wenn der Computer für die Verwendung der selektiven Bindung konfiguriert ist, garantiert die erfolgreiche Rückgabe nicht, dass der Server Endpunkte für alle auf dem Computer vorhandenen Netzwerkschnittstellen erstellt hat. Die RPC-Laufzeit lauscht möglicherweise nicht an einigen Netzwerkschnittstellen, abhängig von den Einstellungen für die selektive Bindung. Wenn eine Schnittstelle noch keine IP-Adresse über DHCP empfangen hat, lauscht der RPC-Server nicht an der Netzwerkschnittstelle, bis ihr eine DHCP-Adresse zugewiesen ist. Eine erfolgreiche Rückgabe bedeutet, dass der Server mindestens eine Netzwerkschnittstelle lauscht. Die vollständige Liste der Bindungshandles, über die Remoteprozeduraufrufe empfangen werden können, kann mit einem Aufruf der RpcServerInqBindings-Funktion abgerufen werden.
Um Protokollsequenzen selektiv zu registrieren, ruft ein Server RpcServerUseProtseqEx, RpcServerUseProtseqIfEx oder RpcServerUseProtseqEpEx auf. Eine Beschreibung der Routinen, die ein Server normalerweise nach der Registrierung von Protokollsequenzen aufruft, finden Sie unter Serverseitige Bindung .
Anforderungen
Unterstützte Mindestversion (Client) | Windows 2000 Professional [nur Desktop-Apps] |
Unterstützte Mindestversion (Server) | Windows 2000 Server [nur Desktop-Apps] |
Zielplattform | Windows |
Kopfzeile | rpcdce.h (include Rpc.h) |
Bibliothek | Rpcrt4.lib |
DLL | Rpcrt4.dll |
Weitere Informationen
Konfigurieren der Registrierung für Portzuordnungen und selektive Bindung