Подскажите пожалуйста как установить модуль mysql_db в debian 9. Пишу playbook в ansible. Нужно было создать базу данных и пользователя. В документации ansible написано, что для этого используется модуль mysql_db. Ниже на этой же странице есть информация
Пакет Python можно установить с помощью apt-get install python-pymysql
Устанавливаю по инструкции с офф сайта Ansible.
xxxx@instance-3:/etc/ansible$ sudo apt-get install python-pymysql
Reading package lists... Done
Building dependency tree
Reading state information... Done
Suggested packages:
python-pymysql-doc
The following NEW packages will be installed:
python-pymysql
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
Need to get 61.4 kB of archives.
After this operation, 318 kB of additional disk space will be used.
Get:1 http://deb.debian.org/debian stretch/main amd64 python-pymysql all 0.7.10-1 [61.4 kB]
Fetched 61.4 kB in 0s (987 kB/s)
Selecting previously unselected package python-pymysql.
(Reading database ... 55250 files and directories currently installed.)
Preparing to unpack .../python-pymysql_0.7.10-1_all.deb ...
Unpacking python-pymysql (0.7.10-1) ...
Setting up python-pymysql (0.7.10-1) ...
Далее я пытаюсь начать действовать по плану.
xxxx@instance-3:/etc/ansible$ ansible-playbook db.yml
PLAY [create data base] ********************************************************
TASK [setup] *******************************************************************
ok: [xx.xx.xx.xxx]
TASK [db] **********************************************************************
fatal: [xx.xx.xx.xxx]: FAILED! => {"changed": false, "failed": true, "msg": "the python mysqldb module is required"}
[WARNING]: Could not create retry file '/etc/ansible/db.retry'. [Errno 13] Permission denied:
u'/etc/ansible/db.retry'
PLAY RECAP *********************************************************************
xx.xx.xx.xxx : ok=1 changed=0 unreachable=0 failed=1
Мой план действий для ansible
---
- name: create data base
hosts: all
become: yes
tasks:
- name: db
mysql_db:
name: bobdata
state: present
- name: user
mysql_user:
name: wpuser
password: 123456
priv: '*.*:ALL'
state: present
решение1
Короткий ответ
Установите модуль Python mysqldb на удаленном хосте.
Подробности
НЕУДАЧНО! => { ... "msg": "требуется модуль python mysqldb" ...
Цитата изТребования
На хосте, на котором выполняется этот модуль, должны быть выполнены следующие требования.
- MySQLdb (Python 2.x)
- PyMySQL (Python 2.7 и Python 3.X) или
- mysql (двоичный файл командной строки)
- mysqldump (двоичный файл командной строки)
" The host that executes this module
" этоудаленный узел.
Например, в FreeBSD (как удаленный хост)
$ pkg info | grep -i MySQLdb
py27-MySQLdb-1.2.5_1 Access a MySQL database through Python
Кстати, есть открытый вопросТребуется модуль MySQL-python #906с Debian.