|
|
74b1de |
From 5a35a996257d6aaa7fa55ff1e1aac407dd4824fe Mon Sep 17 00:00:00 2001
|
|
|
74b1de |
From: Sanju Rakonde <srakonde@redhat.com>
|
|
|
74b1de |
Date: Fri, 12 Jul 2019 16:28:04 +0530
|
|
|
74b1de |
Subject: [PATCH 252/255] glusterd: do not mark skip_locking as true for
|
|
|
74b1de |
geo-rep operations
|
|
|
74b1de |
|
|
|
74b1de |
We need to send the commit req to peers in case of geo-rep
|
|
|
74b1de |
operations even though it is a no volname operation. In commit
|
|
|
74b1de |
phase peers try to set the txn_opinfo which will fail because
|
|
|
74b1de |
it is a no volname operation where we don't require a commit
|
|
|
74b1de |
phase. We mark skip_locking as true for no volname operations,
|
|
|
74b1de |
but we have to give an exception to geo-rep operations, so that
|
|
|
74b1de |
they can set txn_opinfo in commit phase.
|
|
|
74b1de |
|
|
|
74b1de |
Please refer to detailed RCA at the bug: 1729463
|
|
|
74b1de |
|
|
|
74b1de |
> upstream patch : https://review.gluster.org/#/c/glusterfs/+/23034/
|
|
|
74b1de |
|
|
|
74b1de |
>fixes: bz#1729463
|
|
|
74b1de |
>Change-Id: I9f2478b12a281f6e052035c0563c40543493a3fc
|
|
|
74b1de |
>Signed-off-by: Sanju Rakonde <srakonde@redhat.com>
|
|
|
74b1de |
|
|
|
74b1de |
Change-Id: I9f2478b12a281f6e052035c0563c40543493a3fc
|
|
|
74b1de |
BUG: 1727785
|
|
|
74b1de |
Signed-off-by: Sanju Rakonde <srakonde@redhat.com>
|
|
|
74b1de |
Reviewed-on: https://code.engineering.redhat.com/gerrit/176032
|
|
|
74b1de |
Tested-by: RHGS Build Bot <nigelb@redhat.com>
|
|
|
74b1de |
Reviewed-by: Shwetha Acharya <sacharya@redhat.com>
|
|
|
74b1de |
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
|
|
|
74b1de |
---
|
|
|
74b1de |
xlators/mgmt/glusterd/src/glusterd-handler.c | 9 +++++++--
|
|
|
74b1de |
1 file changed, 7 insertions(+), 2 deletions(-)
|
|
|
74b1de |
|
|
|
74b1de |
diff --git a/xlators/mgmt/glusterd/src/glusterd-handler.c b/xlators/mgmt/glusterd/src/glusterd-handler.c
|
|
|
74b1de |
index cb2666b..2e73c98 100644
|
|
|
74b1de |
--- a/xlators/mgmt/glusterd/src/glusterd-handler.c
|
|
|
74b1de |
+++ b/xlators/mgmt/glusterd/src/glusterd-handler.c
|
|
|
74b1de |
@@ -1078,7 +1078,11 @@ __glusterd_handle_stage_op(rpcsvc_request_t *req)
|
|
|
74b1de |
|
|
|
74b1de |
/* In cases where there is no volname, the receivers won't have a
|
|
|
74b1de |
* transaction opinfo created, as for those operations, the locking
|
|
|
74b1de |
- * phase where the transaction opinfos are created, won't be called. */
|
|
|
74b1de |
+ * phase where the transaction opinfos are created, won't be called.
|
|
|
74b1de |
+ * skip_locking will be true for all such transaction and we clear
|
|
|
74b1de |
+ * the txn_opinfo after the staging phase, except for geo-replication
|
|
|
74b1de |
+ * operations where we need to access txn_opinfo in the later phases also.
|
|
|
74b1de |
+ */
|
|
|
74b1de |
ret = glusterd_get_txn_opinfo(txn_id, &txn_op_info);
|
|
|
74b1de |
if (ret) {
|
|
|
74b1de |
gf_msg_debug(this->name, 0, "No transaction's opinfo set");
|
|
|
74b1de |
@@ -1087,7 +1091,8 @@ __glusterd_handle_stage_op(rpcsvc_request_t *req)
|
|
|
74b1de |
glusterd_txn_opinfo_init(&txn_op_info, &state, &op_req.op,
|
|
|
74b1de |
req_ctx->dict, req);
|
|
|
74b1de |
|
|
|
74b1de |
- txn_op_info.skip_locking = _gf_true;
|
|
|
74b1de |
+ if (req_ctx->op != GD_OP_GSYNC_SET)
|
|
|
74b1de |
+ txn_op_info.skip_locking = _gf_true;
|
|
|
74b1de |
ret = glusterd_set_txn_opinfo(txn_id, &txn_op_info);
|
|
|
74b1de |
if (ret) {
|
|
|
74b1de |
gf_msg(this->name, GF_LOG_ERROR, 0, GD_MSG_TRANS_OPINFO_SET_FAIL,
|
|
|
74b1de |
--
|
|
|
74b1de |
1.8.3.1
|
|
|
74b1de |
|