自动化运维工具—Ansible-1

简介: 自动化运维工具—Ansible

一、Ansible概述


1.1 Ansible是什么

Ansible是一个基于Python开发的配置管理和应用部署工具,现在也在自动化管理领域大放异彩。它融合了众多老牌运维工具的优点,Pubbet和Saltstack能实现的功能,Ansible基本上都可以实现。


市面上其他自动化工具:pupet(ruby语言) saltstack(python) chef(C/S模式)等


Ansible能批量配置、部署、管理上千台主机。比如以前需要切换到每个主机上执行的一或多个操作,使用Ansible只需在固定的一台Ansible控制节点上去完成所有主机的操作。


Ansible是基于模块工作的,它只是提供了一种运行框架,它本身没有完成任务的能力,真正执行操作的是Ansible的模块, 比如copy模块用于拷贝文件到远程主机上,service模块用于管理服务的启动、停止、重启等。


1.2 Ansible的特性

(1)特性一


Ansible其中一个比较鲜明的特性是Agentless,即无Agent的存在,它就像普通命令一样,并非C/S软件,也只需在某个作为控制节点的主机上安装一次Ansible即可,通常它基于ssh连接来控制远程主机,远程主机上不需要安装Ansible或其它额外的服务。


使用者在使用时,在服务器终端输入命令或者playbooks,会通过预定好的规则将playbook拆解为play,再组织成ansible可以识别的任务,调用模块和插件,根据主机清单通过SSH将临时文件发给远程的客户端执行并返回结果,执行结束后自动删除


(2)特性二


Ansible的另一个比较鲜明的特性是它的绝大多数模块都具备幂等性(idempotence)。所谓幂等性,指的是多次操作或多次执行对系统资源的影响是一致的。比如执行 systemctl stop xxx 命令来停止服务,当发现要停止的目标服务已经处于停止状态, 它什么也不会做,所以多次停止的结果仍然是停止,不会改变结果,它是幂等的,而 systemctl restart xxx 是非幂等的。


Ansible的很多模块在执行时都会先判断目标节点是否要执行任务,所以,可以放心大胆地让Ansible去执行任务,重复执行某个任务绝大多数时候不会产生任何副作用。


1.3 Ansible的特点

  • 部署简单,只需在主控端部署Ansible环境, 被控端无需做任何操作
  • 默认使用SSH协议设备进行管理;
  • 主从集中化管理
  • 配置简单、功能强大、扩张性强;
  • 支持API及自定义模块,可以通过Pyhton轻松扩展
  • 通过playbooks 来定制强大的配置、状态管理
  • 对云计算平台、大数据都有很好的支持

1.4 Ansible数据流向

Host Inventory:记录Ansible管理的主机信息,包含端口、密码、IP等


Playbooks:剧本 YMAL 格式文件,多个任务定义在一个文件中,定义主机需要调用哪些模块来完成的功能


Core Modules:核心模块 主要操作是通过调用核心模块来完成任务


Connection Plugins:连接主机,是插件,ansible和 Host (主机) 通信使用


Custom Modules:自动定义模块,完成核心模块无法完成的功能,支持多种语言


6c42b874ec6c4157aa47c71a9a08ffa8.png


二、Ansible 环境安装部署



IP
服务
管理端 192.168.147.105 ansible
被管理端 192.168.147.106
被管理端 192.168.147.107


//管理端安装 ansible
yum install -y epel-release     //先安装 epel 源
yum install -y ansible
//ansible 目录结构
/etc/ansible/
├── ansible.cfg     #ansible的配置文件,一般无需修改
├── hosts       #ansible的主机清单,用于存储需要管理的远程主机的相关信息
└── roles/        #公共角色目录
//配置主机清单  
cd /etc/ansible 
vim hosts       
[webservers]      #配置组名
192.168.147.106     #组里包含的被管理的主机IP地址或主机名(主机名需要先修改/etc/hosts文件)
[dbservers]
192.168.147.107
//配置密钥对验证
ssh-keygen
#生成公钥,输入命令输入4个回车即可
cd ~/.ssh
ssh-copy-id -i   192.168.147.106
ssh-copy-id -i   192.168.147.107
#进入生成的公钥路径将公钥传输给备管理的服务器,传输需要输入每台备管理服务的root密码
//进行验证
ssh 192.168.147.106


0c04c19c4f134a7dbe1391372b134844.png

f3c098ccd9b349e1b4ec4abbfea737f1.png

411e2a8b138a496c8cca0fdf97c09423.png

e7baacc0092f46b5a084f375a0eda0f3.png


三、Ansible 命令行模块


命令格式


ansible <组名> -m <模块> -a <参数列表>
ansible <主机IP> -m <模块> -a <参数列表>
ansible <主机名> -a <参数列表>      #不加-m指定模块默认使用command
#选项解释
-m: 指定模块
-a: 指定命令
ansible-doc -l        #列出所有已安装的模块,按q退出

(1)command 模块

在远程主机执行命令,不支持管道,重定向等shell的特性。


ansible-doc -s command    #-s 列出指定模块的描述信息和操作动作
ansible 192.168.147.106 -m command -a 'date'    #指定 ip 执行 date
ansible webservers -m command -a 'date'     #指定组执行 date
ansible dbservers -m command -a 'date'       
ansible all -m command -a 'date'        #all 代表所有 hosts 主机
ansible all -a 'ls /'             #如省略 -m 模块,则默认运行 command 模块

288edeff9cc444c1b9badca1eaa28c92.png30646e7ac26649eb92c59af6f90632f9.png


6e92a7be7a094f0d842b0f8d6eba1fa7.png


//常用的参数:
chdir:在远程主机上运行命令前提前进入目录
creates:判断指定文件是否存在,如果存在,不执行后面的操作
removes:判断指定文件是否存在,如果存在,执行后面的操作
ansible all -m command -a "chdir=/home  ls ./"

9e0bc7e9167941458d2489dbda4bb3ad.png076edfb0fc1a4a5eb6380359178c75d5.png


df3afe8350d945aebe8cdab2b6772807.png

(2)shell 模块

在远程主机执行命令,相当于调用远程主机的shell进程,然后在该shell下打开一个子shell运行命令(支持管道符号等功能)


ansible-doc -s shell
免交互修改用户密码
ansible dbservers -m shell -a 'echo 123456 | passwd --stdin test'
过滤ens33网卡地址
ansible dbservers -m shell -a 'echo $(ifconfig ens33 | awk "NR==2 {print $2}") | cut -d " " -f2'
ansible dbservers -m shell -a 'echo $(ifconfig ens33 | awk "NR==2 {print \$2}")'

1e0819986d4d4a39b8a26dbc20da0638.png

fdf4d2e7ce47447ca69c581b5da67c1a.png

99bd8fdccecf48d383de0a92b114b6f6.png


目录
相关文章
|
18天前
|
敏捷开发
【sgCreatePinyin】自定义小工具:敏捷开发→自动化生成拼音字段名称(字段名生成工具)
【sgCreatePinyin】自定义小工具:敏捷开发→自动化生成拼音字段名称(字段名生成工具)
|
1月前
|
存储 运维 安全
构建高效自动化运维体系:Ansible与Docker的完美结合
【2月更文挑战第31天】 随着云计算和微服务架构的兴起,自动化运维成为保障系统稳定性和提升部署效率的关键手段。本文将详细探讨如何通过Ansible和Docker的结合来构建一个高效、可靠且易于管理的自动化运维体系。首先,介绍自动化运维的必要性及其在现代IT基础设施中的作用;然后,分别阐述Ansible和Docker的技术特点及优势;最后,提供一个基于Ansible和Docker结合使用的实践案例,以及实施过程中遇到的挑战和解决方案。
|
1月前
|
移动开发 安全 数据安全/隐私保护
iOS 全局自动化代码混淆工具!支持 cocoapod 组件代码一并混淆
iOS 全局自动化代码混淆工具!支持 cocoapod 组件代码一并混淆
|
1月前
|
jenkins 测试技术 持续交付
现代软件测试中的自动化工具与挑战
随着软件开发领域的不断发展,自动化测试工具在测试过程中扮演着越来越重要的角色。本文将探讨现代软件测试中自动化工具的应用及面临的挑战,旨在帮助开发人员和测试人员更好地理解和应对自动化测试中的问题。
|
2天前
|
算法 安全 Linux
Ansible自动化工具copy复制用法
Ansible 中的 copy 模块用于将文件或目录从本地计算机或远程主机复制到远程主机上的特定位置。它是一个功能强大的模块,可用于各种文件传输任务. ### 作用 将配置文件复制到远程服务器 将应用程序部署到远程服务器 将日志文件从远程服务器复制到本地计算机 备份和恢复文件和目录
Ansible自动化工具copy复制用法
|
2天前
|
存储 运维 Kubernetes
构建高效自动化运维体系:Ansible与Kubernetes的协同策略
【4月更文挑战第25天】 在当今快速迭代的软件开发过程中,自动化运维已成为提升效率、保证一致性和降低人为错误的关键。本文将探讨如何利用Ansible作为配置管理工具,以及Kubernetes作为容器编排系统,共同构建一个高效、可靠的自动化运维体系。文章首先概述了自动化运维的基本概念及其重要性,随后详细分析了Ansible与Kubernetes在自动化流程中的作用与优势,并通过一系列实践案例,展示了两者如何协同工作以优化部署、扩缩容和灾难恢复等关键运维任务。最后,文中还讨论了在实际应用中可能遇到的挑战及相应的解决策略,为读者提供了一套完整的自动化运维解决方案参考。
|
3天前
|
存储 运维 Shell
Ansible自动化运维工具安装和基本使用
Ansible 是一款无代理的IT自动化工具,通过SSH连接目标主机执行配置管理、应用部署和云端管理任务。它使用YAML编写的Playbook定义任务,核心组件包括Playbook、模块、主机清单、变量等。Ansible的优势在于易用、功能强大、无须在目标主机安装额外软件,并且开源。安装过程涉及配置网络源、yum安装和SSH密钥设置。通过定义主机清单和使用模块进行通信测试,确保连接成功。
Ansible自动化运维工具安装和基本使用
|
3天前
|
机器学习/深度学习 运维 网络协议
运维工程师必会工具(Nmap和TCPdump)
运维工程师必会工具(Nmap和TCPdump)
|
18天前
|
敏捷开发
【sgCreateTableData】自定义小工具:敏捷开发→自动化生成表格数据数组[基于el-table]
【sgCreateTableData】自定义小工具:敏捷开发→自动化生成表格数据数组[基于el-table]
|
26天前
|
Java 测试技术 API
软件测试中的自动化工具与策略
软件测试是确保软件质量的重要环节,而自动化测试工具和策略的应用在提高测试效率和准确性方面发挥着重要作用。本文将介绍几种常见的自动化测试工具,并探讨在软件测试中应用自动化测试的最佳实践和策略。

热门文章

最新文章