UPDATE Поддержка этой функции была удалена. Пожалуйста, ищите другие варианты
Оригинальное сообщение:
Возможно, вам захочется взглянуть на облаченные стили; см. http://css-tricks.com/saving-the-day-with-scoped-css/ .
Основная идея -
Тем не менее, вы находитесь на грани кровопролития здесь с точки зрения поддержки браузера. См. http://caniuse.com/style-scoped .
. Один вариант - использовать iframe.
Вы должны сохранить контент как факт :
- set_fact:
string_to_echo: "{{ command_output.stdout }}"
Нет необходимости устанавливать факт.
- shell: cat "hello"
register: cat_contents
- shell: echo "I cat hello"
when: cat_contents.stdout == "hello"
.stdout
.
– Tim Malone
25 April 2018 в 10:20
В случае, если вы хотите сохранить сложную команду для сравнения результата текста, например, чтобы сравнить версию ОС, возможно, это может помочь вам:
tasks:
- shell: echo $(cat /etc/issue | awk {'print $7'})
register: echo_content
- shell: echo "It works"
when: echo_content.stdout == "12"
register: out
- debug: var=out.stdout_lines
Я новичок в Ansible, но я бы предложил следующее решение:
playbook.yml
...
vars:
command_output_full:
stdout: will be overriden below
command_output: {{ command_output_full.stdout }}
...
...
...
tasks:
- name: Create variable from command
command: "echo Hello"
register: command_output_full
- debug: msg="{{ command_output }}"
Он должен работать (и работает для меня), потому что Ansible использует ленивая оценка. Но кажется, что он проверяет достоверность перед запуском, поэтому я должен определить command_output_full.stdout
в vars.
И, конечно, если в этом разделе слишком много таких vars, это будет выглядеть уродливым .
Небольшая модификация за пределами ответа udondan. Мне нравится повторно использовать зарегистрированные имена переменных с помощью set_fact
, чтобы свести к минимуму беспорядок.
Итак, если бы я зарегистрировался с использованием переменной, psk
, я бы использовал ту же переменную имя с созданием set_fact
.
- name: generate PSK
shell: openssl rand -base64 48
register: psk
delegate_to: 127.0.0.1
run_once: true
- set_fact:
psk={{ psk.stdout }}
- debug: var=psk
run_once: true
Затем, когда я запустил его:
$ ansible-playbook -i inventory setup_ipsec.yml
PLAY [all] *************************************************************************************************************************************************************************
TASK [Gathering Facts] *************************************************************************************************************************************************************
ok: [hostc.mydom.com]
ok: [hostb.mydom.com]
ok: [hosta.mydom.com]
TASK [libreswan : generate PSK] ****************************************************************************************************************************************************
changed: [hosta.mydom.com -> 127.0.0.1]
TASK [libreswan : set_fact] ********************************************************************************************************************************************************
ok: [hosta.mydom.com]
ok: [hostb.mydom.com]
ok: [hostc.mydom.com]
TASK [libreswan : debug] ***********************************************************************************************************************************************************
ok: [hosta.mydom.com] => {
"psk": "6Tx/4CPBa1xmQ9A6yKi7ifONgoYAXfbo50WXPc1kGcird7u/pVso/vQtz+WdBIvo"
}
PLAY RECAP *************************************************************************************************************************************************************************
hosta.mydom.com : ok=4 changed=1 unreachable=0 failed=0
hostb.mydom.com : ok=2 changed=0 unreachable=0 failed=0
hostc.mydom.com : ok=2 changed=0 unreachable=0 failed=0