目录
回复内容:
首页 后端开发 php教程 为什么memcache的incr不会出现并发的问题?

为什么memcache的incr不会出现并发的问题?

Jun 06, 2016 pm 08:33 PM
memcached php redis

为什么呢?都说他是原子性的,我理解的是原子性就是要么全提交要么不提交,但感觉这和并发没有关系啊,比如,第一个人用incr的时候这个时候是1但还没加完呢,这个时候第二个人来了,他还是1,这个时候第一个加成2,第二个可能还是2,我不知道理解对么,除非他是第一个用的时候把读锁住了,等待第二个读完才能继续,在线等大神帮我解除疑惑~

回复内容:

为什么呢?都说他是原子性的,我理解的是原子性就是要么全提交要么不提交,但感觉这和并发没有关系啊,比如,第一个人用incr的时候这个时候是1但还没加完呢,这个时候第二个人来了,他还是1,这个时候第一个加成2,第二个可能还是2,我不知道理解对么,除非他是第一个用的时候把读锁住了,等待第二个读完才能继续,在线等大神帮我解除疑惑~

防止并发的问题,memcached 提供了CAS (chech and save) 方式,在get 时候获取对应值的同时还获取当前key 对应的token(或者叫版本号),在更新操作时候需要带上token,会比较当前的token,是否和get时的一直,如果不一致就更新失败。如果由于其他人对当前key操作,token值就会发生变化。
php的参考代码如下:

<code>$cas = 0.0;

do {
    $cnt = $m->get('cnt_key', null, $cas);

    if ($m->getResultCode() == Memcached::RES_NOTFOUND) {
        $m->add('cnt_key', 1);
    } else { 
        $m->cas($cas, 'cnt_key', $cnt + 1);
    }   
} while ($m->getResultCode() != Memcached::RES_SUCCESS);

</code>
登录后复制

注意上面代码中的 get 方法中有一个$cas 参数,这个就是当前cnt_key对应的token,一旦 cnt_key 被操作后,其值也发生变化。在cas方法中需要传递$cas值,如果token发生变化,那么cas 将会执行失败,也即 $m->getResultCode() != Memcached::RES_SUCCESS。所以将会再次执行循环体。

这个是在memcached 客户端做的。对于incr,保证原子性,是在memcached服务端完成的,原理应该类似上述的cas操作,由于没有查看memcached的源代码,不敢妄下结论。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1672
14
CakePHP 教程
1428
52
Laravel 教程
1332
25
PHP教程
1276
29
C# 教程
1256
24
如何利用Redis缓存方案高效实现产品排行榜列表的需求? 如何利用Redis缓存方案高效实现产品排行榜列表的需求? Apr 19, 2025 pm 11:36 PM

Redis缓存方案如何实现产品排行榜列表的需求?在开发过程中,我们常常需要处理排行榜的需求,例如展示一个�...

REDIS的角色:探索数据存储和管理功能 REDIS的角色:探索数据存储和管理功能 Apr 22, 2025 am 12:10 AM

Redis在数据存储和管理中扮演着关键角色,通过其多种数据结构和持久化机制成为现代应用的核心。1)Redis支持字符串、列表、集合、有序集合和哈希表等数据结构,适用于缓存和复杂业务逻辑。2)通过RDB和AOF两种持久化方式,Redis确保数据的可靠存储和快速恢复。

Spring Boot中OAuth2Authorization对象Redis缓存失败怎么办? Spring Boot中OAuth2Authorization对象Redis缓存失败怎么办? Apr 19, 2025 pm 08:03 PM

SpringBoot中使用Redis缓存OAuth2Authorization对象在SpringBoot应用中,使用SpringSecurityOAuth2AuthorizationServer...

IIS和PHP的兼容性:深度潜水 IIS和PHP的兼容性:深度潜水 Apr 22, 2025 am 12:01 AM

IIS和PHP可以兼容,通过FastCGI实现。1.IIS通过配置文件将.php文件请求转发给FastCGI模块。2.FastCGI模块启动PHP进程处理请求,提高性能和稳定性。3.实际应用中需注意配置细节、错误调试和性能优化。

如果session_start()被多次调用会发生什么? 如果session_start()被多次调用会发生什么? Apr 25, 2025 am 12:06 AM

多次调用session_start()会导致警告信息和可能的数据覆盖。1)PHP会发出警告,提示session已启动。2)可能导致session数据意外覆盖。3)使用session_status()检查session状态,避免重复调用。

使用RedisTemplate进行批量查询时,为什么返回值会为空? 使用RedisTemplate进行批量查询时,为什么返回值会为空? Apr 19, 2025 pm 10:15 PM

使用RedisTemplate进行批量查询时为何返回值为空?在使用RedisTemplate进行批量查询操作时,可能会遇到返回的结果�...

REDIS:了解其架构和目的 REDIS:了解其架构和目的 Apr 26, 2025 am 12:11 AM

Redis是一种内存数据结构存储系统,主要用作数据库、缓存和消息代理。它的核心特点包括单线程模型、I/O多路复用、持久化机制、复制与集群功能。 Redis在实际应用中常用于缓存、会话存储和消息队列,通过选择合适的数据结构、使用管道和事务、以及进行监控和调优,可以显着提升其性能。

作曲家:通过AI的帮助开发PHP 作曲家:通过AI的帮助开发PHP Apr 29, 2025 am 12:27 AM

AI可以帮助优化Composer的使用,具体方法包括:1.依赖管理优化:AI分析依赖关系,建议最佳版本组合,减少冲突。2.自动化代码生成:AI生成符合最佳实践的composer.json文件。3.代码质量提升:AI检测潜在问题,提供优化建议,提高代码质量。这些方法通过机器学习和自然语言处理技术实现,帮助开发者提高效率和代码质量。

See all articles