Pet*_*ger 12 postgresql virtualenv ansible
Ansible postgresql_user模块需要psycopg2的工作安装:
http://docs.ansible.com/postgresql_user_module.html
如果这是安装在服务器上的VirtualEnv中,Ansible模块如何找到它?
其他Ansible模块似乎有明确的VirtualEnv支持,所以这只是一个缺失的功能吗?
如果您想使用 virtualenv 中的 psycopg2 模块,一种可能的解决方案是
步骤如下:
1)创建了一台ubuntu 16.04 vagrant机器并安装了postgresql。
2)使用ansible postgresql_db模块创建新数据库失败并出现错误FAILED! => {"changed": false, "failed": true, "msg": "the python psycopg2 module is required"}
3)创建一个virtualenv并在virtualenv中安装psycopg2
virtualenv venv -p /usr/bin/python (Note: python2.7)
source venv/bin/activate
pip install psycopg2
Run Code Online (Sandbox Code Playgroud)
4) 使用ansible_python_interpreter运行 ansible-playbook以从 virtualenv 指向 python 解释器,并且数据库创建任务成功。ansible命令及内容如下,
---
- hosts: vagrant
sudo: true
pre_tasks:
- raw: test -e /usr/bin/python || (apt -y update && apt install -y python-minimal)
- setup:
tasks:
- name: db create
postgresql_db:
name: acme
become_user: postgres
Run Code Online (Sandbox Code Playgroud)
ansible-playbook 命令
ansible-playbook playbook.yml -e "ansible_python_interpreter=/home/ubuntu/venv/bin/python"
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
3020 次 |
最近记录: |