struttura RPC_ENDPOINT_TEMPLATEA (rpcdce.h)
La struttura RPC_ENDPOINT_TEMPLATE specifica le proprietà di un endpoint server del gruppo di interfacce RPC, tra cui sequenza e nome del protocollo.
Sintassi
typedef struct {
unsigned long Version;
RPC_CSTR ProtSeq;
RPC_CSTR Endpoint;
void *SecurityDescriptor;
unsigned long Backlog;
} RPC_ENDPOINT_TEMPLATEA, *PRPC_ENDPOINT_TEMPLATEA;
Membri
Version
Questo campo è riservato e deve essere impostato su 0.
ProtSeq
Puntatore a un identificatore stringa della sequenza di protocollo da registrare con la libreria di runtime RPC. Sono supportati solo ncalrpc, ncacn_ip_tcp e ncacn_np. Questo valore non deve essere NULL.
Endpoint
Puntatore facoltativo alle informazioni sull'indirizzo dell'endpoint da usare per la creazione di un'associazione per la sequenza di protocollo specificata nel parametro Protseq. Specificare NULL per usare endpoint dinamici.
SecurityDescriptor
Puntatore a un parametro facoltativo fornito per il sottosistema di sicurezza. Usato solo per le sequenze di protocollo ncacn_np e ncalrpc. Tutte le altre sequenze di protocollo ignorano questo parametro. Non è consigliabile usare un descrittore di sicurezza nell'endpoint per proteggere un server.
Backlog
Lunghezza della coda di backlog per la sequenza di protocollo ncacn_ip_tcp. Tutte le altre sequenze di protocollo ignorano questo parametro. Usare RPC_C_PROTSEQ_MAX_REQS_DEFAULT per specificare il valore predefinito. Per altre informazioni, vedere La sezione Osservazioni.
Osservazioni
Il valore fornito in backlog dalle applicazioni è solo un hint. Il runtime RPC o il provider Windows Sockets può eseguire l'override del valore. Ad esempio, in Windows XP o Windows 2000 Professional, il valore è limitato a 5. I valori maggiori di 5 vengono ignorati e 5 vengono invece usati. In Windows Server 2003 e Windows 2000 Server il valore verrà rispettato.
Le applicazioni devono prestare attenzione a passare valori ragionevoli in backlog. I valori di grandi dimensioni nel server, nel server avanzato o nel server datacenter possono causare l'utilizzo di una grande quantità di memoria del pool non di paging. Anche l'uso di un valore troppo piccolo non è favorevole, perché può comportare l'esaurimento dei pacchetti TCP SYN da parte di TCP RST dal server.
Uno sviluppatore di applicazioni deve bilanciare il footprint di memoria rispetto ai requisiti di scalabilità quando si determina il valore appropriato per Backlog.
Nota
L'intestazione rpcdce.h definisce RPC_ENDPOINT_TEMPLATE come alias che seleziona automaticamente la versione ANSI o Unicode di questa funzione in base alla definizione della costante del preprocessore UNICODE. La combinazione dell'utilizzo dell'alias indipendente dalla codifica con il codice non indipendente dalla codifica può causare mancate corrispondenze che generano errori di compilazione o di runtime. Per altre informazioni, vedere convenzioni di per i prototipi di funzioni.
Fabbisogno
Requisito | Valore |
---|---|
client minimo supportato | Windows 8 [solo app desktop] |
server minimo supportato | Windows Server 2012 [solo app desktop] |
intestazione |
rpcdce.h (include Rpc.h) |