最近在做一个主进程fork出多个子进程的项目时候,一开始,想在主进程之前 new redis出一个实例,让fork出的多个子进程共用这个实例,但是总感觉有哪里不妥!
思来想去,想到这么个例子来证明这么做的可怕性
首先在redis里面建了一个 【1-8,除去4】的集合体
然后在进程里面有加入这么段代码:
把不为集合成员的4却返回true 和 为集合成员的【1,2,3,5,6,7,8】却返回false的情况记录下来,结果
得出了一堆这样的错误情况记录,所以说多进程千万不能共用一个redis实例
总结:
必须每个进程单独创建redis/mysql连接,其他的存储客户端同样也是如此。原因是如果共用1个连接,那么返回的结果无法保证被哪个进程处理。持有连接的进程理论上都可以对这个连接进行读写,这样数据就发生错乱了。
所以在多个进程之间,一定不能共用连接