ImportError: No module named ansible.errors

现象:

root 身份使用 pip 安装了 ansible,然后切换为 tidb 用户,执行 ansible --version 遇到了 No module named ansible.errors 错误。

以 root 身份运行时

# ansible --version
ansible 2.7.4
  config file = None
  configured module search path = [u'/root/.ansible/plugins/modules', u'/usr/share/ansible/plugins/modules']
  ansible python module location = /usr/lib/python2.7/site-packages/ansible
  executable location = /bin/ansible
  python version = 2.7.5 (default, Aug 4 2017, 00:39:18) [GCC 4.8.5 20150623 (Red Hat 4.8.5-16)]

以 tidb 身份运行时

$ ansible --version
Traceback (most recent call last):
  File "/usr/bin/ansible", line 40, in <module>
    from ansible.errors import AnsibleError, AnsibleOptionsError, AnsibleParserError
ImportError: No module named ansible.errors

原因:

服务器上有配置过 umask 而修改了文件的默认权限。pip 的 ansible 安装目录为 /usr/lib/python2.7/site-packages/ansible。

查看权限

$ ls -lart /usr/lib/python2.7/site-packages/ansible/errors/
total 36
-rw-------  1 root root 11555 May 9 13:12 __init__.py
# 应该是 -rw-r--r--

解决方案:

对安装目录授予应有的权限

chmod -R a+rX /usr/lib/python2.7/site-packages/ansible