PHP操作DB後,會去請求兩個其他服務的API介面。現在有個問題是,如果請求失敗了,怎麼操作DB回滾呢?除了讓資料庫回滾之外的方法
說穿了就是一個程式設計的問題,基於事務的話可以:
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));
缺點是只能資料庫回滾
一般最好是自己實作撤銷邏輯,既可以撤銷資料庫操作,又可以撤銷api操作,用異常會很方便
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;
也可以結合起來用
DB不就是資料庫嗎? 我沒遇到過相關問題,冒昧回答一下:是否可以將每步操作生成一個標記放到緩存(或者種種存儲媒體)內,這個存在有效期,如果超出了有效期沒有執行下一步,就回滾(邏輯操作)
(@ο@) 哇~,涉及了一個分佈式事物的難題,看各位大神如何解決多次RPC
說穿了就是一個程式設計的問題,基於事務的話可以:
缺點是只能資料庫回滾
一般最好是自己實作撤銷邏輯,既可以撤銷資料庫操作,又可以撤銷api操作,用異常會很方便
也可以結合起來用
DB不就是資料庫嗎?
我沒遇到過相關問題,冒昧回答一下:
是否可以將每步操作生成一個標記放到緩存(或者種種存儲媒體)內,這個存在有效期,如果超出了有效期沒有執行下一步,就回滾(邏輯操作)
(@ο@) 哇~,涉及了一個分佈式事物的難題,看各位大神如何解決多次RPC