【已解决】cannot invoke setopt() - perform() is currently running

最近抢红包应用人数激增

暴露了一些并发的问题

在抢的高峰期,日志里经常报错 cannot invoke setopt() - perform() is currently running


搜了一下,基本没有什么有价值的解答

只是知道了跟pycurl有关……

因为代码是别人写的,之前只是直接引用,在我仔细理了一遍代码后才发现,

抢红包的微信支付接口类,用的是单例模式……

也就是说,在较短时间内,唯一一个抢红包进程里的多个线程,只能创建并使用同一个微信支付接口对象

而这个接口对象又只创建了一个pycurl对象

这就造成了,线程a修改好了网络请求配置(setopt()),并创建了pycurl对象,

此时线程b又来了,也想使用微信支付对象里的pycurl对象,但是又不能自己再建一个微信支付对象(单例限制),线程b想要setopt()却又发现线程a已经perform()使它运行了,不能修改,于是报错了!


晕,看来不能照搬代码啊(原先的代码只用来购买商品)。
按自己的抢红包应用的需求,去掉了单例模式后,问题解决。

你可能感兴趣的:(【已解决】cannot invoke setopt() - perform() is currently running)