Ansible自动化运维工具-上

[Ansible特点]

1)Ansible与saltstack均是基于Python语言开发的

2)安装使用简单,基于不同插件和模块实现各种软件,平台,版本的管理以及支持虚拟容器多层级的部署

3)不需要安装客户端,ansible基于SSH远程管理,不需要为配置工作添加额外的支持;

PS:很多认为Ansible工具执行效率慢,其原因是SSH服务慢,我们可以选择优化SSH连接速度以及Ansible加速模块

【Ansible自动化管理工具特点】

#轻量级,更新时,需要在操作机上进行一次更新即可

#采用SSH协议

#不需要去客户端安装Agent;

#批量任务执行可以写成脚本,而且不用分发到远程就可以执行

#使用python编写,维护简单,支持sudo普通用户命令,中心化管理

【Ansible工具的安装配置】

Ansible可以工作在Linux,BSD,Mac OS X等平台,对于

Red Hat、CentOS操作系统可以直接基于YUM工具自动安装Ansible,CentOS6.x或者CentOS7.x安装前,需先安装epel扩展源,

[[email protected] ~]# rpm -Uvh http://mirrors.ustc.edu.cn/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpm   安装epel扩展源

[[email protected] ~]# yum install -y epel-release ansible

[[email protected] ~]# cd /etc/ansible/
[[email protected] ansible]# ls
ansible.cfg     hosts    roles

PS:ansible.cfg为主配置文件,host文件为被管理机IP或者主机名列表;roles为角色或者插件路径,该目录为空;

Ansible远程批量管理,其中执行命令是通过Ad-Hoc来完成的,也就是点对点执行命令,能够快速的执行,而且不需要保存执行的命令,默认host文件配置主机列表,可以配置分组,可以自定义各种IP及规则

Ansible基于多模块管理,常用的Ansible工具模块包括:command,shell,script,yum,copt,File,async,docker,cron,mysql_user,ping,acl,add_host,easy_install.haproxy等等

  可使用ansible-doc -l | morec查看ansible支持的模块,也可以查看每个模块的帮助文档

【Ansible工具参数详解】

基于Ansible批量管理之前,需要被管理的服务器IP列表添加到/etc/ansible/hosts配置文件中如下定义为web服务组以及对应的IP

[webserver]
192.168.2.138
192.168.2.139

基于Ansible自动化运维工具管理客户端案列操作,由于ansible管理远程服务器基于SSH,在远程服务器执行命令时需要远程服务器的用户名和密码,也可以加入-k参数手动输入密码或者基于SSH-keygen生成免秘钥;

【主要参数如下】

-v,–verbose                                      打印详细模式;

-i PATH,–inventory=PATH                       指定host文件路径;

-f NUM,–forks=NUM                             指定fork开启同步进程的个数,默认5;

-m NAME,–module-name=NAME           指定module名称,默认模块command;

-a MODULE_ARGS                       module模块的参数或者命令;

-k,–ask-pass                           输入远程被管理端密码;

–sudo                               基于sudo用户执行;

-K,–ask-sudo-pass                      提示输入sudo密码与sudo一起使用;

-u USERNAME,–user=USERNAME         指定移动端的执行用户;

-C,–check                            测试执行过程,不改变真实内容,相当于预演;

-T TIMEOUT,                                           执行命令超时时间,默认为10秒;

--version                                                  查看Ansible软件版本信息。

 【Ansible配置文件详解】

Ansible默认配置文件为/etc/ansible/ansible.cfg,配置文件中可以对ansible进行各项参数的调整,包括并发线程,用户,模块路径,配置优化等等

[defaults]            #通用默认配置段

#inventory = /etc/ansible/hosts                 #被控端IP或者DNS列表
#library = /usr/share/my_modules/             #ansible默认搜寻模块位置
#module_utils = /usr/share/my_module_utils/        
#remote_tmp = ~/.ansible/tmp            #ansible远程执行临时文件;
#local_tmp = ~/.ansible/tmp      
#forks = 5                            #并行进程数
#poll_interval = 15               #回频率或者轮训间隔时间
#sudo_user = root               #sudo远程执行用户名
#ask_sudo_pass = True            #使用sudo,是够需要输入密码
#ask_pass = True                   #是否需要输入密码
#transport = smart                  #通信机制
#remote_port = 22                    #远程SSH端口
#module_lang = C                   #模块和系统之间通信语言
#module_set_locale = False

#gathering = implicit             #控制默认facts收集(远程系统变量)

roles_path= /etc/ansible/roles                     用于playbook搜索Ansible roles;

host_key_checking = False                             检查远程主机密钥;

#sudo_exe = sudo                                      sudo远程执行命令;

#sudo_flags = -H                                              传递sudo之外的参数;

timeout = 10                                                    SSH超时时间;

remote_user = root                                  远程登陆用户名;

log_path = /var/log/ansible.log                日志文件存放路径;

module_name = command                             Ansible命令执行默认的模块;

#executable = /bin/sh                             执行的Shell环境,用户Shell模块;

#hash_behaviour = replace                             特定的优先级覆盖变量;

#jinja2_extensions                              允许开启Jinja2拓展模块;

#private_key_file = /path/to/file             私钥文件存储位置;

#display_skipped_hosts = True                       显示任何跳过任务的状态;

#system_warnings = True                               禁用系统运行ansible潜在问题警告;

#deprecation_warnings = True                          Playbook输出禁用“不建议使用”警告;

#command_warnings = False                       command模块Ansible默认发出警告;

#nocolor = 1                                                  输出带上颜色区别,开启/关闭:0/1;

pipelining = False                                             开启pipe SSH通道优化;

[accelerate]                                                      accelerate缓存加速。

accelerate_port = 5099

accelerate_timeout = 30

accelerate_connect_timeout = 5.0

accelerate_daemon_timeout = 30

accelerate_multi_key = yes

时间: 2024-12-17 05:34:11

Ansible自动化运维工具-上的相关文章

Ansible自动化运维工具部署及使用

一.Ansible介绍 1.简介 ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)的优点,实现了批量系统配置.批量程序部署.批量运行命令等功能.ansible是基于模块工作的,本身没有批量部署的能力.真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架.主要包括: (1).连接插件connection plugins:负责和被监控端实现通信: (2).host inven

ansible自动化运维工具使用详解

一.ansible简介 1.ansible ansible是新出现的自动化运维工具,基于Python研发.糅合了众多老牌运维工具的优点实现了批量操作系统配置.批量程序的部署.批量运行命令等功能.仅需在管理工作站上安装ansible程序配置被管控主机的IP信息,被管控的主机无客户端.ansible应用程序存在于epel(第三方社区)源,依赖于很多python组件 参考站点:http://www.ansible.com.cn 2.ansible特性 模块化设计,调用特定的模块来完成特定任务,本身是核

Puppet Saltstatck Ansible 自动化运维工具对比

最近尝试安装了一下salt statck就对自动化工具感兴趣了点所以找了一些资料入门下面总结一下希望和看到这篇文章一起探索自动化运维的世界.                              --- 小 Q ------------------------------------------------------------------------------------------------------ 自动化运维就是为减少重复又枯燥的工作而建立起来的流程更能减少失误及时报警并恢复

Linux中ansible自动化运维工具

1.ansible简介ansible是一款自动化运维工具,基于Python开发,集合了众多运维工具(puppet,cfengine,chef,func,fabric)的优点,实现了批量系统配置,批量 程序部署,批量运行命令等功能.ansible是基于模块工作的,本身没有批量部署的能力.真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架.主要包括:(1)连接插件connection plugins:负责和被监控端实现通信:(2)host inventory:指定操作的主

ansible自动化运维工具

简介 ansible是新出现的运维工具是基于Python研发的糅合了众多老牌运维工具的优点实现了批量操作系统配置.批量程序的部署.批量运行命令等功能. 1.ansible的安装直接用yum安装,配置好epel源即可. 2.ansible安装目录在/etc/ansible下. 服务器环境 192.168.32.200:作为ansible管理节点 192.168.32.202:被管理节点 ansible.cfg配置文件 hostfile=/etc/ansible/hosts #指定默认hosts配置

Ansible自动化运维工具阐述及配置实现

什么是ansible ansible是一个轻量级的运维管理工具 , 基于Python研发 .可实现对系统的批量管理配置.程序的批量部署.批量的运行命令等功能. 仅需在任意管理主机安装 ansible 程序即可实现批量管理被管控主机且被管控的主机无需客户端. 我们在安装ansible时一定要依托epel源来安装(推荐阿里云),并且在线用yum安装.它基于python开发所以得解决ansible对python编程的各种依赖. ansible 特性 1.模块化:调用特定的模块,完成特定的任务: 2.基

Ansible 自动化运维工具之when条件语句

1.When语句 有时候用户有可能需要某一个主机越过某一个特定的步骤.这个过程就可以简单的像在某一个特定版本的系统上少装了一个包一样或者像在一个满了的文件系统上执行清理操作一样. 这些操作在Ansible上,若使用`when`语句都异常简单.When语句也含Jinja2表达式, 第一个例子: tasks:   - name: "shutdown Debian flavored systems"     command: /sbin/shutdown -t now     when: a

Ansible 自动化运维工具之inventory和常用模块介绍

一.inventory介绍 前面我们介绍过ansible的hosts文件是存放被管理主机的,被管理主机比较少的情况下,直接在hosts中定义即可,但是以后很定会管理多台主机,而ansible可管理的主机集合就叫做inventory.在ansible中,描述你主机的默认方法是将它们列在一个文本文件中,这个文件叫inventory文件. 一个简单的inventory文件可能只包含一组主机名的列表,如下: ftp.testansible.com samba.testansible.com mail.t

Ansible 自动化运维工具简单入门(二)

三.Ansible的使用 1.Ansible命令执行过程及状态 过程: 加载自己的配置文件,默认/etc/ansible/ansible.cfg 加载自己对应的模块文件,如command ping 通过ansible将模块或命令生成对应的临时py文件,并将该文件传输至远程服务器 给文件+x权限 执行并返回结果 删除临时py文件,sleep 10 退出 状态: 绿色:执行成功并且不需要做改变的动作 黄色:执行成功并且对目标主机做变更 红色:执行失败 2.Ansible系列命令 ansible an