- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我需要帮助来弄清楚我应该如何为我的用例构建我的主机和组。
让我稍微设定一下场景。我当前的设置如下:
主持
[windows]
client_1 ansible_host=172.0.0.1
[linux]
client_2 ansible_host=172.0.0.2
client_3 ansible_host=172.0.0.3
让我们只看一下 Windows 设置。
group_vars/windows
jboss_service_name: JBOSSAS7SVC
app_service_name: APPSRVC
...
host_vars/client_1
ansible_user: username
ansible_password: pasword
ansible_port: 5986
ansible_connection: winrm
ansible_winrm_server_cert_validation: ignore
然后我的剧本如下所示:
- hosts: '{{ target }}'
name: Stop JBoss and App Services.
remote_user: '{{ ansible_user }}'
tasks:
- name: Stopping JBoss Service.
win_service:
name: '{{ jboss_service_name }}'
start_mode: manual
state: stopped
- name: Stopping App Service.
win_service:
name: '{{ app_service_name }}'
start_mode: manual
state: stopped
所以我可以按如下方式运行我的游戏:
ansible-playbook my-playbook.yml --extra-var "target=client_1"
或者对于所有 Windows 机器:
ansible-playbook my-playbook.yml --extra-var "target=windows"
这工作正常,我按照上面列出的方式工作。但是,此解决方案适用于我的客户的单个服务器设置。这意味着 jboss、应用程序、Web 和数据库服务器都在同一台物理服务器上 - 在本例中为 172.0.0.1。
然而,情况并非总是如此。对于任何给定的客户端,它可能是共享或分布式设置。这意味着 jboss、app、web、db 服务可能在单个服务器上,或者每个都在自己的服务器上。
所以我一直在尝试调整此设置,但我不确定如何运行我的游戏以便在特定客户端服务器上执行摊牌服务命令。我仍然需要能够在单个客户端或组 - Windows 上执行剧本。
这是我到目前为止的想法。
hosts(删除了 ansible_host=...)
[windows]
client_1
[linux]
client_2
client_3
group_vars/windows(这里没有变化)
jboss_service_name: JBOSSAS7SVC
app_service_name: APPSRVC
...
host_vars/client_1(将 ip 地址下移到客户端 host_var 级别)
ansible_user: username
ansible_password: pasword
ansible_port: 5986
ansible_connection: winrm
ansible_winrm_server_cert_validation: ignore
app_server: 172.0.0.1
jboss_server: app_server: 172.0.0.2
web_server: app_server: 172.0.0.3
...
在上面的 host_var 文件中,如果它是一个共享设置,我只需将 **_server* 变量设置为都使用相同的 IP 地址。
我创建了一个测试 playbook,用于调试 host_var 文件和 group_var 文件中的打印变量,这意味着它可以访问所有这些数据。
我执行如下:
ansible-playbook -i client_1 test-playbook.yml
然后我可以传入组窗口而不是客户端主机。
但我不明白的是如何编辑我的旧剧本以利用这些新变量,例如调用 win_service 以关闭该客户端的 jboss 应该只在服务器 host_vars/client_1.app_server 上执行,同样关闭我的应用程序服务应该只在该客户端的服务器 app_server 上运行。
我知道这是一篇很长的文字,所以感谢您花时间阅读。
那么我的问题是,我完全错了吗?我应该如何构建我的主机,以便我可以区分 Windows 和 Linux 主机,可以由客户端设置,并能够支持任何给定客户端的共享或分布式服务器设置?
非常感谢。
最佳答案
将您的主机命名为不同的名称,但使用相同的 IP 地址:
[windows_app]
wa01 ansible_host=111.111.111.1
[windows_jboss]
wj01 ansible_host=111.111.111.1
[windows:children]
windows_app
windows_jboss
在 group_vars/windows_app
和 group_vars/windows_jboss
中定义 service_name
。
您的剧本应该为特定剧本定义主机:
- hosts: windows
name: Stop JBoss and App Services on Windows servers
remote_user: '{{ ansible_user }}'
tasks:
- name: Stopping Service.
win_service:
name: '{{ service_name }}'
start_mode: manual
state: stopped
不要使用--extra-vars
,而是使用-l
或--limit=
来停止一个服务而不是另一个:
ansible-playbook test-playbook.yml -l windows_app
关于linux - Ansible 主机/组结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44415928/
尽管用户是 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""
我是一名优秀的程序员,十分优秀!