Home
Document
Q&A
Video
Donate
Source Code
Code-Galaxy 云原生平台
Business
Swoole Tracker
Swoole Compiler
Login
Register
全部
提问
分享
讨论
建议
公告
开发框架
发表新帖
关于swoole异步服务器与table多进程下并发读写的问题
### 问题描述 在swoole异步风格服务器下,在worker1中遍历table,然后在遍历结束后对table的某些key删除,这时,worker2也在遍历,那么会发生什么. ### Swoole版本,PHP版本,以及操作系统版本信息 swoole4 ### 想知道 1. 在另一个进程中这时会被读取到,还是会直接不见 2. 在同时遍历时1进行了删除,那么又会怎么样
发布于1年前 · 7 次浏览 · 来自
提问
QAQ
### 问题描述 在swoole异步风格服务器下,在worker1中遍历table,然后在遍历结束后对table的某些key删除,这时,worker2也在遍历,那么会发生什么. ### Swoole版本,PHP版本,以及操作系统版本信息 swoole4 ### 想知道 1. 在另一个进程中这时会被读取到,还是会直接不见 2. 在同时遍历时1进行了删除,那么又会怎么样
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
评论
2020-08-22
Rango
底层只能保证`get`、`set`、`del`、`exists`、`decr`、`incr`操作本身的原子性。你提到的这`2`种情况,是需要开发者自己保证数据同步的,请使用`Swoole\Lock`对数据操作实现互斥。
赞
0
回复
微信公众号
热门内容
- Swoole 4.8.10 已发布
- 云原生时代 PHP/Golang 项目如何实现微服务
- 异步风格的写法,如何同时开启http和websocket?
- 使用全局变量,一个worker进程同时执行多个onRequest协程问题
- HTTP服务器出发热更新,看到工作进程的worker_id也变了,但重新请求response的结果不更新
- 清空redis key
- PDO配置长连接在并发请求时候会报一个bug工作进程自动重启
- Swoole 团队云原生新项目 Code-Galaxy 介绍
- swoole 进程繁忙时候\Swoole\Process::kill($pid, SIGTERM)终止运行后出现一大堆僵尸进程
- 给官方建议 [SWOOLE LINUX 独立版本,加上PHP-event的扩展]
暂无回复的问答
- 关于openssl CURL WARNING swSSL_connect: SSL_connect(fd=69) failed. Error: error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small[1|394]
- 请问那个一键协程化的代码是放外面还是set里面
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。