单应用,单数据库
业务是这样的: 用户请求我们 API 查询,先在账户充值金额。
每请求一次 API 会有一次计费,请求成功计费,余额减; 失败不计费; 余额不足请求失败;
余额结算怎么做比较好?业界都是什么方案?
1
securityCoding 2020-12-05 10:17:52 +08:00
请求前检查费用(商户锁) -》请求成功-》消息队列-》扣费
|
2
securityCoding 2020-12-05 10:18:23 +08:00
没有消息队列可以使用 redis stream
|
3
moult 2020-12-05 10:31:56 +08:00 via iPhone
请求 API 肯定有写记录吧。根据请求记录表,十分钟或一小时统一扣费一次。云服务那些按量计费很多都是一小时甚至一天计费在。实时扣费的话真的太浪费资源了。
|
5
kikione OP @securityCoding 谢谢
|
6
wangbenjun5 2020-12-05 11:47:59 +08:00
像这种单应用单数据库太简单了,一个锁就解决了并发问题,保证 1 毛钱不亏
|
7
wangbenjun5 2020-12-05 11:50:57 +08:00
当然如果考虑到锁的性能影响接口速度的话就不要使用数据库锁,可以使用内存锁,redis 锁。如果使用队列做成异步模式的话可能会导致超额,假设并发量大的话。
|
8
kikione OP @wangbenjun5 给数据库加一个 乐观锁就可了是吧
|
10
Dabaicong 2020-12-05 12:48:46 +08:00
如果实时计费,最好是悲观锁。select for update 。记得 where 条件中要有索引,要不然就会退化成表锁
|
11
brucefu 2020-12-05 13:01:17 +08:00
如何定义“请求一次”,为请求一次做一个唯一键,异步插表就好,要保成功。将来计费系统单独出去的话,就发消息出去
|
12
dengkj 2020-12-05 21:28:10 +08:00
MySQL RR RC 级别的话不用显式加锁,只需要判断用户余额是否大于等于零即可,数据库会自动加锁
|