当前位置: 首页 > article >正文

ansible基础教程(上)

一、介绍:

Ansible是一款用于软件配置、配置管理和软件部署的开源自动化和编排工具。相比于其它的工具,Ansible的安装更加简单、易于使用。通过SSH到客户端的方式进行连接,因此它不需要在客户端有特殊的代理,并且通过将模块推送到客户端,模块然后在客户端本地执行,并将输出推送回 Ansible 服务器。

由于它使用 SSH,因此可以非常轻松地使用 SSH 密钥连接到客户端,从而简化整个过程。客户端详细信息(如主机名或 IP 地址和 SSH 端口)存储在称为清单文件的文件中。创建清单文件并填充后,ansible 就可以使用它了。

二、优势:

Ansible相比于其他的自动化工具,具有以下优点:

  1. 开源免费,所有人都可以使用。

  2. 基于YAML语法编写剧本(相当于shell的自动化脚本),被称为playbook,YAML 语法简洁、易读,具有良好的层次结构。以下是一个简易部署Apache的playbook

    - name: Install and start Apache
      hosts: web_servers
      tasks:
        - name: Install Apache package
          yum:
            name: httpd
            state: present
        - name: Start Apache service
          service:
            name: httpd
            state: started

    这个 Playbook 首先定义了任务名称(name),然后指定了目标主机组(hosts),接着列出了具体的任务(tasks),包括安装软件包(yum模块)和启动服务(service模块)。

  3. Ansible 不需要在被管理的节点上安装额外的代理软件。它通过 SSH(Secure Shell)协议来连接和管理目标主机,这使得 Ansible 的部署更加简单和快速。与一些需要在每个节点上安装代理才能工作的自动化工具相比,Ansible 减少了额外的配置和维护工作。

  4. 丰富的内置模块:Ansible 提供了大量的内置模块,可以用于各种系统管理任务,如软件包管理、文件操作、用户管理、服务管理等。以软件包管理为例,对于基于 Debian 的系统有apt模块,对于基于 Red Hat 的系统有yum模块。这些模块可以轻松地安装、升级或删除软件包。

  5. 易于扩展模块:除了内置模块,Ansible 还允许用户通过自定义模块来扩展其功能。用户可以使用 Python 或其他编程语言编写自定义模块,以满足特定的自动化需求。

  6. 并行执行任务:Ansible 可以在多个目标主机上并行地执行任务,这大大提高了自动化操作的效率。它能够根据目标主机的数量和系统资源自动调整并行度,从而在短时间内完成大规模的部署或配置任务。

  7. 任务依赖管理:Playbooks 支持定义任务之间的依赖关系。这意味着可以指定某些任务必须在其他任务完成之后才能执行,确保自动化流程的顺序和逻辑正确性。

  8. 动态主机清单(Inventory):Ansible 的主机清单是一个灵活的配置文件,用于定义要管理的目标主机。主机清单可以是静态的(手动编辑主机列表和相关变量),也可以是动态的。动态主机清单可以通过脚本或其他方式从外部数据源(如云服务提供商的 API、配置管理数据库等)获取主机信息,使得 Ansible 能够轻松地适应不断变化的基础设施环境。

  9. 主机变量和组变量:在主机清单中,可以为每个主机或主机组定义变量。这些变量可以用于定制化任务执行,例如根据不同主机的操作系统版本或硬件配置来执行不同的操作。

三、安装:

在Centos中安装Ansible

# rpm包安装:
EPEL源 
yum install -y epel-release 
yum install -y ansible  

查看版本信息

ansible-doc --version

修改配置文件

/etc/ansible/hosts

可以在最后面添加如下

[test]         此处表示受控节点ip
192.168.119.134

[all]           此处表示所有节点的ip,前者为主控节点,后者为受控节点
192.168.119.182
192.168.119.134

可以使用ansible all --list-hosts命令查看所有的主机

ect/ansible/ansible.cfg

将该文件内的如下内容取消注释

去掉第一次连接ssh ask确认

开启记录日志

生成密钥,并将主控节点的密钥发送给受控节点

ssh-keygen

远程连接受控节点

ssh root@192.168.119.134

可以看到已经连接到受控节点,接下来设置免密登录

ssh-copy-id root@192.168.119.134

可以看到不需要输入密码,直接就可以连接受控节点

接下来进行主机连通性测试

ansible all -m ping

可以看到受控节点成功连通,但是主控节点却显示失败,原因是主控节点没有设置免密登录,接下来设置主控节点免密登录

将主控节点做免密登录之后再次测试连通性,这次全部都显示成功。

四、命令详解:

1.命令集:

/usr/bin/ansible  Ansibe AD-Hoc 临时命令执行工具,常用于临时命令的执行
/usr/bin/ansible-doc   Ansible 模块功能查看工具
/usr/bin/ansible-galaxy  下载/上传优秀代码或Roles模块 的官网平台,基于网络的
/usr/bin/ansible-playbook  Ansible 定制自动化的任务集编排工具
/usr/bin/ansible-pull  Ansible远程执行命令的工具,拉取配置而非推送配置(使用较少,海量机器时使用,对运维的架构能力要求较高)
/usr/bin/ansible-vault  Ansible 文件加密工具
/usr/bin/ansible-console  Ansible基于Linux Consoble界面可与用户交互的命令执行工具

2.anible-doc命令:

ansible-doc -l #获取全部模块的信息 
ansible-doc -s MOD_NAME #获取指定模块的使用帮助

例如查看mysql有哪些模块

ansible-doc -l |grep mysql

3.ansible命令详解:

-a MODULE_ARGS   #模块的参数,如果执行默认COMMAND的模块,即是命令参数,如: “date”,“pwd”等等
-k,--ask-pass #ask for SSH password。登录密码,提示输入SSH密码而不是假设基于密钥的验证
--ask-su-pass #ask for su password。su切换密码
-K,--ask-sudo-pass #ask for sudo password。提示密码使用sudo,sudo表示提权操作
--ask-vault-pass #ask for vault password。假设我们设定了加密的密码,则用该选项进行访问
-B SECONDS #后台运行超时时间
-C #模拟运行环境并进行预运行,可以进行查错测试
-c CONNECTION #连接类型使用
-f FORKS #并行任务数,默认为5
-i INVENTORY #指定主机清单的路径,默认为/etc/ansible/hosts
--list-hosts #查看有哪些主机组
-m MODULE_NAME #执行模块的名字,默认使用 command 模块,所以如果是只执行单一命令可以不用 -m参数
-o #压缩输出,尝试将所有结果在一行输出,一般针对收集工具使用
-S #用 su 命令
-R SU_USER #指定 su 的用户,默认为 root 用户
-s #用 sudo 命令
-U SUDO_USER #指定 sudo 到哪个用户,默认为 root 用户
-T TIMEOUT #指定 ssh 默认超时时间,默认为10s,也可在配置文件中修改
-u REMOTE_USER #远程用户,默认为 root 用户
-v #查看详细信息,同时支持-vvv,-vvvv可查看更详细信息

五、模块:

1.定义

Ansible 模块是 Ansible 用于执行特定任务的独立脚本单元。这些模块是用 Python 等编程语言编写的(Ansible 核心是用 Python 实现的,大多数模块也是 Python 脚本),它们被 Ansible 引擎发送到目标主机上运行,以实现各种系统管理和自动化任务。

2.常用模块:

commond模块:

这个模块可以直接在远程主机上执行命令,并将结果返回本主机。

ansible test -m command -a 'touch 2.sh'

该条命令的意思是把test清单中的服务器执行touch命令创建文件,我们在test清单中的服务器查看是否创建成功

可以看到是创建成功的,这里的警告意思是让我们通过playbook的格式,不过这里为了测试,可以忽略。

下面来看看该模块下常用的几个命令:

chdir       # 在执行命令之前,先切换到该目录
executable # 切换shell来执行命令,需要使用命令的绝对路径
free_form   # 要执行的Linux指令,一般使用Ansible的-a参数代替。
creates  # 一个文件名,当这个文件存在,则该命令不执行,可以
用来做判断
removes # 一个文件名,这个文件不存在,则该命令不执行

以下对这些命令进行示例

ansible test -m command -a 'chdir=/root/ touch 3.sh'

该命令表示先切换目录到/root/,之后再执行touch命令,再test服务器上查看,可以看到创建成功

ansible test -m command -a 'creates=/root/3.sh touch 4.sh'

该命令的意思是如果3.sh文件存在,则不执行touch命令,起到一个判断作用,查看以下test服务器,可以看到确实没有创建4.sh

ansible test -m command -a 'removes=/root/3.sh touch 4.sh'

该命令与上条命令意义相反,表示3.sh文件存在则执行touch命令

再test上查看是否创建成功

可以看到创建成功。

更多模块将在下次进行学习上传。


http://www.kler.cn/a/427896.html

相关文章:

  • 【AI】DeepSeek 概念/影响/使用/部署
  • 汽车蓝牙钥匙定位仿真小程序
  • 32. C 语言 安全函数( _s 尾缀)
  • 商品列表及商品详情展示
  • thinkphp6+swoole使用rabbitMq队列
  • 【深度分析】DeepSeek 遭暴力破解,攻击 IP 均来自美国,造成影响有多大?有哪些好的防御措施?
  • UE5 Compile Plugins | Rebuild from Source Manually | Unreal Engine | Tutorial
  • 如何在Ubuntu 20.04上编译安装OpenCV 4.4并启用pkg-config支持
  • 【工具变量】上市公司企业商业信用融资数据(2003-2022年)
  • LeetCode - #152 乘积最大子数组(Top 100)
  • ADB常用各模块操作命令
  • 第二部分:基础知识 5.控制流 --[JavaScript 新手村:开启编程之旅的第一步]
  • 【趋势红蓝交易】主图指标操盘技术图文展示,注意要点,通达信炒股软件指标
  • Android 按两下power键不打开相机改为打开手电筒
  • 第三周作业
  • 如何在MySQL中开启死锁日志及查看日志
  • 超详细!!关于Docker的访问仓库操作
  • TCP Analysis Flags 之 TCP Spurious Retransmission
  • Apache Dolphinscheduler可视化 DAG 工作流任务调度系统
  • 【Elasticsearch】ES+MySQL实现迷糊搜索
  • 【062B】基于51单片机无线病房呼叫系统(+时间)【Keil程序+报告+原理图】
  • 使用CIFS挂载nas到centos
  • Android仿美团左右联动购物列表
  • 数据分析类论文通过stata进行数据预处理(一)
  • 数据仓库全生命周期管理
  • 怎么实现邮件营销自动化?