- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在努力通过其 cli 将我的部署过程自动化到 WildFly。 cli 本身不是幂等的,所以如果我想使用 ansible 添加一些服务器属性,它只是在它已经存在的情况下抛出一个错误(官方 cli 文档只提供 3 种方法添加、读取、删除 https://docs.jboss.org/author/display/WFLY10/CLI+Recipes - 没有替换或强制添加)。所以我需要先创造一些条件,最简单的就是ready(just if exists):
Ansible 代码:
- name: Check Server Runtime properties
shell: ./jboss-cli.sh --commands="connect {{ wf_server }},/core-service=platform-mbean/type=runtime:read-attribute(name=system-properties)" $AUTH_DATA
args:
chdir: "{{ wf_path }}/bin"
register: srp_chk
- name: Configure Some properties
shell: ./jboss-cli.sh --commands="connect {{ wf_server }},/system-property={{ item.mkey }}:add(value=\"{{ item.mval }}\")" $AUTH_DATA
args:
chdir: "{{ wf_path }}/bin"
when: "not '{{ item.mkey }}' in srp_chk.stdout"
with_items:
- { mkey: some.property1, mval: "{{ some_value1 }}" }
- { mkey: some.property2, mval: "{{ some_value2 }}" }
在我需要更改 some_value1 或 some_value2 之前,它工作正常。在那种情况下,如您所知,我需要删除属性并重新创建。
所以我们几乎接近我的问题:)
我知道这些值可以在 srp_chk.stdout 中找到,我可以为 ex 创建相同的检查:
when: "not '{{ item.mval }}' in srp_chk.stdout"
但是万一我有更复杂的结构并且我需要在 Ansible 中比较两个 json 呢?
这就是我的问题开始的地方 :))
在我的示例 srp_chk.stdout 中,Jboss cli 以 Json 格式输出,但在一行中,不幸的是,当我尝试 Jinja2 过滤器“from_json”时,它给出了错误:
the field 'args' has an invalid value ([]), and could not be converted to an dict
“to_json”和“to_nice_json”给出了一些奇怪的不可读数据和错误:
template error while templating string: expected token 'end of print statement', got 'outcome'.
“结果”- 是我的字符串的内容。
所以,我有变量 srp_chk.stdout_lines,它在 json 格式方面更具可读性,并且有这样的东西:
"stdout_lines": [
"{",
" \"outcome\" => \"success\",",
" \"result\" => {",
" \"PID\" => \"76462\",",
" \"[Standalone]\" => \"\",",
" \"awt.toolkit\" => \"sun.awt.X11.XToolkit\",",
" \"some.property1\" => \"some.value1\",",
" \"some.property2\" => \"some.value2\",",
等但它的列表。
问题:如何将此列表转换为 json 数据,以便在 Ansible 中我可以从变量“srp_chk.stdout_lines.result.some.property1”中获取“some.value1”?
附言请不要建议总是删除和添加属性,因为在每次部署时我都需要重新加载我的服务器 - 当我们谈论 PROD 时这是非常糟糕的情况。
最佳答案
下一版本的 WildFly(又名 12)将支持输出到 JSON https://issues.jboss.org/browse/WFCORE-3363
关于python - 在 Ansible 中将 Jboss (WildFly) cli 输出转换为 json,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48580822/
尽管用户是 sudo 用户,但远程主机在运行 Ansible playbook 时仍会引发错误。 "/usr/bin/python: can't open file '/home/ludd/.ansi
只是想了解 ansible 和 ansible-galaxy 之间的核心区别是什么?从文档中,ansible-galaxy 用于管理角色(创建和发布)那么ansible是做什么用的呢?只运行剧本? 我
只是想了解 ansible 和 ansible-galaxy 之间的核心区别是什么?从文档中,ansible-galaxy 用于管理角色(创建和发布)那么ansible是做什么用的呢?只运行剧本? 我
我有一个定义如下的剧本: - name: install percona rpms hosts: imdp roles: - role1 - role2 - role3
Ansible 版本:2.4.2.0 来自 here和 here ,我可以写下面的剧本 $ cat test.yml - name: Finding Master VMs hosts: all-c
我正在运行这个 Ansible 剧本: - name: Set String set_fact: string: item loop: "{{some_var|filter()}}"
我无法在我的输出变量中搜索我用于 when 语句的指定字符串。下面的代码应该检查输出变量中的字符串“distribute-list”,但是在运行 playbook 时会出现错误。 fatal: [19
在 Ansible 中是否可以仅当处理程序出现在该播放中时才有条件地通知处理程序? 例如:我有一个多主机配置的剧本。有些主机使用 Apache 运行 PHP,有些使用 PHP-FPM。根据主机,修改
我是 ansible 的新手,正在学习 ansible 并致力于定义 ansible 脚本以在服务器上安装 confluent。在查看有关如何定义和运行 ansible 脚本的示例时,一些示例使用“a
是否可以列出Ansible角色中的任务? 即除了grepping - name以外,还有没有现成的方法可以做到这一点? 最佳答案 创建一个指定角色的简单剧本,并使用ansible-playbook选项
所以ansible-playbook有 --ask-pass和 --ask-sudo-pass .有没有办法让 ssh 先尝试没有密码,然后只有在无密码登录失败时才提示输入密码?同样,ansible
Ansible 提供了许多过滤器和条件。据我所知;应该可以实现一个 Ansible playbook 来执行一组任务,这些任务实现与图灵完备语言相同的结果。那么,图灵完备吗? 最佳答案 我觉得是这样的
我一直在寻找,但没有太多关于什么 Ansible 保险库密码文件应该是什么样的。 例如我想做: ANSIBLE_VAULT_PASSWORD_FILE=./pwdfile ansible-vault
我在运行完整的剧本时遇到了麻烦,因为后来的剧本所依赖的一些事实在早期的剧本中被修改了,但是 ansible 不会在运行中更新事实。 运行ansible somehost -m setup当整个剧本开始
我对Ansible很陌生 是否可以使用Ansible检查文件中是否存在字符串。 我要检查的是用户有权访问服务器。 这可以使用cat /etc/passwd | grep username在服务器上完成
我正在尝试使用 jinja2 通过 ansible 模板循环字典以创建多个数据源,但收到此错误 [{'msg': "AnsibleUndefinedVariable: One or more unde
我正在尝试将文件复制到/ etc。但是当我运行剧本时,我收到“msg:目标/ etc不可写”的消息。这是我的Playbook任务部分。非常感谢您的帮助。 任务: - name: copy rsyslo
我正面临这个恼人的错误:Ansible hosts are randomly unreachable #18188 . 有没有办法告诉 Ansible 如果 SSH 连接失败,再试一次?还是2倍? 根
我正在编写一个简单的任务来创建用户。作为此任务的一部分,我想从defaults / main.yml中读取密码。 默认值/ main.yml test_user:testuser test_group
当我在Ansible中使用lineinfile时,它不会写',"字符 lineinfile: 'dest=/home/xyz state=present line="CACHES="default""
我是一名优秀的程序员,十分优秀!