
单应用,单数据库
业务是这样的: 用户请求我们 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 级别的话不用显式加锁,只需要判断用户余额是否大于等于零即可,数据库会自动加锁 |