Put Client Configuration Operation
(for database)
-
What is the Client-Configuration:
The Client-Configuration is a set of configuration options that apply to the client when communicating with the database. See what can be configured below. -
Initializing the Client-Configuration (on the client):
This configuration can be initially customized from the client code when creating the Document Store via the Conventions. -
Overriding the initial Client-Configuration for the database (on the server):
-
From the client code:
UsePutClientConfigurationOperation
to set the client-configuration options on the server.
See the example below. -
From the Studio:
Set the Client-Configuration from the Client-Configuration view.
-
-
Updating the running client:
-
Once the Client-Configuration is modified on the server, the running client will receive the updated settings the next time it makes a request to the database.
-
Setting the Client-Configuration on the server enables administrators to dynamically control the client behavior after it has started running.
e.g. manage load balancing of client requests on the fly in response to changing system demands.
-
-
The client-configuration set for the database level overrides the server-wide client-configuration.
What can be configured
The following client-configuration options are available:
-
Identity parts separator:
Set the separator used with automatically generated document identity IDs (default separator is/
).
Learn more about identity IDs creation here. -
Maximum number of requests per session:
Set this number to restrict the number of requests (Reads & Writes) per session in the client API. -
Read balance behavior:
Set the Read balance method the client will use when accessing a node with Read requests.
Learn more in Balancing client requests - overview and Read balance behavior. -
Load balance behavior:
Set the Load balance method for Read & Write requests.
Learn more in Load balance behavior.
Put client-configuration (for database)
// You can customize the client-configuration options in the client
// when creating the Document Store (this is optional):
// =================================================================
var documentStore = new DocumentStore
{
Urls = new[] { "ServerURL_1", "ServerURL_2", "..." },
Database = "DefaultDB",
Conventions = new DocumentConventions
{
// Initialize some client-configuration options:
MaxNumberOfRequestsPerSession = 100,
IdentityPartsSeparator = '$'
// ...
}
}.Initialize();
// Override the initial client-configuration in the server using the put operation:
// ================================================================================
using (documentStore)
{
// Define the client-configuration object
ClientConfiguration clientConfiguration = new ClientConfiguration
{
MaxNumberOfRequestsPerSession = 200,
ReadBalanceBehavior = ReadBalanceBehavior.FastestNode
// ...
};
// Define the put client-configuration operation, pass the configuration
var putClientConfigOp = new PutClientConfigurationOperation(clientConfiguration);
// Execute the operation by passing it to Maintenance.Send
documentStore.Maintenance.Send(putClientConfigOp);
}
// Override the initial client-configuration using the put operation:
using (documentStore)
{
// Define the client-configuration object
ClientConfiguration clientConfiguration = new ClientConfiguration
{
MaxNumberOfRequestsPerSession = 200,
ReadBalanceBehavior = ReadBalanceBehavior.FastestNode
// ...
};
// Define the put client-configuration operation, pass the configuration
var putClientConfigOp = new PutClientConfigurationOperation(clientConfiguration);
// Execute the operation by passing it to Maintenance.SendAsync
await documentStore.Maintenance.SendAsync(putClientConfigOp);
}
Syntax
public PutClientConfigurationOperation(ClientConfiguration configuration)
Parameter | Type | Description |
---|---|---|
configuration | ClientConfiguration |
Client configuration that will be set on the server (for the database) |
public class ClientConfiguration
{
public long Etag { get; set; }
public bool Disabled { get; set; }
public int? MaxNumberOfRequestsPerSession { get; set; }
public ReadBalanceBehavior? ReadBalanceBehavior { get; set; }
public LoadBalanceBehavior? LoadBalanceBehavior { get; set; }
public int? LoadBalancerContextSeed { get; set; }
public char? IdentityPartsSeparator; // can be any character except '|'
}