ansible定义时间戳的变量

时间:2017-03-14 17:06:28

标签: ansible

设置带有时间戳的变量时,我遇到麻烦,通过我的剧本使用它。 我想要实现的是在两个服务器中使用发布文件夹名称,并使用相同的时间戳标记新的数据库。

我在/ ansibleproject / vars /中名为common.yml的文件中定义这些变量。

timestamp: "{{lookup('pipe', 'date +%Y%m%d%H%M%SZ')}}"
release_name: '{{ repo_tag }}_{{timestamp}}'
new_db_name: '{{release_name}}'

然后,在任务文件中,我正在创建这样的目录:

- name: "Create new release folder"
  file: path={{new_release_path}} state=directory mode=2775 owner=deployment group=deployment
  become: yes

在一个单独的任务文件中,我正在创建这样的数据库:

- name: "Prepare db user rights"
  shell: echo "CREATE DATABASE \`{{new_db_name}}\` CHARACTER SET utf8 COLLATE utf8_general_ci; " > db_create.sql
  when: inventory_hostname ==  groups['app'][0]

- name: "Create new database for new release"
  shell: mysql -h {{mysql_server}} -u{{mysql_username}} -p{{mysql_password}} < db_create.sql
  when: inventory_hostname ==  groups['app'][0]

在我正在部署的两台服务器上创建的文件夹具有相同的时间戳:

drwxrwsr-x  2 deployment deployment 4096 Mar 14 16:36 test_20170314173640Z/

但db名称有不同的时间戳。

mysql> show databases;
+---------------------------------------------------------------+
| Database                                                      |
+---------------------------------------------------------------+
| information_schema                                            |
| dummy                                                         |
| mysql                                                         |
| performance_schema                                            |
| test_20170314173819Z                                          |
+---------------------------------------------------------------+

我正在阅读“set_fact”以设置时间戳,但这似乎在主机上有效。

有没有办法让它在服务器和数据库上保持一致?

此致

1 个答案:

答案 0 :(得分:5)

这是预期的行为,因为变量在使用时是模板化的,但在“已定义”时却没有模板化(实际上没有定义)。
因此,date +%Y%m%d%H%M%SZ将针对每项任务执行(在不同的原因时间)。

如果您需要一致性,请使用set_fact制作持久性事实:

- set_fact:
    timestamp: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"

timestamp之后是一个带有管道结果的普通字符串,而不是像你的情况那样的Jinja表达式。

您可以为每个主机或仅localhost创建此事实,并将其作为hostvars['localhost'].timestamp从其他主机访问。