gpt4 book ai didi

php - 使用redis存储和修改缓存对象

转载 作者:可可西里 更新时间:2023-11-01 11:24:45 26 4
gpt4 key购买 nike

我正在尝试使用 redis 缓存 php 对象(代表数据库记录)。

我需要每隔一段时间编辑很多对象的一个​​字段,(对象代表产品,数量字段应该经常批量更新)。

我在互联网上遇到了不同的方法,例如哈希表和序列化 json。

对于这种情况,哪种方法最好?

最佳答案

是的,根据我的经验,我肯定会使用由 productId 索引的哈希和存储为 JSON 对象的产品数据。不要为每个项目都使用一个 key ,因为您可能会遇到内存问题。查看 Redis 文档中的这些链接,了解为什么在您的用例中使用散列而不是键更好:

https://redis.io/topics/memory-optimization#use-hashes-when-possible https://redis.io/topics/memory-optimization#using-hashes-to-abstract-a-very-memory-efficient-plain-key-value-store-on-top-of-redis

除了要选择的结构之外,我认为定义是要存储完整的产品对象还是仅存储 quantity 字段也很重要。我猜你的产品在某个数据库中,你想移动到缓存,比如 Redis,数量的值(value)是为了提高性能、速度并避免对你的数据库进行读取操作。可能我错了,但如果是这样的话,我只会创建一个由 productId 索引的散列,并且只将 quantity 字段作为值。无论如何,如果您还需要在缓存中保留产品对象中的其他一些字段,我什么也没说。

另一个可能不属于您问题的主题是您将如何在 Redis 哈希中更新此数量值,我还猜测您会在每次销售产品时减少 Redis 中的数量,但它可以发生这种情况,因为用户转到产品页面并且他/她决定购买产品,产品数量可能为零。因此,您应该首先从 Redis 动态更新您的 Web 应用程序中的产品计数器,以便让您的用户了解情况,并且在完成购买之前检查该产品的数量,但要对照数据库。我的意思是,即使使用 Redis,真实的来源是你的数据库,Redis 和你的数据库之间可能存在一些同步问题

可能我已经猜到了很多事情......:)

关于php - 使用redis存储和修改缓存对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49512699/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com