Compare commits
No commits in common. "42eebfc1bda060dee2989c7edce514651b1ad84a" and "7fbb04fdfa89cd035257860a7d42e014570bfc12" have entirely different histories.
42eebfc1bd
...
7fbb04fdfa
|
@ -304,24 +304,12 @@ void osd_t::handle_primary_bs_subop(osd_op_t *subop)
|
||||||
(bs_op->opcode != BS_OP_WRITE && bs_op->opcode != BS_OP_WRITE_STABLE ||
|
(bs_op->opcode != BS_OP_WRITE && bs_op->opcode != BS_OP_WRITE_STABLE ||
|
||||||
bs_op->retval != -ENOSPC))
|
bs_op->retval != -ENOSPC))
|
||||||
{
|
{
|
||||||
// die on any error except ENOSPC during write
|
// die on any error except ENOSPC
|
||||||
if (bs_op->opcode == BS_OP_WRITE || bs_op->opcode == BS_OP_WRITE_STABLE)
|
throw std::runtime_error(
|
||||||
{
|
"local blockstore modification failed (opcode = "+std::to_string(bs_op->opcode)+
|
||||||
printf(
|
" retval = "+std::to_string(bs_op->retval)+")"
|
||||||
"%s subop to %jx:%jx v%ju failed locally: retval = %d (expected %d)\n",
|
|
||||||
osd_op_names[bs_op_to_osd_op[bs_op->opcode]],
|
|
||||||
bs_op->oid.inode, bs_op->oid.stripe, bs_op->version, bs_op->retval, expected
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
printf(
|
|
||||||
"%s subop failed locally: retval = %d (expected %d)\n",
|
|
||||||
osd_op_names[bs_op_to_osd_op[bs_op->opcode]], bs_op->retval, expected
|
|
||||||
);
|
|
||||||
}
|
|
||||||
throw std::runtime_error("local blockstore modification failed");
|
|
||||||
}
|
|
||||||
bool recovery_related = cur_op->peer_fd == SELF_FD && cur_op->req.hdr.opcode != OSD_OP_SCRUB;
|
bool recovery_related = cur_op->peer_fd == SELF_FD && cur_op->req.hdr.opcode != OSD_OP_SCRUB;
|
||||||
add_bs_subop_stats(subop, recovery_related);
|
add_bs_subop_stats(subop, recovery_related);
|
||||||
subop->req.hdr.opcode = bs_op_to_osd_op[bs_op->opcode];
|
subop->req.hdr.opcode = bs_op_to_osd_op[bs_op->opcode];
|
||||||
|
@ -395,11 +383,9 @@ void osd_t::handle_primary_subop(osd_op_t *subop, osd_op_t *cur_op)
|
||||||
{
|
{
|
||||||
uint64_t version = subop->reply.sec_rw.version;
|
uint64_t version = subop->reply.sec_rw.version;
|
||||||
#ifdef OSD_DEBUG
|
#ifdef OSD_DEBUG
|
||||||
int64_t peer_osd = subop->peer_fd == SELF_FD ? osd_num :
|
uint64_t peer_osd = msgr.clients.find(subop->peer_fd) != msgr.clients.end()
|
||||||
(msgr.clients.find(subop->peer_fd) != msgr.clients.end()
|
? msgr.clients[subop->peer_fd]->osd_num : osd_num;
|
||||||
? msgr.clients[subop->peer_fd]->osd_num : -subop->peer_fd);
|
printf("subop %s %jx:%jx from osd %ju: version = %ju\n", osd_op_names[opcode], subop->req.sec_rw.oid.inode, subop->req.sec_rw.oid.stripe, peer_osd, version);
|
||||||
printf("subop %s %jx:%jx from osd %jd: version = %ju\n", osd_op_names[opcode],
|
|
||||||
subop->req.sec_rw.oid.inode, subop->req.sec_rw.oid.stripe, peer_osd, version);
|
|
||||||
#endif
|
#endif
|
||||||
if (op_data->fact_ver != UINT64_MAX)
|
if (op_data->fact_ver != UINT64_MAX)
|
||||||
{
|
{
|
||||||
|
@ -417,23 +403,21 @@ void osd_t::handle_primary_subop(osd_op_t *subop, osd_op_t *cur_op)
|
||||||
}
|
}
|
||||||
if (retval != expected)
|
if (retval != expected)
|
||||||
{
|
{
|
||||||
int64_t peer_osd = (msgr.clients.find(subop->peer_fd) != msgr.clients.end()
|
|
||||||
? msgr.clients[subop->peer_fd]->osd_num : -subop->peer_fd);
|
|
||||||
if (opcode == OSD_OP_SEC_READ || opcode == OSD_OP_SEC_WRITE || opcode == OSD_OP_SEC_WRITE_STABLE)
|
if (opcode == OSD_OP_SEC_READ || opcode == OSD_OP_SEC_WRITE || opcode == OSD_OP_SEC_WRITE_STABLE)
|
||||||
{
|
{
|
||||||
printf(
|
printf(
|
||||||
subop->peer_fd >= 0
|
subop->peer_fd >= 0
|
||||||
? "%1$s subop to %2$jx:%3$jx v%4$ju failed on osd %7$jd: retval = %5$d (expected %6$d)\n"
|
? "%1$s subop to %2$jx:%3$jx v%4$ju failed on peer %7$d: retval = %5$d (expected %6$d)\n"
|
||||||
: "%1$s subop to %2$jx:%3$jx v%4$ju failed locally: retval = %5$d (expected %6$d)\n",
|
: "%1$s subop to %2$jx:%3$jx v%4$ju failed locally: retval = %5$d (expected %6$d)\n",
|
||||||
osd_op_names[opcode], subop->req.sec_rw.oid.inode, subop->req.sec_rw.oid.stripe, subop->req.sec_rw.version,
|
osd_op_names[opcode], subop->req.sec_rw.oid.inode, subop->req.sec_rw.oid.stripe, subop->req.sec_rw.version,
|
||||||
retval, expected, peer_osd
|
retval, expected, subop->peer_fd
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
printf(
|
printf(
|
||||||
"%s subop failed on osd %jd: retval = %d (expected %d)\n",
|
"%s subop failed on peer %d: retval = %d (expected %d)\n",
|
||||||
osd_op_names[opcode], peer_osd, retval, expected
|
osd_op_names[opcode], subop->peer_fd, retval, expected
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
subop->rmw_buf = NULL;
|
subop->rmw_buf = NULL;
|
||||||
|
@ -744,7 +728,7 @@ void osd_t::submit_primary_rollback_subops(osd_op_t *cur_op, const uint64_t* osd
|
||||||
for (int role = 0; role < op_data->pg_size; role++)
|
for (int role = 0; role < op_data->pg_size; role++)
|
||||||
{
|
{
|
||||||
if (osd_set[role] != 0 && !stripes[role].read_error &&
|
if (osd_set[role] != 0 && !stripes[role].read_error &&
|
||||||
(osd_set[role] == this->osd_num || msgr.osd_peer_fds.find(osd_set[role]) != msgr.osd_peer_fds.end()))
|
msgr.osd_peer_fds.find(osd_set[role]) != msgr.osd_peer_fds.end())
|
||||||
{
|
{
|
||||||
n_subops++;
|
n_subops++;
|
||||||
}
|
}
|
||||||
|
@ -761,7 +745,7 @@ void osd_t::submit_primary_rollback_subops(osd_op_t *cur_op, const uint64_t* osd
|
||||||
for (int role = 0; role < op_data->pg_size; role++)
|
for (int role = 0; role < op_data->pg_size; role++)
|
||||||
{
|
{
|
||||||
if (osd_set[role] != 0 && !stripes[role].read_error &&
|
if (osd_set[role] != 0 && !stripes[role].read_error &&
|
||||||
(osd_set[role] == this->osd_num || msgr.osd_peer_fds.find(osd_set[role]) != msgr.osd_peer_fds.end()))
|
msgr.osd_peer_fds.find(osd_set[role]) != msgr.osd_peer_fds.end())
|
||||||
{
|
{
|
||||||
osd_op_t *subop = &op_data->subops[i];
|
osd_op_t *subop = &op_data->subops[i];
|
||||||
op_data->unstable_writes[i] = (obj_ver_id){
|
op_data->unstable_writes[i] = (obj_ver_id){
|
||||||
|
|
|
@ -260,6 +260,11 @@ resume_4:
|
||||||
op_data->st = 4;
|
op_data->st = 4;
|
||||||
return;
|
return;
|
||||||
resume_5:
|
resume_5:
|
||||||
|
if (op_data->scheme != POOL_SCHEME_REPLICATED)
|
||||||
|
{
|
||||||
|
// Remove version override just after the write, but before stabilizing
|
||||||
|
pg.ver_override.erase(op_data->oid);
|
||||||
|
}
|
||||||
if (op_data->errors > 0)
|
if (op_data->errors > 0)
|
||||||
{
|
{
|
||||||
// Handle ENOSPC/EDOM/ERANGE/EIO. If some subops fail, but others succeed,
|
// Handle ENOSPC/EDOM/ERANGE/EIO. If some subops fail, but others succeed,
|
||||||
|
@ -271,7 +276,7 @@ resume_5:
|
||||||
{
|
{
|
||||||
if (op_data->scheme != POOL_SCHEME_REPLICATED)
|
if (op_data->scheme != POOL_SCHEME_REPLICATED)
|
||||||
{
|
{
|
||||||
submit_primary_rollback_subops(cur_op, pg.cur_set.data());
|
submit_primary_rollback_subops(cur_op, op_data->prev_set);
|
||||||
resume_11:
|
resume_11:
|
||||||
op_data->st = 11;
|
op_data->st = 11;
|
||||||
return;
|
return;
|
||||||
|
@ -282,22 +287,15 @@ resume_12:
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pg.ver_override.erase(op_data->oid);
|
|
||||||
mark_partial_write(pg, op_data->oid, op_data->object_state, op_data->stripes, true);
|
mark_partial_write(pg, op_data->oid, op_data->object_state, op_data->stripes, true);
|
||||||
pg_cancel_write_queue(pg, cur_op, op_data->oid, op_data->errcode);
|
pg_cancel_write_queue(pg, cur_op, op_data->oid, op_data->errcode);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
pg.ver_override.erase(op_data->oid);
|
|
||||||
deref_object_state(pg, &op_data->object_state, true);
|
deref_object_state(pg, &op_data->object_state, true);
|
||||||
pg_cancel_write_queue(pg, cur_op, op_data->oid, op_data->errcode);
|
pg_cancel_write_queue(pg, cur_op, op_data->oid, op_data->errcode);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (op_data->scheme != POOL_SCHEME_REPLICATED)
|
|
||||||
{
|
|
||||||
// Remove version override just after the write, but before stabilizing
|
|
||||||
pg.ver_override.erase(op_data->oid);
|
|
||||||
}
|
|
||||||
if (op_data->object_state)
|
if (op_data->object_state)
|
||||||
{
|
{
|
||||||
// We must forget the unclean state of the object before deleting it
|
// We must forget the unclean state of the object before deleting it
|
||||||
|
|
Loading…
Reference in New Issue