Ansible自动化运维工具主机清单配置

ops/2024/12/22 17:39:10/

作者主页:点击! 

Ansible专栏:点击!

创作时间:2024年4月24日12点21分


Ansible主机清单文件用于定义要管理的主机及其相关信息。它是Ansible的核心配置文件之一,用于Ansible识别目标主机并与其建立连接。

主机清单文件通常位于Ansible控制器的/etc/ansible/hosts目录下,也可自定义位置。文件内容使用YAML格式编写,语法简单易懂。

1.增加主机组

(host1做了免密登录 可以直接ssh访问)

(host2 没有免密登录 所以需要输入用户和密码才可以ssh访问)

这边host2访问失败也很正常因为没有设置免密需要用户和密码

访问的时候直接访问组 可以包括所有的主机 十分的方便

文件 /etc/ansible/hosts 是 Ansible 控制机上 Ansible 库存文件的默认位置。

有两种方法可以在此文件中定义主机:

  • 按组:将相似的主机分组以便更好地管理。
  • 单独:单独定义每个主机。
[root@localhost ~]# ansible webServer -m ping -o
host2 | UNREACHABLE!: Failed to connect to the host via 
ssh: ssh: Could not resolve hostname host2: Name or service not known
host1 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python"
: "/usr/bin/python"}, "changed": false, "ping": "pong"}

2.增加用户名密码

我们在内部设置密码这样更加的方便快捷去访问

符合自动化运维的特征

接着我们在测试连通性(一举拿下!!!!!!!!!!!!)

ansible webServers -m ping -o

3.组变量

Ansible 组变量是一种将变量与主机关联的方式,用于为组内所有主机设置共享属性。这可以简化 Playbook 的编写,提高配置的一致性和可维护性。

优点

使用组变量具有以下优点:

  • 提高代码简洁性: 无需在 Playbook 中重复定义相同变量,使代码更简洁易读。
  • 增强配置一致性: 确保组内所有主机都使用相同的配置值,避免配置差异。
  • 简化维护工作: 当需要修改配置时,只需修改组变量即可,无需逐个修改主机变量。
  • 提高灵活性: 可以根据组的不同特征定义不同的变量,满足不同组的配置需求。
vim /etc/ansible/host

通过以下配置就是创建一个webServers组 并且加入两个主机 再给组赋予变量 用户名和密码 这样组下的所有主机都可以访问 更加的便捷

[webServers]
host1
host2[webServers:vars]
ansible_ssh_user='root'
ansible_ssh_pass='abc-123'

常用的一些变量

4.子分组

Ansible 中的子分组

Ansible 主机清单支持多级分组功能,也被称为子分组。这是一种将主机组织成层级结构的有效方法,可以使清单更易于管理和维护,尤其是在复杂的环境中。

优点

使用子分组具有以下优点:

  • 提高组织性: 将相关的主机分组在一起,使清单更加清晰明了,易于理解和查找目标主机。
  • 简化管理: 可以对子组应用通用的配置和操作,减少重复任务,提高管理效率。
  • 增强灵活性: 可以根据需要创建多级子分组,满足不同层次的管理需求。
  • 支持条件过滤: 可以使用条件表达式过滤子组中的主机,更精准地定位目标主机。

没有定义webServers组之前

调用的时候需要单独去输出

[root@localhost ~]# ansible apache -m ping -o
host1 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}
[root@localhost ~]# ansible mysql -m ping -u root -k -o
SSH password: 
host2 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}

定义之后

调用webServers就等于调用apache,mysql 并且给组赋予的属性(用户名和权限)也可以使用

[root@localhost ~]# ansible webServers -m ping  -o
host2 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}
host1 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}

5.自定义主机列表

Ansible 提供了多种方式来定义和管理主机列表,除了默认的 /etc/ansible/hosts 文件之外,您还可以使用自定义主机列表。这提供了更大的灵活性,允许您根据需要从不同来源获取主机信息。

优点

使用自定义主机列表具有以下优点:

  • 灵活性: 可以从各种来源获取主机信息,例如数据库、API、文件等。
  • 可扩展性: 随着主机数量的增加,可以轻松添加新主机而无需手动修改清单文件。
  • 动态性: 可以根据主机状态或其他条件动态更新主机列表。
  • 可重用性: 可以创建多个自定义主机列表,并根据需要在 Playbook 中使用。

我们在当前的目录下定义一个hostlist 加入写好的配置衣语法

[root@localhost ~]# vim /etc/ansible/hosts 
[root@localhost ~]# ls
anaconda-ks.cfg
[root@localhost ~]# ls
anaconda-ks.cfg
[root@localhost ~]# vim hostlist
[root@localhost ~]# ls
anaconda-ks.cfg  hostlist

这时我们来测试一下

[root@localhost ~]# ansible -i hostlist webServers  -m ping -o
host2 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}
host1 | SUCCESS => {"ansible_facts": {"discovered_interpreter_python": "/usr/bin/python"}, "changed": false, "ping": "pong"}
ansible -i hostlist webServers  -m ping -o

从hostlist中调用webServers这个组来检测

  • ansible :这是 Ansible 可执行命令。
  • -i hostlist :此选项指定要使用的清单文件。在本例中,您使用的是名为 hostlist 的自定义清单文件。
  • webServers :这是您要在其上执行 Ansible 模块的目标主机组或主机名。
  • -m ping :此选项指定您要运行的 Ansible 模块。在这里,您使用 ping 模块来检查与目标主机的连接。

http://www.ppmy.cn/ops/23264.html

相关文章

Java 设计模式(行为型)

文章目录 策略模式迭代器模式访问者模式观察者模式命令模式模板方法模式事件驱动模式责任链模式中介者模式状态模式 策略模式 策略模式是一种行为设计模式,它定义了一系列算法,将每个算法封装在独立的策略类中,并使它们可以互相替换。策略模…

如何将本地项目上传到Github(SSH方式)

天行健,君子以自强不息;地势坤,君子以厚德载物。 每个人都有惰性,但不断学习是好好生活的根本,共勉! 文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。…

Linux入门攻坚——21、gawk入门

gawk——GNU awk 文本处理三剑客:grep,sed,awk grep,egrep,fgrep:文本过滤工具,pattern; sed:行编辑器:模式空间、保持空间; awk:报告…

任务调度xxljob的使用记录

1.基本使用 a.下载代码,地址:https://gitee.com/xuxueli0323/xxl-job.git b.执行sql,修改配置,启动任务调度中心的代码 启动代码后任务调度中心访问地址:http://localhost:8080/xxl-job-admin(自己机器…

【前端面试常问】什么是响应式❓Vue2/Vue3中响应式的原理

🔥 浅析Vue2/Vue3中响应式的原理 👋 大家好,今天我们来聊聊前端开发中经常提到的“响应式”概念,并剖析Vue2和Vue3是如何实现响应式原理的。对于前端开发者来说,理解响应式原理不仅能帮助我们更好地使用框架&#xff0…

Java基础知识总结(73)

1、今天学了什么 1、线程休眠 (1)sleep() 如果需要让当前正在执行的线程暂停一段时间,并进入阻塞状态(Timed_Waiting),则可以通过调用Thread类的静态sleep()方法来实现。 static void sleep(long millis):让…

Trello与Notion的开源替代项目管理利器Focalboard本地安装与远程访问

本篇文章将介绍如何使用 Docker 本地部署 Focalboard 项目管理工具,并且结合 cpolar 内网穿透进行公网访问,实现团队协作,提高工作效率! Focalboard 是一个开源项目管理工具,可以替代 Asana、Trello 和 Notion 等软件…

TP8 利用jwt 生成token

使用Composer安装依赖库&#xff0c;终端切换到项目根目录输入如下 composer require firebase/php-jwt 下面是示例代码&#xff1a; <?php namespace app\common\base;use Firebase\JWT\JWT; use Firebase\JWT\Key;class Token {/*** 创建 token* param array $data 必填…