Ala*_*mHo 1 ansible ansible-2.x
我为本地和开发环境编写了一个特定角色,该角色将从 dbserver 组中的第一台服务器删除并重新创建数据库,该服务器主要用作主数据库。
group_vars/dbserver
[dbserver]
vagrant1 # master db
vagrant2 # slave db
Run Code Online (Sandbox Code Playgroud)
之后,如果我需要删除数据库并再次创建数据库,基本上我只需要在组中的第一台服务器上运行该命令。
- name: drop database
mysql_db: name={{ targetdbname }} state=absent
when: targetdeploydb == "new"
delegate_to: "{{ item }}"
with_items: "{{ groups.dbserver }}"
run_once: true
- name: create database
mysql_db: name={{ targetdbname }} state=present
when: targetdeploydb == "new"
delegate_to: "{{ item }}"
with_items: "{{ groups.dbserver }}"
when: targetdeploydb == "new"
run_once: true
Run Code Online (Sandbox Code Playgroud)
这是我运行剧本时的日志
TASK [laravel : drop database] *************************************************
changed: [vagrant1 -> vagrant1] => (item=vagrant1)
changed: [vagrant1 -> vagrant2] => (item=vagrant2)
TASK [laravel : create database] ***********************************************
changed: [vagrant1 -> vagrant1] => (item=vagrant1)
changed: [vagrant1 -> vagrant2] => (item=vagrant2)
Run Code Online (Sandbox Code Playgroud)
我能想到的另一种方法是直接在 delegate_to 上使用主数据库主机名,但这意味着我需要创建另一个变量。另一方面,我认为减少变量的数量并使其更加动态会更好。请指教
如果您需要将任务仅委托给第一台服务器并运行一次,无论当前游戏中有多少台服务器,请使用:
- name: drop database
mysql_db: name={{ targetdbname }} state=absent
when: targetdeploydb == "new"
delegate_to: "{{ groups['dbserver'] | first }}"
run_once: true
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
8486 次 |
最近记录: |