今天遇到一件奇怪的事, 原本好好的云平台出现异常, 不能创建虚拟机. 错误信息是cannot import name universaldetector
File "/usr/lib/python2.7/site-packages/neutronclient/client.py", line 343, in do_request
return self.request(url, method, **kwargs)
File "/usr/lib/python2.7/site-packages/neutronclient/client.py", line 332, in request
return resp, resp.text
File "/usr/lib/python2.7/site-packages/requests/models.py", line 845, in text
non-HTTP knowledge to make a better guess at the encoding, you should
File "/usr/lib/python2.7/site-packages/requests/models.py", line 715, in apparent_encoding
@property
File "/usr/lib/python2.7/site-packages/requests/packages/chardet/__init__.py", line 27, in detect
ImportError: cannot import name universaldetector
对比了一下正常的环境, 并没有universaldetector这个模块. 找不到头绪, 准备调试一下. 挂上pdb重启服务进程. 发现又好了.
过了一会儿, 另一个服务又出现这样的问题... 估计也是需要重启一下就会恢复. 可是为什么会这样呢?
仔细一看, 这个异常的环境中, 连/usr/lib/python2.7/site-packages/requests/packages/chardet这个目录都不存在, 明显是被删除了. 再检查/usr/lib/python2.7/site-packages/requests这个目录的修改时间, 发现最近有变化. 估计是requests被重新安装了不同的版本. 找同事确认了一下, 果然是这样.
那么解决办法挺简单, 就是重启所有用到requests的服务. 当然如果能够避免重新安装requests就更好了.