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