Learner
Learner

Reputation: 1968

ansible returns with "Failed to import the required Python library (Docker SDK for Python: docker (Python >= 2.7) or docker-py (Python 2.6))

I am running myserver in ubuntu:

+ sudo cat /etc/os-release
NAME="Ubuntu"
VERSION="16.04.6 LTS (Xenial Xerus)"
ID=ubuntu
ID_LIKE=debian
PRETTY_NAME="Ubuntu 16.04.6 LTS"
VERSION_ID="16.04"
HOME_URL="http://www.ubuntu.com/"
SUPPORT_URL="http://help.ubuntu.com/"
BUG_REPORT_URL="http://bugs.launchpad.net/ubuntu/"
VERSION_CODENAME=xenial
UBUNTU_CODENAME=xenial

I use ansible and when I run it I get the following error:

fatal: [localhost]: FAILED! => {"changed": false, "msg": "Failed to import the required Python library (Docker SDK for Python: docker (Python >= 2.7) or docker-py (Python 2.6)) on dd63315fad06's Python /usr/bin/python. Please read module documentation and install in the appropriate location, for example via `pip install docker` or `pip install docker-py` (Python 2.6). The error was: No module named docker"}

when I run

python -c "import sys; print(sys.path)"

I see:

['', '/usr/lib/python2.7', '/usr/lib/python2.7/plat-x86_64-linux-gnu', '/usr/lib/python2.7/lib-tk', '/usr/lib/python2.7/lib-old', '/usr/lib/python2.7/lib-dynload', '/usr/local/lib/python2.7/dist-packages', '/usr/local/lib/python2.7/dist-packages/pip-19.2.2-py2.7.egg', '/usr/local/lib/python2.7/dist-packages/fasteners-0.15-py2.7.egg', '/usr/local/lib/python2.7/dist-packages/monotonic-1.5-py2.7.egg', '/usr/lib/python2.7/dist-packages']

and python versions are as follows:

+ python --version
Python 2.7.12
+ python3 --version
Python 3.5.2

Then as I see everything is fine and I am not sure why I get

"Failed to import the required Python library (Docker SDK for Python: docker (Python >= 2.7) or docker-py (Python 2.6)) on dd63315fad06's Python /usr/bin/python. Please read module documentation and install in the appropriate location, for example via `pip install docker` or `pip install docker-py` (Python 2.6). The error was: No module named docker"

in ansible?

Upvotes: 35

Views: 101669

Answers (6)

jaime luque
jaime luque

Reputation: 1

Debian bootstrap with debian 10 have native python 2.6 enter to eco with chroot and install ansible it's easy

Upvotes: 0

Rob Goretsky
Rob Goretsky

Reputation: 133

I started getting this same error in April 2021, with the release of Version 5.0 of the Docker SDK For Python. The error message was almost the exact same as the original question, with the only difference being that at the end of the error message was one of the statements:

The error was: No module named parse

or

The error was: No module named selectors

This was ultimately due to the older version of pip that Ansible was using, incorrectly installing a Python3 library on a Python2.7 setup. The fix was to pin the version of the docker Python library to something earlier than Version 5.0, and the 'websocket-client' library to something earlier than Version 1.0:

- name: Install Docker SDK for Python
  pip:
    name: "docker<5" 
  become: yes

- name: Setup more docker dependencies
  pip:
    name: "websocket-client<1" 
  become: yes

Alternatively, this set of commands would have also worked, given that Python2 was still in use:

pip install docker<5
pip install websocket-client<1

Once these older versions of the Docker SDK for Python and Websocket Client were installed, Ansible was able to again successfully manage Docker on my behalf.

Upvotes: 4

larsks
larsks

Reputation: 312400

It appears that you don't have the docker module installed.

You will need to install it via your system package manager (apt install python-docker, for example), or using pip (pip install docker).

If you have multiple Python versions, make sure that you've installed the docker module into the version that Ansible is using.

Upvotes: 32

Roman Shishkin
Roman Shishkin

Reputation: 2605

Here, in May 2021 for Ubuntu 20.04 you need to run apt install python3-docker because no python 2.x is shipped by default anymore

Upvotes: 16

Jay Reddy
Jay Reddy

Reputation: 710

I have faced the same issue for the Ansible docker-compose module. I was able to fix it by selecting python3 for those tasks.

Before (Not working)

- name: Create docker service services
  docker_compose:
    project_src: /root/
  become: true

After (Working)

We can get the python location by $which python3

- name: Create fleuntd services
  docker_compose:
    project_src: /root/
  become: true
  vars:
    ansible_python_interpreter: /bin/python3

Upvotes: 11

Daniel
Daniel

Reputation: 8677

In my case (Ubuntu 20 with installed docker) these commands was required

apt update
apt install python3 python3-pip
pip3 install docker docker-compose

Detailed requirements:

https://docs.ansible.com/ansible/latest/collections/community/general/docker_compose_module.html

Upvotes: 3

Related Questions