ansiblefact

Ansible date variable


I'm trying to learn how to use Ansible facts as variables, and I don't get it. When I run...

$ ansible localhost -m setup

...it lists all of the facts of my system. I selected one at random to try and use it, ansible_facts.ansible_date_time.date, but I can't figure out HOW to use it. When I run...

$ ansible localhost -m setup -a "filter=ansible_date_time"
localhost | success >> {
    "ansible_facts": {
        "ansible_date_time": {
            "date": "2015-07-09",
            "day": "09",
            "epoch": "1436460014",
            "hour": "10",
            "iso8601": "2015-07-09T16:40:14Z",
            "iso8601_micro": "2015-07-09T16:40:14.795637Z",
            "minute": "40",
            "month": "07",
            "second": "14",
            "time": "10:40:14",
            "tz": "MDT",
            "tz_offset": "-0600",
            "weekday": "Thursday",
            "year": "2015"
        }
    },
    "changed": false
}

So, it's CLEARLY there. But when I run...

$ ansible localhost -a "echo {{ ansible_facts.ansible_date_time.date }}"
localhost | FAILED => One or more undefined variables: 'ansible_facts' is undefined

$ ansible localhost -a "echo {{ ansible_date_time.date }}"
localhost | FAILED => One or more undefined variables: 'ansible_date_time' is undefined

$ ansible localhost -a "echo {{ date }}"
localhost | FAILED => One or more undefined variables: 'date' is undefined

What am I not getting here? How do I use Facts as variables?


Solution

  • The command ansible localhost -m setup basically says "run the setup module against localhost", and the setup module gathers the facts that you see in the output.

    When you run the echo command these facts don't exist since the setup module wasn't run. A better method to testing things like this would be to use ansible-playbook to run a playbook that looks something like this:

    - hosts: localhost
      tasks:
          - debug: var=ansible_date_time
    
          - debug: msg="the current date is {{ ansible_date_time.date }}"
    

    Because this runs as a playbook facts for localhost are gathered before the tasks are run. The output of the above playbook will be something like this:

    PLAY [localhost] **************************************************
    
    GATHERING FACTS ***************************************************************
    ok: [localhost]
    
    TASK: [debug var=ansible_date_time] *******************************************
    ok: [localhost] => {
        "ansible_date_time": {
            "date": "2015-07-09",
            "day": "09",
            "epoch": "1436461166",
            "hour": "16",
            "iso8601": "2015-07-09T16:59:26Z",
            "iso8601_micro": "2015-07-09T16:59:26.896629Z",
            "minute": "59",
            "month": "07",
            "second": "26",
            "time": "16:59:26",
            "tz": "UTC",
            "tz_offset": "+0000",
            "weekday": "Thursday",
            "year": "2015"
        }
    }
    
    TASK: [debug msg="the current date is {{ ansible_date_time.date }}"] **********
    ok: [localhost] => {
        "msg": "the current date is 2015-07-09"
    }
    
    PLAY RECAP ********************************************************************
    localhost      : ok=3    changed=0    unreachable=0    failed=0