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

时间:2021-03-10 16:42:50

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

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

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

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

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

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

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

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

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


总结:

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

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