Stay organized with collections Save and categorize content based on your preferences.
This shows how to override the retry policies for run_v2::ServicesClient:
auto options =
google::cloud::Options{}
.set<
google::cloud::run_v2::ServicesConnectionIdempotencyPolicyOption>(
CustomIdempotencyPolicy().clone())
.set<google::cloud::run_v2::ServicesRetryPolicyOption>(
google::cloud::run_v2::ServicesLimitedErrorCountRetryPolicy(3)
.clone())
.set<google::cloud::run_v2::ServicesBackoffPolicyOption>(
google::cloud::ExponentialBackoffPolicy(
/*initial_delay=*/std::chrono::milliseconds(200),
/*maximum_delay=*/std::chrono::seconds(45),
/*scaling=*/2.0)
.clone());
auto connection = google::cloud::run_v2::MakeServicesConnection(options);
// c1 and c2 share the same retry policies
auto c1 = google::cloud::run_v2::ServicesClient(connection);
auto c2 = google::cloud::run_v2::ServicesClient(connection);
// You can override any of the policies in a new client. This new client
// will share the policies from c1 (or c2) *except* for the retry policy.
auto c3 = google::cloud::run_v2::ServicesClient(
connection, google::cloud::Options{}
.set<google::cloud::run_v2::ServicesRetryPolicyOption>(
google::cloud::run_v2::ServicesLimitedTimeRetryPolicy(
std::chrono::minutes(5))
.clone()));
// You can also override the policies in a single call:
// c3.SomeRpc(..., google::cloud::Options{}
// .set<google::cloud::run_v2::ServicesRetryPolicyOption>(
// google::cloud::run_v2::ServicesLimitedErrorCountRetryPolicy(10).clone()));
Assuming you have created a custom idempotency policy. Such as:
class CustomIdempotencyPolicy
: public google::cloud::run_v2::ServicesConnectionIdempotencyPolicy {
public:
~CustomIdempotencyPolicy() override = default;
std::unique_ptr<google::cloud::run_v2::ServicesConnectionIdempotencyPolicy>
clone() const override {
return std::make_unique<CustomIdempotencyPolicy>(*this);
}
// Override inherited functions to define as needed.
};
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-08-14 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-14 UTC."],[[["The content provides a list of available versions for `run_v2_1_1ServicesClient-retry-snippet`, ranging from the latest release candidate 2.37.0-rc down to version 2.11.0."],["The provided code demonstrates how to override the default retry policies for `run_v2::ServicesClient` using options for custom `IdempotencyPolicy`, `RetryPolicy`, and `BackoffPolicy`."],["You can create multiple `ServicesClient` instances that share the same retry policies, and specific policies can be overridden in new clients or on a per-call basis, as shown with `c3` and `SomeRpc` examples."],["The code showcases how to use `ServicesLimitedErrorCountRetryPolicy` or `ServicesLimitedTimeRetryPolicy` and `ExponentialBackoffPolicy` for managing retries, using custom values."],["The code shows an example of a `CustomIdempotencyPolicy` that can be implemented by a user to define specific Idempotency logic to suit their need."]]],[]]
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4