Redis扣减库存后怎么同步到数据库的简单介绍

本文目录一览:

  • 1、利用Redis设计库存系统的苦与乐
  • 2、canal+Kafka实现mysql与redis数据同步
  • 3、redis怎么实现和数据库同步
利用Redis设计库存系统的苦与乐我们先在Redis中拿到当前的库存值,然后check是否已经扣减到了零,如果已经扣减到了零,则直接return;否则,就利用Redis的decr原子操作进行扣减,同时返回扣减后的库存值 。
内存使用效率对比:使用简单的key-value存储的话,Memcached的内存利用率更高,而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached 。
【Redis扣减库存后怎么同步到数据库的简单介绍】库存全部放在redis是可取的 。商品的库存全部放入redis,库存的读取直接读取redis,到了下单环节 , 库存的扣除也直接在redis扣除,通过消息队列通知后端数据库,最终把库存的扣减异步同步到后台数据库,避免了对数据库的瞬时压力 。
根据目前风控系统运行情况来看 , 遇到如下的问题 redis 中的key 太多,在存量卡号比较大的情况下,redis 中key的存储过于庞大 。redis 本身RDB 和 AOF 的问题 。线上开启AOF 重写出差情况下,会阻塞redis 主线程 。
canal+Kafka实现mysql与redis数据同步1、答案是肯定的,下面通过canal结合Kafka来实现mysql与redis之间的数据同步 。架构设计 通过上述结构设计图可以很清晰的知道用到的组件:MySQL、Canal、Kafka、ZooKeeper、Redis 。
2、使用阿里开源的 canal 作为数据同步工具 。总的来说有两种方案 本文把两种方式都实现下 。如果公司有统一的平台接入binlog的话,canal+mq应该是比较好的解耦的方式 。
3、二者数据同步的关键在于mysql数据库中主键,方案是在redis启动时区mysql读取所有表键值存入redis中,往redis写数据是,对redis主键自增并进行读取 , 若mysql更新失败,则需要及时清除缓存及同步redis主键 。
4、这里还可以基于binlog使用mysql_udf_redis , 将数据库中的数据同步到Redis 。
redis怎么实现和数据库同步1、配置迁移链路:选择要迁移的源和目标实例,选择复制类型为数据迁移 。选择迁移对象:可选择不同的数据库进行迁移 。配置映射对象:将源实例的多个数据库映射到目标实例的指定数据库 , 实现类似于MySQL多源复制的场景 。
2、读取数据的时候先从redis里面查 , 若没有,再去数据库查,同时写到redis里面,并且要设置失效时间 。
3、Worker使用一个while死循环实现守护进程 , 运行 php worker.php 可以看到Gearman状态变为:writeLog 001 同时查看同目录下gearman.log,内容应为从Client传入的值Log content 。
4、二者数据同步的关键在于mysql数据库中主键,方案是在redis启动时区mysql读取所有表键值存入redis中 , 往redis写数据是,对redis主键自增并进行读取 , 若mysql更新失败 , 则需要及时清除缓存及同步redis主键 。
5、插入时同步,比如先更新了oracle,再更新redis , 这个要靠代码逻辑来做 。谁先谁后得看设计了 。

    推荐阅读