REDIS实践之请勿踩多进程共用一个实例连接的坑

最近在做一个主进程fork出多个子进程的项目时候,一开始,想在主进程之前 new redis出一个实例,让fork出的多个子进程共用这个实例,但是总感觉有哪里不妥!

思来想去,想到这么个例子来证明这么做的可怕性

首先在redis里面建了一个 【1-8,除去4】的集合体


然后在进程里面有加入这么段代码:


把不为集合成员的4却返回true  和  为集合成员的【1,2,3,5,6,7,8】却返回false的情况记录下来,结果


得出了一堆这样的错误情况记录,所以说多进程千万不能共用一个redis实例


总结:

必须每个进程单独创建redis/mysql连接,其他的存储客户端同样也是如此。原因是如果共用1个连接,那么返回的结果无法保证被哪个进程处理。持有连接的进程理论上都可以对这个连接进行读写,这样数据就发生错乱了。

所以在多个进程之间,一定不能共用连接


评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值