Ansible 委托和 run_once

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 上使用主数据库主机名,但这意味着我需要创建另一个变量。另一方面,我认为减少变量的数量并使其更加动态会更好。请指教

Kon*_*rov 6

如果您需要将任务仅委托给第一台服务器并运行一次,无论当前游戏中有多少台服务器,请使用:

- 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)