summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKevin Pulo <kevin.pulo@mongodb.com>2018-07-04 01:05:22 +0000
committerKevin Pulo <kevin.pulo@mongodb.com>2018-07-11 01:54:13 +0000
commit3346e3cb9609422e4f6ac41b6791e175bdfb5124 (patch)
tree465785bec8ab67edb5d33a1d1d722eedac2166fc
parent5d6df07e2513577b5c6d55c9342d462d931662d6 (diff)
downloadmongo-3346e3cb9609422e4f6ac41b6791e175bdfb5124.tar.gz
SERVER-34897 add parameter to prohibit mongos retries
(cherry picked from commit 80c7c825a44cf99b17e81f4233445c7ab1927706)
-rw-r--r--src/mongo/s/client/shard_remote.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/mongo/s/client/shard_remote.cpp b/src/mongo/s/client/shard_remote.cpp
index 2b72d77fb64..afad62b0f5c 100644
--- a/src/mongo/s/client/shard_remote.cpp
+++ b/src/mongo/s/client/shard_remote.cpp
@@ -45,6 +45,7 @@
#include "mongo/db/operation_context.h"
#include "mongo/db/query/query_request.h"
#include "mongo/db/repl/read_concern_args.h"
+#include "mongo/db/server_parameters.h"
#include "mongo/executor/task_executor_pool.h"
#include "mongo/rpc/get_status_from_command_result.h"
#include "mongo/rpc/metadata/repl_set_metadata.h"
@@ -69,6 +70,11 @@ namespace {
// response.
const BSONObj kReplMetadata(BSON(rpc::kReplSetMetadataFieldName << 1));
+constexpr bool internalProhibitShardOperationRetryByDefault = false;
+MONGO_EXPORT_SERVER_PARAMETER(internalProhibitShardOperationRetry,
+ bool,
+ internalProhibitShardOperationRetryByDefault);
+
/**
* Returns a new BSONObj describing the same command and arguments as 'cmdObj', but with maxTimeMS
* replaced by maxTimeMSOverride (or removed if maxTimeMSOverride is Milliseconds::max()).
@@ -101,6 +107,10 @@ ShardRemote::ShardRemote(const ShardId& id,
ShardRemote::~ShardRemote() = default;
bool ShardRemote::isRetriableError(ErrorCodes::Error code, RetryPolicy options) {
+ if (internalProhibitShardOperationRetry.loadRelaxed()) {
+ return false;
+ }
+
if (options == RetryPolicy::kNoRetry) {
return false;
}