PHP操作DB后,會(huì)去請(qǐng)求兩個(gè)其他服務(wù)的API接口?,F(xiàn)在有個(gè)問題是,如果請(qǐng)求失敗了,怎么操作DB回滾呢?除了讓數(shù)據(jù)庫回滾之外的方法
說白了就是一個(gè)程序設(shè)計(jì)的問題,基于事務(wù)的話可以:
function save_if_success($transaction, $result)
{
if ($result) $transaction->commit();
else $transaction->rollback();
}
$db_ret = db();
save_if_success($transaction, api1($db_ret) && api2($db_ret));
缺點(diǎn)是只能數(shù)據(jù)庫回滾
一般最好是自己實(shí)現(xiàn)撤銷邏輯,既可以撤銷數(shù)據(jù)庫操作,又可以撤銷api操作,用異常會(huì)很方便
function revoke_if_failed($do_func, $do_func_params, $revoke_callback, $revoke_params, $exception) {
try
{
$do_func_ret = call_user_func_array($do_func, $do_func_params);
}
catch($exception $e)
{
call_user_func_array($revoke_callback, $revoke_params);
throw;
}
return $do_func_ret;
}
try
{
$dbret = db();
$api1_ret = revoke_if_failed(api1, [$dbret], revoke_db, [$dbret], OperationFailedException::class);
revoke_if_failed(api2, [$api1_ret], revoke_api1, [$api1_ret], OperationFailedException::class);
}
catch (OperationFailedException $e)
{
return ERR;
}
return SUCCESS;
也可以結(jié)合起來用
DB不就是數(shù)據(jù)庫嗎?
我沒遇到過相關(guān)問題,冒昧回答一下:
是否可以將每步操作生成一個(gè)標(biāo)記放到緩存(或者種種存儲(chǔ)介質(zhì))內(nèi),這個(gè)存在有效期,如果超出了有效期沒有執(zhí)行下一步,就回滾(邏輯操作)